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

Cad 反应器 cad c#二次开发

在 AutoCAD C# 二次开发中,`DocumentCollectionEventHandler` 是一个委托(delegate)**,用于处理与 AutoCAD 文档集合(DocumentCollection)相关的事件。它属于 AutoCAD .NET API 的事件处理机制,本质上是一种**反应器(Reactor)模式**的实现,用于响应文档生命周期事件(如创建、激活、销毁文档等)。

 

 

 

 

### 核心概念解释:

1. **DocumentCollection**  

   `Application.DocumentManager` 属性返回当前 AutoCAD 会话中所有打开文档的集合(`DocumentCollection`类)。

 

2. **事件类型**  

   `DocumentCollection` 包含以下关键事件:

   - `DocumentCreated`:创建新文档时触发

   - `DocumentActivated`:切换活动文档时触发

   - `DocumentToBeDestroyed`:文档关闭前触发

   - `DocumentLockModeChanged`:文档锁定状态变化时触发

 

3. **DocumentCollectionEventHandler**  

   这是处理上述事件的**委托签名**,定义如下:

   ```csharp

   public delegate void DocumentCollectionEventHandler(

       object sender, 

       DocumentCollectionEventArgs e

   );

   ```

 

---

 

### 完整代码示例(响应文档切换事件)

以下示例演示如何监听文档激活事件,并在切换文档时执行操作:

 

```csharp

using Autodesk.AutoCAD.ApplicationServices;

using Autodesk.AutoCAD.Runtime;

using Autodesk.AutoCAD.EditorInput;

 

public class DocumentEventReactor

{

    // 初始化时订阅事件

    public DocumentEventReactor()

    {

        DocumentCollection docCol = Application.DocumentManager;

        docCol.DocumentActivated += OnDocumentActivated;

    }

 

    // 文档激活事件处理

    private void OnDocumentActivated(object sender, DocumentCollectionEventArgs e)

    {

        Document activeDoc = e.Document;

        Editor ed = activeDoc.Editor;

        

        // 获取文档名称(不含路径)

        string docName = System.IO.Path.GetFileName(activeDoc.Name);

        

        // 在命令行显示提示

        ed.WriteMessage($"\n切换到文档: {docName} | 事件类型: {e.GetType().Name}");

        

        // 示例扩展操作:检查文档是否只读

        if (activeDoc.Database.ReadOnly)

        {

            ed.WriteMessage("\n警告:当前文档为只读模式!");

        }

    }

 

    // 清理时取消订阅(重要!)

    public void Unsubscribe()

    {

        DocumentCollection docCol = Application.DocumentManager;

        docCol.DocumentActivated -= OnDocumentActivated;

    }

}

 

// 在插件入口初始化

public class PluginCommands : IExtensionApplication

{

    private static DocumentEventReactor _reactor;

 

    public void Initialize()

    {

        _reactor = new DocumentEventReactor();

        Application.DocumentManager.MdiActiveDocument.Editor.WriteMessage(

            "\n文档事件反应器已启动");

    }

 

    public void Terminate()

    {

        _reactor?.Unsubscribe();

    }

}

```

 

---

 

### 关键功能说明:

1. **事件响应场景**:

   - 用户新建/打开文档

   - 在多个图形窗口间切换

   - 关闭文档前执行清理操作

   - 同步不同文档间的状态

 

2. **实际应用场景**:

   - **多文档协同**:在文档切换时更新全局变量

   - **许可控制**:限制特定文档的功能访问

   - **日志记录**:跟踪用户操作路径

   - **资源管理**:文档关闭时释放关联资源

 

3. **注意事项**:

   - **必须显式取消订阅**:否则导致内存泄漏(在 `Terminate()` 或 `Dispose()` 中处理)

   - **避免耗时操作**:事件处理应快速完成,否则影响用户体验

   - **线程安全**:事件在 AutoCAD 主线程触发,可直接操作 UI

 

---

 

### 其他常用事件处理示例:

#### 响应文档创建事件

```csharp

Application.DocumentManager.DocumentCreated += (sender, e) => 

{

    Editor ed = e.Document.Editor;

    ed.WriteMessage($"\n新文档已创建: {e.Document.Name}");

};

```

 

#### 响应文档关闭事件

```csharp

Application.DocumentManager.DocumentToBeDestroyed += (sender, e) => 

{

    // 保存自定义数据到外部文件

    string backupPath = $"C:\\Backups\\{e.Document.Name}.settings";

    SaveCustomData(e.Document, backupPath);

};

```

 

通过合理利用 `DocumentCollectionEventHandler`,您可以构建响应 AutoCAD 文档环境变化的智能插件,显著提升用户体验和自动化水平。

 

 

 

http://www.lqws.cn/news/151075.html

相关文章:

  • 网络测试实战:金融数据传输的生死时速
  • 第16期_网站搭建_Go个人版网络验证 虚拟主机搭建笔记 不推荐没卡密没完全搭建成功
  • 26考研 | 王道 | 计算机组成原理 | 三、存储系统
  • Selenium常用函数介绍
  • C++自定义简单的内存池
  • App使用webview套壳引入h5(三)——解决打包为app后在安卓机可物理返回但是在苹果手机无法测滑返回的问题
  • C++学习-入门到精通【14】标准库算法
  • 996引擎-自定义装备/道具:限时装备、限时道具
  • 【Linux】 Linux 进程控制
  • mongodb源码分析session异步接受asyncSourceMessage()客户端流变Message对象
  • elementUI点击浏览table所选行数据查看文档
  • .net Span类型和Memory类型
  • 中国森林地上和地下植被碳储量数据集(2002~2021)
  • 在 Oracle 中,创建不同类型索引的 SQL 语法
  • Neo4j图数据库管理:原理、技术与最佳实践
  • MDK程序调试
  • 五、查询处理和查询优化
  • Spring Boot + Elasticsearch + HBase 构建海量数据搜索系统
  • Spring Boot 缓存注解详解:@Cacheable、@CachePut、@CacheEvict(超详细实战版)
  • 【Linux篇】0基础之学习操作系统进程
  • Selenium 查找页面元素的方式
  • 【hadoop】Flink安装部署
  • 华为OD最新机试真题-小明减肥-OD统一考试(B卷)
  • CLIP多模态大模型的优势及其在边缘计算中的应用
  • mac 电脑Pycharm ImportError: No module named pip
  • opencv如何在仿射变换后保留完整图像内容并自动裁剪
  • 数学建模-嘉陵江铊污染事件解题全过程文档及程序
  • 论文速读《DexWild:野外机器人策略的灵巧人机交互》
  • Uniapp 二维码生成与解析完整教程
  • SpringBoot自动化部署全攻略:CI/CD高效实践与避坑指南