明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1913|回复: 3

关于扩展数据问题

[复制链接]
发表于 2011-7-12 11:22:15 | 显示全部楼层 |阅读模式

    <CommandMethod("S3")> _
Public Sub SelectObjectsOnscreen3()
        '' 获得当前文档和数据库   Get the current document and database
        Dim acDoc As Document = Application.DocumentManager.MdiActiveDocument
        Dim acCurDb As Database = acDoc.Database
        ''启动一个事务   Start a transaction
        Using acTrans As Transaction = acCurDb.TransactionManager.StartTransaction()
            '' 要求在图形区域中选择对象    Request for objects to be selected in the drawing area
            Dim acSSPrompt As PromptSelectionResult = acDoc.Editor.GetSelection()
            '' 如果提示状态是 OK,对象就被选择了    If the prompt status is OK, objects were selected
            If acSSPrompt.Status = PromptStatus.OK Then
                Dim acSSet As SelectionSet = acSSPrompt.Value
                '' 遍历选择集中的对象   Step through the objects in the selection set
                For Each acSSObj As SelectedObject In acSSet
                    '' 检查以确定返回的 SelectedObject 对象是有效的     Check to make sure a valid SelectedObject object was returned
                    If Not IsDBNull(acSSObj) Then
                        '' 以写的方式打开选择的对象   Open the selected object for write
                        Dim acEnt As Entity = acTrans.GetObject(acSSObj.ObjectId, _
                                                                OpenMode.ForWrite)
                        If Not IsDBNull(acEnt) Then
                            '' 修改对象的颜色为绿色   Change the object's color to Green
                            acEnt.ColorIndex = 3

                            Dim df As ResultBuffer = New ResultBuffer
                            df.Add(New TypedValue(DxfCode.ExtendedDataRegAppName, "AppName"))
                            df.Add(New TypedValue(DxfCode.ExtendedDataAsciiString, "objll"))
                            acEnt.XData = df

                        End If
                    End If
                Next
                '' 保存新对象到数据库中   Save the new object to the database
                acTrans.Commit()
            End If
            '' 销毁事务  Dispose of the transaction
        End Using
    End Sub

此处报错 acEnt.XData = df     eRegappIdNotFound
发表于 2011-7-12 13:17:32 | 显示全部楼层
你需要先添加注册应用程序名
 楼主| 发表于 2011-7-14 14:19:40 | 显示全部楼层
sieben 发表于 2011-7-12 13:17
你需要先添加注册应用程序名

请问怎么添加呀?
发表于 2011-7-14 16:16:20 | 显示全部楼层
VB的代码我不懂 ,你去搜 RegAppTable RegAppTableRecord 这两个关键字吧;

DxfCode.ExtendedDataRegAppName, "AppName")) 里面的"AppName"是对应的这个名字的 RegAppTableRecord ,你要使用它之前需要先有这个东西,它是应用注册表RegAppTable里面的一个记录
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-11-25 21:44 , Processed in 0.161227 second(s), 24 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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