当前位置: 首页 > news >正文

<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二次开发问题,评论区留言讨论! 👇

http://www.jsqmd.com/news/335921/

相关文章:

  • 上海肺结节就医指南:如何为肺结节手术寻找精准方案
  • <span class=“js_title_inner“>rk3568上解析webrtc音频降噪算法处理流程</span>
  • 咸宁管道疏通服务现状与可靠机构盘点 - 2026年企业推荐榜
  • <span class=“js_title_inner“>rk3568移植WebRTC AudioProcessing</span>
  • 2026年咸宁管道疏通服务公司综合实力与口碑盘点 - 2026年企业推荐榜
  • 2026年咸宁管道疏通服务商选择指南:6家优质公司深度解析 - 2026年企业推荐榜
  • <span class=“js_title_inner“>Python+tkinter程序中ttk.Progressbar进度条组件用法演示</span>
  • 2026年国内兰州轻钢龙骨厂家采购参考指南 - 行业平台推荐
  • VPX架构军工级SSD选型指南:板级定制与国产化解决方案(2026)
  • 2026年初粮油批发定制厂商竞争格局深度分析 - 2026年企业推荐榜
  • 2026年热门的兰州吊顶石膏板/青海石膏板值得信赖厂家推荐(精选) - 行业平台推荐
  • <span class=“js_title_inner“>真正的AI手机永远不会有了吗?</span>
  • 腾讯宣布:发10亿现金红包!
  • <span class=“js_title_inner“>2033年将破40亿美元!区块链+AI 撞出“信任+智能”的超级风口</span>
  • 最后一天。
  • <span class=“js_title_inner“>Siri 终于要“死”了?苹果 iOS 27 惊天曝光:这次不仅是更新,而是换脑!</span>
  • 【硬件测试】基于FPGA的8PSK+卷积编码Viterbi译码硬件片内测试,包含帧同步,信道,误码统计,可设置SNR
  • 前后端分离人事管理系统系统|SpringBoot+Vue+MyBatis+MySQL完整源码+部署教程
  • <span class=“js_title_inner“>让 AI 也能当“反洗钱专家“——一个通俗易懂的模型训练故事</span>
  • 通过 DeepFlow 查询函数在 CPU 上消耗的时间(CPU 性能剖析)
  • 2026年靠谱的防火石膏板/纸面石膏板新厂实力推荐(更新) - 行业平台推荐
  • 2026年口碑好的青甘大环线旅游/西北旅游客户认可榜 - 行业平台推荐
  • 2026硝化菌厂家甄选指南:三大维度与顶尖服务商解析 - 2026年企业推荐榜
  • Vue-day6 路由!
  • Linux命令--echo~反引号符~重定向符(>>)~tail命令
  • which命令
  • C++_竞态_底层原理解释
  • 基于FPGA的8PSK+卷积编码Viterbi译码通信系统,包含帧同步,信道,误码统计,可设置SNR
  • 2026年健康无添加石榴汁供货商实力盘点 - 2026年企业推荐榜
  • 2026年靠谱的私人定制旅行社/1V1旅行社口碑推荐榜 - 行业平台推荐