找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 682|回复: 0

[每日一码] .NET存取组

[复制链接]

已领礼包: 6个

财富等级: 恭喜发财

发表于 2016-8-1 08:49:23 | 显示全部楼层 |阅读模式

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

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

×
How to access AutoCAD Group subsystem via .NET

Issue
I want to extract the ObjectIds that make up a particular Group, how can it be done?

Solution
Here's some sample code written in VB.NET to show how to do what you want.


' Define command 'getGroupIds' - by Fenton Webb, DevTech, Autodesk 12/09/2006
<CommandMethod("getGroupIds")> _
Public Sub getGroupIds()
' input the group name we want to list
Dim ed As Editor = Application.DocumentManager.MdiActiveDocument.Editor
Dim groupName As PromptResult = ed.GetString("Enter Group name to list : ")
' get the working database
Dim db As Database = Autodesk.AutoCAD.DatabaseServices.HostApplicationServices.WorkingDatabase
' start a transaction
Dim trans As Transaction = db.TransactionManager.StartTransaction()
' now try the read
Try
' get the named objects dictionary
Dim nod As DBDictionary = trans.GetObject(db.NamedObjectsDictionaryId, OpenMode.ForRead)
' now get the ACAD_GROUP dictionary entry, this contains all of the Groups defined in the drawing
Dim acadGroup As DBDictionary = trans.GetObject(nod("ACAD_GROUP"), OpenMode.ForRead)
' next, find the group name that was entered above
Dim groupRequired As Group = trans.GetObject(acadGroup(groupName.StringResult), OpenMode.ForRead)
' we now have the group required, lets find out what's inside
Dim entityIds As ObjectId() = groupRequired.GetAllEntityIds()
Dim id As ObjectId
For Each id In entityIds
' open the entity for read
Dim ent As Entity = trans.GetObject(id, OpenMode.ForRead)
' create the highlight path
Dim path As FullSubentityPath = New FullSubentityPath(New ObjectId(0) {id}, New SubentityId(SubentityType.Null, 0))
' now highlight it
ent.Highlight(path, True)
Next
trans.Commit()
Catch ex As Exception
MsgBox(ex.Message)
trans.Dispose()
Finally
End Try
End Sub

论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2024-4-18 11:42 , Processed in 0.377771 second(s), 27 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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