田草博客

互联网田草博客


网友交流QQ群:11740834 需注明申请加入原因

微信 公众号:ByCAD

邮箱:tiancao1001x126.com
ByCAD,微信公众号
首页 | 普通 | 电脑 | AutoCAD | VB/VB.NET | FLash | 结构 | 建筑 | 电影 | BIM | 规范 | 软件 | ID
-随机-|-分布-
-博客论坛-|-﨣﨤﨧﨨-
-网站导航-|-规范下载-
-BelovedFLash欣赏-

用户登陆
用户:
密码:
 

站点日历
73 2024 - 3 48
     12
3456789
10111213141516
17181920212223
24252627282930
31


站点统计

最新评论



隐藏日志,无权浏览 AutoCAD 为索引符号添加连接到zoomwindow
未知 AutoCAD VB.Net 选择一个参照块后自动选择所有同名的参照块   [ 日期:2009-11-24 ]   [ 来自:本站原创 ]  HTML
   <CommandMethod("SelectBlockRef")> _
   Public Sub SelectBlockRef()
        On Error Resume Next
        Dim acDoc As Document = Application.DocumentManager.MdiActiveDocument
        Dim acCurDb As Database = acDoc.Database
        Dim acEditor As Editor = Autodesk.AutoCAD.ApplicationServices.Application.DocumentManager.MdiActiveDocument.Editor
        Dim prEnt As PromptEntityOptions = New PromptEntityOptions("选择一个对象:")
        Dim prEntRes As PromptEntityResult = acEditor.GetEntity(prEnt)
        Using acTrans As Transaction = acCurDb.TransactionManager.StartTransaction()
            Dim Obj As Object = acTrans.GetObject(prEntRes.ObjectId, OpenMode.ForRead)
            MsgBox(Obj.GetType.ToString) '返回对象类型
            Dim ObjFullName As String = Obj.GetType.FullName
            Dim ObjName As String = ObjFullName.Substring(InStrRev(ObjFullName, "."))
            If ObjName = "BlockReference" Then
                Dim BlockRef As BlockReference = Obj
                Dim BlockRecord As BlockTableRecord
                BlockRecord = acTrans.GetObject(BlockRef.BlockTableRecord, _
                                           OpenMode.ForRead)
                '这才得到参照块的名称
                'MsgBox(BlockRecord.Name)
                '过滤条件
                Dim acTypValAr(0) As TypedValue
                acTypValAr.SetValue(New TypedValue(DxfCode.BlockName, BlockRecord.Name), 0)
                Dim acSelFtr As SelectionFilter = New SelectionFilter(acTypValAr)
                Dim acSSPrompt As PromptSelectionResult = acEditor.SelectAll(acSelFtr)
                Dim acSSet As SelectionSet = acSSPrompt.Value
                '……
            Else
                acEditor.WriteMessage(vbLf & "请选择图框参照块。")
                Exit Sub
            End If
            acTrans.Commit()
        End Using
        If Err.Number <> 0 Then  MsgBox(Err.Description)
    End Sub




暂时没有评论
发表评论 - 不要忘了输入验证码哦!
作者: 用户:  密码:   注册? 验证:  防止恶意留言请输入问题答案:2*6=?  
评论:

禁止表情
禁止UBB
禁止图片
识别链接
识别关键字

字体样式 文字大小 文字颜色
插入粗体文本 插入斜体文本 插入下划线
左对齐 居中对齐 右对齐
插入超级链接 插入邮件地址 插入图像
插入 Flash 插入代码 插入引用
插入列表 插入音频文件 插入视频文件
插入缩进符合
点击下载按钮 下标 上标
水平线 简介分割标记
表  情
 
Tiancao Blog All Rights Reserved 田草博客 版权所有
Copyright ©