田草博客

互联网田草博客


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

微信 公众号:ByCAD

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

用户登陆
用户:
密码:
 

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


站点统计

最新评论



清除带属性文字的属性 天正建筑8.5 2012.12.02 过期补丁
未知 在AutoCAD中生成块的缩略图 BlockPreviews   [ 日期:2012-11-25 ]   [ 来自:本站原创 ]  HTML
'原文:http://through-the-interface.typepad.com/through_the_interface/2011/11/gen ... -blocks-in-an-autocad-drawing-using-net.html
'VB.Net翻译转换 田草博客 www.tiancao.net
Imports Autodesk.AutoCAD.ApplicationServices
Imports Autodesk.AutoCAD.DatabaseServices
Imports Autodesk.AutoCAD.EditorInput
Imports Autodesk.AutoCAD.Geometry
Imports Autodesk.AutoCAD.Runtime
Imports System.IO
Namespace BlockPreviews
    Public Class Commands
        <CommandMethod("GBP", CommandFlags.Session)> _
        Public Shared Sub GenerateBlockPreviews()
            Dim ed As Editor = Application.DocumentManager.MdiActiveDocument.Editor
            Dim res As PromptFileNameResult = ed.GetFileNameForOpen("选择你要生成预览图像的文件:")
            If res.Status <> PromptStatus.OK Then
                Return
            End If
            Dim doc As Document = Nothing
            Try
                doc = Application.DocumentManager.Open(res.StringResult, False)
            Catch
                ed.WriteMessage(vbLf & "图形文件无效.")
                Return
            End Try
            Dim db As Database = doc.Database
            Dim path As String = System.IO.Path.GetDirectoryName(res.StringResult), name As String = System.IO.Path.GetFileName(res.StringResult), iconPath As String = path + "\" + name + " icons"
            Dim numIcons As Integer = 0
            Dim tr As Transaction = doc.TransactionManager.StartTransaction()
            Using tr
                Dim table As BlockTable = CType(tr.GetObject(db.BlockTableId, OpenMode.ForRead), BlockTable)
                For Each blkId As ObjectId In table
                    Dim blk As BlockTableRecord = CType(tr.GetObject(blkId, OpenMode.ForRead), BlockTableRecord)
                    ' 忽略布局和匿名块
                    If blk.IsLayout OrElse blk.IsAnonymous Then
                        Continue For
                    End If
                    ' 当缩略图不在时,生成缩略图
                    If blk.PreviewIcon Is Nothing Then
                        Dim ActiveDocument As Object = doc.AcadDocument
                        Dim data As Object() = {"_.BLOCKICON " + blk.Name + vbLf}
                        ActiveDocument.[GetType]().InvokeMember("SendCommand", System.Reflection.BindingFlags.InvokeMethod, Nothing, ActiveDocument, data)
                    End If
                    ' 现在所有块都有了缩略图
                    If blk.PreviewIcon IsNot Nothing Then
                        ' 创建一个输出文件夹
                        If Not Directory.Exists(iconPath) Then
                            Directory.CreateDirectory(iconPath)
                        End If
                        ' 保存缩略图至文件夹
                        blk.PreviewIcon.Save(iconPath + "\" + blk.Name + ".bmp")
                        ' 图标计数器加1
                        System.Math.Max(System.Threading.Interlocked.Increment(numIcons), numIcons - 1)
                    End If
                Next
                tr.Commit()
            End Using
            doc.CloseAndDiscard()
            ed.WriteMessage(vbLf & "{0} block icons saved to ""{1}"".", numIcons, iconPath)
        End Sub
    End Class
End Namespace


【BlockPreviews.rar】点击下载此文件



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

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

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