找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 753|回复: 2

[求助]:请教对选择集中的对象的判断条件

[复制链接]
发表于 2006-8-1 10:29:25 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

×
Sub tt()
   Dim tuceng1 As AcadSelectionSet
   

'×××××使用选择集前最应该使用的判断×××××××××
Dim xzj As Object
   For Each xzj In ThisDrawing.SelectionSets
         If xzj.Name = "tuceng1" Then
           ThisDrawing.SelectionSets.Item("tuceng1").Delete
         End If
    Next
'××××××××忘了当初是摘的还是想的。以上我认为是使用选择集中最应该使用的判断×××××'这种方法可以避免出现提示选择集存在无法创建,或者是没有选择集而强制删除××××导致操作失败的结果
  Dim ss As Object
   Set ss = ThisDrawing.SelectionSets.Add("tuceng1")
   ss.Select acSelectionSetAll

   dim i as acadobject
   For Each i In ss
    If i.Layer = tt  and i.lineweight  = 0.30 and i.color = 80 Then          '此处我想加入的判断条件:图层,线宽,颜色等等,此处出错了。无法达到我的需要。不知道是不是我i的定义错了还是怎么回事,除了LAYER可以正确的识别,其他的都不行,求助大家了

            i.Layer = "kk"

                       Update
     
          End If
          Next
  End Sub

在线苦等中
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2006-8-2 13:35:46 | 显示全部楼层
你可以用过滤器吗
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2006-8-2 22:40:38 | 显示全部楼层
我的目的是:
选择屏幕上所有的线
然后按照图层,线型,线宽大小,颜色号等信息重新分层。
补充一下程序的过滤器
Sub tt()
Dim tuceng1 As AcadSelectionSet
Dim xzj As Object
For Each xzj In ThisDrawing.SelectionSets
If xzj.Name = "tuceng1" Then
ThisDrawing.SelectionSets.Item("tuceng1").Delete
End If
Next

Dim FilterType(0 To 6) As Integer
    Dim FilterData(0 To 6) As Variant
    FilterType(0) = -4
    FilterData(0) = "<or"  
    FilterType(1) = 0
    FilterData(1) = "Arc"
    FilterType(2) = 0
    FilterData(2) = "Circle"
    FilterType(3) = 0
    FilterData(3) = "Line"
    FilterType(4) = 0
    FilterData(4) = "Polyline"
    FilterType(5) = 0
    FilterData(5) = "LWPolyline"
    FilterType(6) = -4
    FilterData(6) = "or>
   
   ss.Select acSelectionSetAll, , , FilterType, FilterData
Dim ss As Object
Set ss = ThisDrawing.SelectionSets.Add("tuceng1")
ss.Select acSelectionSetAll

dim i as acadobject
For Each i In ss
       If i.Layer = tt and i.ConstantWidth = 0.30 and i.color = 80 Then
    i.Layer = "kk1"
       Update
      elseif  i.layer = 22 and i.ConstantWidth= 0.30 then      
      i.layer= "kk2"
       End If
      Next
End Sub
个人觉的,如果可以用if来区分的话
如上所示
可能要简洁,易读一些
我总共有一百多个图层
如果每个层都用过滤器,程序可能会很冗长
现在图层用layer这个参数是正确的
都是多义线的时候constantwidth也正确
color就不对了,其他的参数试了很多,就是不行
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-9-28 17:35 , Processed in 0.234746 second(s), 33 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表