明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
12
返回列表 发新帖
楼主: tataki

选择集内多段线排序问题

[复制链接]
发表于 2016-1-7 22:05 | 显示全部楼层
我想这个应该不涉及CAD的数据库,选择集里元素是对象,
SSet.Item(ii + 1) = SSet.Item(ii)为什么错误,因为对象不能直接用等于。
既然是对象,就应该加上SET
所以
               SSet.Item(ii + 1) = SSet.Item(ii)
                SSet.Item(ii) = iTemp
都应该加SET
 楼主| 发表于 2016-1-7 22:36 | 显示全部楼层
本帖最后由 tataki 于 2016-1-7 22:40 编辑
vbcad 发表于 2016-1-7 22:05
我想这个应该不涉及CAD的数据库,选择集里元素是对象,
SSet.Item(ii + 1) = SSet.Item(ii)为什么错误,因 ...

你说的加上 set ,我前天也试过了,然后这个错误就没有了,但是...我单步运行的时候,在交换语句那里没有错误,问题是执行过交换后,这个sset里面item的顺序并没有互换,也就是说即使程序执行了交换动作,也是无效的。。。这个我就非常奇怪。
我用debug命令都显示了交换前后的面积,结果仍然是一样的,见图片里红框的地方。我也不清楚为什么会这样~~

本帖子中包含更多资源

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

x
发表于 2016-1-7 22:42 来自手机 | 显示全部楼层
选择集的顺序在选择后是不可变的 因为底层的对象还包含选择方式,选择点等参数
Vba的选择集只是个封装
 楼主| 发表于 2016-1-7 22:50 | 显示全部楼层
雪山飞狐_lzh 发表于 2016-1-7 22:42
选择集的顺序在选择后是不可变的 因为底层的对象还包含选择方式,选择点等参数
Vba的选择集只是个封装

感谢飞狐版主热心解释。
我觉得这种问题非常隐蔽和晦涩,程序一路运行下去一点错都不报,但是就是没有效果,如果不了解到底层对象这些概念,发现不了问题。
另外,飞狐版主对于选择集顺序等不可改变这些信息是从哪里来获取?对这些没有概念啊。
发表于 2016-1-7 22:58 来自手机 | 显示全部楼层
Objectarx和.netapi的选择集的组成都是这样
选择集是selectedobject对象的集合
而该对象包含objectid  pickpoint  selectmode等
Vba的选择集应该是在objectarx选择集基础的封装
发表于 2016-10-25 19:20 | 显示全部楼层
给你个解决办法:
Sub 多段线按面积按大小输出()
    Dim SSet As AcadSelectionSet
    Dim ftype(0 To 1) As Integer
    Dim fdata(0 To 1) As Variant

    ftype(0) = 0: fdata(0) = "LWPolyline" '定义过滤器筛选类别,筛选 多段线
    ftype(1) = 8: fdata(1) = "*" '定义过滤器筛选图层,筛选 parts图层
    On Error Resume Next
    If Not IsNull(ThisDrawing.SelectionSets.Item("SSetParts")) Then Set SSet = ThisDrawing.SelectionSets.Item("SSetParts"): SSet.Delete
    On Error GoTo 0
    Set SSet = ThisDrawing.SelectionSets.Add("SSetParts")
    SSet.Select acSelectionSetAll, , , ftype, fdata

    '选择集转换为对象数组:返回包含于选择集中每一项目的变体数组
    Dim i As Long
    Dim retVal() As AcadEntity
    ReDim retVal(0 To SSet.Count - 1)
    For i = 0 To SSet.Count - 1
        Set retVal(i) = SSet.Item(i)
        Debug.Print SSet.Item(i).area   '逐个显示排序前的面积
    Next
   
    '冒泡排序:按照面积从小到大的顺序
    Dim iOuter As Long
    Dim iInner As Long
    Dim iLBound As Long
    Dim iUBound As Long
    Dim iTemp As AcadEntity

    iLBound = LBound(retVal):    iUBound = UBound(retVal)

    '冒泡排序
    For iOuter = iLBound To iUBound - 1
        For iInner = iLBound To iUBound - iOuter - 1
            If retVal(iInner).area > retVal(iInner + 1).area Then '比较相邻项
                Set iTemp = retVal(iInner)
                Set retVal(iInner) = retVal(iInner + 1) '交换
                Set retVal(iInner + 1) = iTemp
            End If
        Next iInner
    Next iOuter

    Debug.Print "面积从小到大排序结果: "
    Dim ipart2 As AcadEntity
    For i = 0 To UBound(retVal)
        Set ipart2 = retVal(i)
        Debug.Print ipart2.area
    Next
End Sub
发表于 2016-10-25 19:22 | 显示全部楼层
根本没那么玄乎.
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-4-17 00:56 , Processed in 0.237123 second(s), 17 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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