news 2026/5/10 12:09:09

<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/4/28 7:19:08

which命令

which命令&#xff0c;查看所使用的一系列命令的程序文件存放在哪里语法:which要查找的命令find 用于查找指定的文件按文件名查找:find起始路径 -name"被查找文件名"支持通配符按文件大小查找:find 起始路径-size1-n[kMG]

作者头像 李华
网站建设 2026/5/10 5:53:11

<span class=“js_title_inner“>ZYNQ MPSOC VCU介绍</span>

1 什么是VCU?VCU 的全称是 Video Codec Unit&#xff0c;即视频编解码单元&#xff0c; Zynq UltraScale MPSoC 系列产品分为三种类型&#xff0c;分别是 CG 型器件、 EG 型器件和 EV 型器件&#xff0c; 其中只有 EV 型器件集成了 VCU。 VCU 适用于视频监控和网络视频连接应用…

作者头像 李华
网站建设 2026/4/25 18:35:56

企业级社区养老服务系统管理系统源码|SpringBoot+Vue+MyBatis架构+MySQL数据库【完整版】

摘要 随着人口老龄化进程的加快&#xff0c;社区养老服务需求日益增长&#xff0c;传统的养老服务模式已难以满足现代社会的需求。社区养老服务系统的数字化、智能化成为提升服务效率和质量的关键。企业级社区养老服务系统通过整合资源、优化管理流程&#xff0c;为老年人提供便…

作者头像 李华
网站建设 2026/5/9 21:18:52

企业级在线互动学习网站管理系统源码|SpringBoot+Vue+MyBatis架构+MySQL数据库【完整版】

摘要 随着信息技术的快速发展和教育模式的数字化转型&#xff0c;企业级在线互动学习平台成为提升员工培训效率和知识管理的重要工具。传统线下培训模式受限于时间和空间&#xff0c;难以满足现代企业灵活、高效的学习需求。在线学习系统通过实时互动、个性化课程推荐和数据分…

作者头像 李华
网站建设 2026/5/9 22:19:45

SpringBoot+Vue 社区养老服务系统管理平台源码【适合毕设/课设/学习】Java+MySQL

摘要 随着人口老龄化问题日益加剧&#xff0c;社区养老服务需求快速增长&#xff0c;传统养老服务模式已无法满足高效化、信息化的管理需求。社区养老服务系统管理平台旨在通过数字化手段优化养老服务流程&#xff0c;提升服务效率和质量。该系统整合了老年人健康档案管理、服务…

作者头像 李华
网站建设 2026/5/9 22:19:45

本地 vs 云端部署:成本、隐私、延迟、运维复杂度怎么选?

传送锚点TL;DR&#xff08;给赶时间的读者&#xff09;1) 先把概念说清&#xff1a;本地、云端、混合各是什么&#xff1f;2) 成本对比&#xff1a;CAPEX vs OPEX&#xff0c;隐藏账单在哪里&#xff1f;2.1 本地成本&#xff08;On-Prem&#xff09;的真实构成2.2 云端成本&am…

作者头像 李华