news 2026/6/10 12:53:25

<span class=“js_title_inner“>【AutoCAD二次开发】一键获取CAD块信息!实用技巧大公开</span>

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
<span class=“js_title_inner“>【AutoCAD二次开发】一键获取CAD块信息!实用技巧大公开</span>

还在手动查看CAD块属性?这个工具让你一键获取所有块信息!

为什么需要获取块信息?

在CAD设计中,块(Block)是重用图形元素的重要方式。但当你需要:

  • 批量统计图纸中的块

  • 分析块的属性信息

  • 导出块数据做进一步处理

  • 检查动态块的参数设置

传统的手动查看方式效率低下!今天分享一个实用的块信息提取工具。

功能亮点:这个工具能做什么?

选择块获取信息- 交互式选择任意块参照
通过句柄查找- 用唯一标识快速定位块
从文件读取- 直接分析DWG文件中的块
批量获取所有块- 一键获取图纸中所有块信息
动态属性提取- 专门处理动态块的参数
可视化操作- 高亮显示、缩放定位



核心代码解析

1. 选择并获取块信息(最常用)

public async Task<BlockSimpleInfo> SelectAndGetBlockInfoAsync(){ // 创建文档锁定,确保线程安全 using (DocumentLock docLock = doc.LockDocument()) { // 提示用户选择块 var promptOptions = new PromptEntityOptions("\n请选择一个块参照: "); promptOptions.AddAllowedClass(typeof(BlockReference), true); var promptResult = editor.GetEntity(promptOptions); if (promptResult.Status == PromptStatus.OK) { // 获取块参照对象 var blockRef = transaction.GetObject(promptResult.ObjectId, OpenMode.ForRead) as BlockReference; if (blockRef != null) { // 转换为简单信息对象 return ConvertToBlockSimpleInfo(blockRef, transaction); } } }}

注意在选择时必须要用下面代码去文档锁定不然会抛出下面这个异常信息

Autodesk.AutoCAD.Runtime.Exception:“eInvalidInput”

using (DocumentLock docLock = doc.LockDocument())

2. 通过句柄查找块(快速定位)

public async Task<BlockSimpleInfo> GetBlockInfoByHandleAsync(string blockHandle){ // 通过句柄获取对象ID var objectId = GetObjectIdByHandle(blockHandle); if (objectId.IsValid) { var blockRef = transaction.GetObject(objectId, OpenMode.ForRead) as BlockReference; if (blockRef != null) { return ConvertToBlockSimpleInfo(blockRef, transaction); } }}

3. 批量获取所有块信息

public async Task<List<BlockSimpleInfo>> GetAllBlocksInfoAsync(){ var blocks = new List<BlockSimpleInfo>(); // 获取模型空间 var modelSpace = (BlockTableRecord)transaction.GetObject( SymbolUtilityServices.GetBlockModelSpaceId(_currentDocument.Database), OpenMode.ForRead); // 遍历所有实体 foreach (ObjectId objectId in modelSpace) { var entity = transaction.GetObject(objectId, OpenMode.ForRead) as Entity; if (entity is BlockReference blockRef) { var blockInfo = ConvertToBlockSimpleInfo(blockRef, transaction); blocks.Add(blockInfo); } } return blocks;}

信息转换:从块参照到结构数据

private BlockSimpleInfo ConvertToBlockSimpleInfo( BlockReference blockRef, Transaction transaction){ return new BlockSimpleInfo { Id = Guid.NewGuid().ToString(), Name = GetRealBlockName(blockRef, transaction), // 获取真实块名 Handle = blockRef.Handle.ToString(), // 唯一句柄 Layer = blockRef.Layer, // 所在图层 Color = blockRef.Color.ToString(), // 颜色 Position = FormatPosition(blockRef.Position), // 位置坐标 Rotation = ToDegrees(blockRef.Rotation), // 旋转角度 Scale = FormatScale(blockRef.ScaleFactors), // 缩放比例 IsDynamicBlock = blockRef.IsDynamicBlock, // 是否动态块 HasAttributes = blockRef.AttributeCollection.Count > 0 // 是否有属性 };}

这里面BlockSimpleInfo类可以增加别的虎丘参数哦!不局限于实例提供的。


实战演示:创建块信息查看器

步骤1:创建Ribbon按钮

// 在之前Ribbon教程的基础上添加var blockButton = new RibbonButton{ Text = "块信息工具", ShowText = true, Size = RibbonItemSize.Large, CommandHandler = new BlockInfoCommandHandler()};panel.Items.Add(blockButton);

步骤2:创建块信息窗口

<!-- WPF窗口用于显示块信息 --><Window x:Class="BlockInfoViewer" Title="CAD块信息查看器" Height="600" Width="800"> <Grid> <Grid.RowDefinitions> <RowDefinition Height="Auto"/> <RowDefinition Height="*"/> </Grid.RowDefinitions> <!-- 工具栏 --> <StackPanel Grid.Row="0" Orientation="Horizontal" Margin="10"> <Button Content="选择块" Click="SelectBlock_Click" Width="80"/> <Button Content="获取全部" Click="GetAllBlocks_Click" Width="80"/> <Button Content="高亮显示" Click="HighlightBlock_Click" Width="80"/> <Button Content="缩放定位" Click="ZoomToBlock_Click" Width="80"/> </StackPanel> <!-- 块信息列表 --> <DataGrid Grid.Row="1" x:Name="BlocksGrid" AutoGenerateColumns="False"> <DataGrid.Columns> <DataGridTextColumn Header="名称" Binding="{Binding Name}"/> <DataGridTextColumn Header="图层" Binding="{Binding Layer}"/> <DataGridTextColumn Header="位置" Binding="{Binding Position}"/> <DataGridTextColumn Header="句柄" Binding="{Binding Handle}"/> <DataGridCheckBoxColumn Header="动态块" Binding="{Binding IsDynamicBlock}"/> </DataGrid.Columns> </DataGrid> </Grid></Window>

步骤3:连接CAD与界面

public partial class BlockInfoViewer : Window{ private readonly BlockInfoService _blockService; public BlockInfoViewer() { InitializeComponent(); _blockService = new BlockInfoService(); LoadAllBlocks(); } private async void SelectBlock_Click(object sender, RoutedEventArgs e) { var blockInfo = await _blockService.SelectAndGetBlockInfoAsync(); if (blockInfo != null) { ShowBlockDetails(blockInfo); } } private async void LoadAllBlocks() { var blocks = await _blockService.GetAllBlocksInfoAsync(); BlocksGrid.ItemsSource = blocks; }}



高级功能:动态块属性提取

public async Task<List<BlockDynamicProperty>> GetBlockDynamicPropertiesAsync( string blockHandle){ var properties = new List<BlockDynamicProperty>(); var blockRef = GetBlockByHandle(blockHandle); if (blockRef != null && blockRef.IsDynamicBlock) { // 获取动态块属性集合 var dynamics = blockRef.DynamicBlockReferencePropertyCollection; foreach (DynamicBlockReferenceProperty property in dynamics) { properties.Add(new BlockDynamicProperty { PropertyName = property.PropertyName, Value = property.Value?.ToString() ?? "", Description = property.Description ?? "", ReadOnly = property.ReadOnly, Visible = property.Show, AllowedValues = GetAllowedValues(property) // 获取允许的值 }); } } return properties;}

选择一个块效果图如下哦:



使用技巧

// 在CAD中,选中块后输入LIST命令// 或在程序中:blockRef.Handle.ToString()

技巧2:处理动态块的特殊情况

// 动态块的真实名称在DynamicBlockTableRecord中if (blockRef.IsDynamicBlock){ var btr = transaction.GetObject(blockRef.DynamicBlockTableRecord, OpenMode.ForRead) as BlockTableRecord; string realName = btr?.Name ?? blockRef.Name;}

当发现你拿取的块名不对时那说明你拿取了动态块的名称了例如*U3,需要做一下处理才能拿到对应的名称哦!

常见问题解答

Q1:为什么获取不到动态块的原始名称?

原因:动态块使用代理块,需要访问DynamicBlockTableRecord
解决:使用上面提到的GetRealBlockName方法

Q2:如何处理嵌套块?

扩展:可以递归遍历块的BlockTableRecord获取嵌套结构

Q3:如何获取块的几何信息?

扩展:使用blockRef.GeometricExtents获取边界框

总结

通过这个块信息提取工具,你可以:

快速获取- 一键获取图纸中所有块信息
精准查找- 通过句柄或名称定位特定块
深度分析- 解析块的属性和动态参数
可视化操作- 高亮、缩放、导出等实用功能
批量处理- 高效处理大量块数据

有任何CAD二次开发问题,评论区留言讨论! 👇

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/5 7:16:40

Vue-day6 路由!

一.路由入门单页应用程序所有功能在一个html页面实现路由概念 路由是一种映射关系&#xff0c;Vue中的路由作用&#xff1a;路径和组件的映射关系 根据路由就能知道不同路径的&#xff0c;应该匹配渲染哪个组件VueRouter的基本使用535个基本步骤/1.下载v3.6.5//2.引入//3.安装注…

作者头像 李华
网站建设 2026/5/30 14:08:07

Linux命令--echo~反引号符~重定向符(>>)~tail命令

echo可以使用echo命令在命令行内输出指定内容 语法:echo输出的内容 无需选项&#xff0c;只有一个参数&#xff0c;表示要输出的内容&#xff0c;复杂内容可以用”"包围反引号符被’包围的内容&#xff0c;会被作为命令执行&#xff0c;而非普通字符重定向符>&#xff…

作者头像 李华
网站建设 2026/6/7 22:33:30

<span class=“js_title_inner“>先正达集团在中国加速布局全球级研发中心和制造工厂 | 美通社头条</span>

、美通社消息&#xff1a;全球领先的农业科技企业先正达集团将全球领先的植保研发中心落地上海&#xff0c;并在江苏南通同步建设高标准制剂与工程化平台。一个旨在贯通研发到应用的植保领域"中国地标"正日益清晰。今年1月&#xff0c;先正达集团全球植保中国创新中心…

作者头像 李华
网站建设 2026/5/23 19:38:13

Flutter for OpenHarmony Python学习助手实战:控制结构与流程控制的实现

控制结构决定了程序的执行流程&#xff0c;是编程逻辑的核心。在开发Python学习助手的过程中&#xff0c;我深刻体会到如何用Flutter为学习者打造一个优秀的控制结构与流程控制功能是多么重要。今天我来分享一下具体的实现思路和技术细节。 为什么控制结构如此重要 在我多年的…

作者头像 李华
网站建设 2026/5/24 22:59:17

【jenkins】testng+allure报告

testngallure报告的配置。 前提&#xff1a;testng本地化配置ok&#xff0c;执行无问题。【选中testng.xml 右键执行&#xff0c;用例执行顺利无异常】 1 本地化执行引入Allure 1.1 maven项目中的pom.xml添加Allure相关依赖 pom.xml添加依赖如下&#xff0c;有allure和衍生…

作者头像 李华
网站建设 2026/6/4 18:20:01

ZZ039移动应用与开发赛项模块A—移动应用界面设计原型图XD参考答案(七)

ZZ039移动应用与开发赛项模块A—移动应用界面设计原型图XD参考答案(七) 文章目录 ZZ039移动应用与开发赛项模块A—移动应用界面设计原型图XD参考答案(七) 模块A:移动应用界面设计 任务1:用户登录界面设计(7.5分) 任务2:健康首页界面设计(7.5分) 任务3:预约记录界面…

作者头像 李华