田草博客
日志搜索


 标题   内容 评论


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

微信 公众号:ByCAD

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

用户登陆
用户:
密码:
 

站点日历
73 2019 - 12 48
1234567
891011121314
15161718192021
22232425262728
293031


站点统计

最新评论



About Obtaining Entity Information (AutoLISP) Finding all block references of a dynamic block
未知 Vb.net acdbEntGet GetEntityDxf   [ 日期:2019-08-14 ]   [ 来自:本站原创 ]  HTML
https://forums.autodesk.com/t5/net/unnamed-ucs/td-p/4345297

程序代码:

<DllImport("acdb19.dll", CallingConvention:=CallingConvention.Cdecl, EntryPoint:="?acdbGetAdsName@@YA?AW4ErrorStatus@Acad@@AEAY01_JVAcDbObjectId@@@Z")> _
    Public Shared Function acdbGetAdsName_R19_64(name As Long(), objId As ObjectId) As Integer
    End Function

    <DllImport("accore.dll", CharSet:=CharSet.Ansi, CallingConvention:=CallingConvention.Cdecl, EntryPoint:="acdbEntGet")> _
    Public Shared Function acdbEntGet(ename As Long()) As System.IntPtr
    End Function

    <DllImport("accore.dll", CharSet:=CharSet.Ansi, CallingConvention:=CallingConvention.Cdecl, EntryPoint:="acdbEntGetX")> _
    Public Shared Function acdbEntGetX(ename As Long(), rb As IntPtr) As System.IntPtr
    End Function

    <CommandMethod("GetEntityDxf")> _
    Public Shared Sub GetEntityDxf()
        Dim doc As Document = Application.DocumentManager.MdiActiveDocument
        Dim ed As Editor = doc.Editor

        Dim per As PromptEntityResult = ed.GetEntity(vbLf & "Select an Entity: ")

        If per.Status <> PromptStatus.OK Then
            Return
        End If

        Dim ename As Long() = New Long() {0, 0}

        ' extract the id into an ename
        Dim result As Integer = acdbGetAdsName_R19_64(ename, per.ObjectId)

        ' now I have the ename lets entget it into a result buffer
        Dim rb As New ResultBuffer()
        Interop.AttachUnmanagedObject(rb, acdbEntGet(ename), True)

        ' print out what we have
        Dim iter As ResultBufferEnumerator = rb.GetEnumerator()

        While iter.MoveNext()
            Dim TmpVal As TypedValue = iter.Current

            Dim strValue As String = (If(TmpVal.Value IsNot Nothing, TmpVal.Value.ToString(), "*Nothing*"))

            ed.WriteMessage(vbLf & " - Code: " & TmpVal.TypeCode.ToString() & " = " & strValue)
        End While
    End Sub






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

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

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