找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 618|回复: 5

[求助]:用VBA如何实现命令"Draworder"的功能?

[复制链接]
发表于 2004-11-5 16:52:51 | 显示全部楼层 |阅读模式

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

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

×
斑竹、各位大侠:
    用VBA如何实现命令"Draworder"的功能?盼回答!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2004-11-5 17:04:50 | 显示全部楼层
下面代码可以将刚画好的图元放在底层,相当于draworder L  B
Thisdrawing.SendCommand "_DRAWORDER" _
& vbCr & "L" & vbCr & vbCr & "b" & vbCr
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2004-11-5 17:17:11 | 显示全部楼层
谢谢,但我要对获得的一批实体进行操作,如何进行呢?盼指教!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2004-11-5 20:53:40 | 显示全部楼层
Option Explicit

Sub Send2Back()
Dim objSS As AcadSelectionSet
On Error GoTo Done
    With ThisDrawing.Utility
    Set objSS = ThisDrawing.SelectionSets.Add("sset")
    objSS.SelectOnScreen
    End With
Done:
    If Not objSS Is Nothing Then
    objSS.Delete
    End If
ThisDrawing.SendCommand "_draworder" & vbCr & _
  "(ssget ""p"")" & vbCr & vbCr & "b" & vbCr
End Sub
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2004-11-6 11:54:37 | 显示全部楼层
多谢大侠指点。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2004-11-12 14:03:58 | 显示全部楼层
2005里可以这样:
Sub tt()
    'Gxet an extension dictionary and, if necessary, add a SortentsTable object
    Dim eDictionary As Object
    Set eDictionary = ThisDrawing.ModelSpace.GetExtensionDictionary
    ' Prevent failed GetObject calls from throwing an exception
    On Error Resume Next
    Dim sentityObj As Object
    Set sentityObj = eDictionary.GetObject("ACAD_SORTENTS")
    On Error GoTo 0
    If sentityObj Is Nothing Then
         ' No SortentsTable object, so add one
         Set sentityObj = eDictionary.AddObject("ACAD_SORTENTS", "AcDbSortentsTable")
    End If
    Dim ss As AcadSelectionSet
    Set ss = CreateSel
    ss.SelectOnScreen
    sentityObj.MoveToBottom Sel2Arr(ss)
End Sub

Function Sel2Arr(TlsSel As AcadSelectionSet)
    Dim objs() As AcadEntity
    Dim nCount As Integer
    nCount = TlsSel.Count - 1
    ReDim objs(nCount)
    For i = 0 To nCount
        Set objs(i) = TlsSel(i)
    Next i
    Sel2Arr = objs
End Function

Function CreateSel(Optional ByVal Name As String = "TlsSel")
On Error Resume Next
    ThisDrawing.SelectionSets(Name).Delete
    Set CreateSel = ThisDrawing.SelectionSets.Add(Name)
End Function
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-24 09:52 , Processed in 0.600486 second(s), 41 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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