ObjectArx 中反应器Reactor的使用

反应器类派生于AcRxObject而不是AcDbObject,因为他们不是数据库对象,没有ID,拥有关系也不适用。

不同类型的反应器接收不同类型的通知事件。派生于AcDbDatabaseReactor的数据库反应器(database reactor)接收与数据库状态相关的事件,例始当一个对象被加入到数据库,在数据库中被修改或删除。这种反应器的通知发送者是数据库,所以它被加入到数据库的反应器列表中。派生于AcDbObjectReactor的对象反应器(object reactor)负责接收对象(object)级别的事件,比如复制、删除、修改一个对象。它可以被加入到任何AcDbObject对象的反应器列表中。派生于AcEditorReactor的编辑反应器(editor reactor)负责接收AutoCAD特殊的事件,例如加载或卸载一张图,开始或结束一个命令以及其他类型的用户交互。AcEditor对象AcEditorReactor的唯一通知发送者。下面是反应器类的继承图:

上面的反应器都是临时反应器类。如你想你的程序接收事件通知,通常使用临时反应器去监视数据库对象事件、数据库事件、用户交互以及应用程序运行时的其他系统事件。

另外一种类型的反应器叫永久反应器,用一个数据库对象(AcDbObject类及其派生类的实例)作为反应器。数据库对象能像发送通知一样接收通知。永久反应器在数据库内的依赖关系是数据库的一部分,因此他们会被保存在DWG和DXF文件中,当文件加载时又会被重建。

将AcDbObject用作反应器

1.   派生一个新的AcDbObject类,并实现你的对象要负责事件的通知函数。

2.   实例化对象反应器。

3.   将对象反应器加入到数据库,并给他设置一个拥有者,最好是容器对象,以便他能被正确存入取出。

4.   使用addPersistentReactor()函数将对象反应器加入到通知发送者的反应器列表中。这个函数要求你传入对象反应器的ID,这个对象反应器就是你在第2步创建的。

注意:当你复制一个对象时,附加在对象上的任何一个永久反应器也将被复制,而临时反应器的附着关系不会被复制。

使用临时反应器,从以下基类中派生一个新类:

AcApDocManagerReactor

监视文档管理系列事件。

AcApLongTransactionReactor

监视长事务相关的动作。

AcDbDatabaseReactor

监视数据库对象的创建、修改和删除。

AcDbEntityReactor

监视一些另外的实体特有的事件,比如修改图像。

AcDbLayoutManagerReactor

监视与布局管理有关的事件。

AcDbObjectReactor

监视与具体数据库对象相关的事件,如创建、修改和删除。

AcDbSummaryInfoReactor

监视与Summary信息相关的改变。

AcEdInputContextReactor

监视与用户输入时的提示相关的事件。

AcEditorReactor

监视AutoCAD特有的事件,比如命令,AutoLISP赋值。

AcRxDLinkerReactor

监视ObjectARX应用程序的加载和卸载。

AcRxEventReactor

监视ObjectARX和ObjectDBX其用的事件。

AcTransactionReactor

监视与事务管理相关的事件,如一个事务的开始、放弃、结束。

在多数情况下,只需标准C++技术就能创建一个新的临时反应器类。为新的反应器类创建一个类的描述符对象的ObjectARX宏,一般不用于派生这些反应器类。

每一个父类都包含了一系列的虚通知函数,这些函数可以在新的派生类中被实现。例如,AcDbObjectReactor就包含了以下这些与对象有关事件的通知函数:

·             cancelled()

·             copied()

·             erased()

·             goodbye()

·             openedForModify()

·             modified()

·             subObjModified()

·             modifyUndone()

·             modifiedXData()

·             unappended()

·             reappended()

·             objectClosed()

每一个函数都要求有一个指针指向通知的发送者。基类AcDbObjectReactor有每一个函数的空实现。在你派生反应器类中,实现你感兴趣的的通知类型函数。然后实例化反应器,然后使用AcDbObject::addReactor()函数将他加到任何数量的数据库对象。添加或删除临时反应器,对象可以是任意状态(读、写、通知)。添加或删除临时对象不会被撤销(undo)机制监视。(对于永久反应器,通知发送对象必须是以写的形式打开,添加或移除反应器会被撤销(undo)机制监视到。)你创建了临时反应器对象,你也要负责删除它。

当一个对象被删除时,例如,它调用了erased()通知函数通知他的反应器列表中的每个反应器。如果你为你的反应器实现了erased()函数,数据库对象会调用这个函数,那么当对象被删除时,你可以采用与你的程序相对应的任务特殊动作。

时间: 2025-01-18 10:08:57

ObjectArx 中反应器Reactor的使用的相关文章

ACE反应器(Reactor)模式(2)

转载于:http://www.cnblogs.com/TianFang/archive/2006/12/18/595808.html 在Socket编程中,常见的事件就是"读就绪","写就绪",通过对这两个事件的捕获分发,可以实现Socket中的异步操作. Socket编程中的事件处理器 在前面我们已经介绍过,在ACE反应器框架中,任何都必须派生自ACE_Event_Handler类,并通过重载其相应会调事件处理函数来实现相应的回调处理的.在Socket编程中,我们

关于ObjectARX中自定义对象的OPM

关键字 ObjectARX,AutoCAD,自定义对象,OPM 在ObjectARX开发中,给自定义对象添加一个属性页面是个很有吸引力的事情, 学习路径如下, 1,学习ObjectARX的samples,其中AsdkSquareWrapper和polysamp 1.1研究AsdkSquareWrapper,这个例子相对简单,比较容易看懂, 弄清楚custent和 custentwrapper之间的关系,和一些固定的关系,和引用,哪些文件是中间生成等等,对没有COM编程经验的比较好: 但估计是制作

关于ObjectARX中自定义对象的OPM代码细节

开发OPM的技术规格如下 1,是一个ATL-COM项目 1.1 是DLL库,引用了COM的代码内容 1.2也可以使用DBX类型作为输出,并且让它做一些DBX库的工作 2 关于stdafx文件 2.1 需要包括的COM文件 常规的情况下,使用CComModule得到一个 COM对象,这样不需要在项目中引用ATL 在引用ATL的情况下,可以通过CAtlDllModuleT创建COM对象 2.2 关于_ATL_NO_UUIDOF 项目中有包含,也有不包含的,作用待定 2.3 包括AC的文件 #incl

ACE反应器(Reactor)模式(1)

转载于:http://www.cnblogs.com/TianFang/archive/2006/12/13/591332.html 1.ACE反应器框架简介 反应器(Reactor):用于事件多路分离和分派的体系结构模式 通常的,对一个文件描述符指定的文件或设备, 有两种工作方式: 阻塞与非阻塞.所谓阻塞方式的意思是指, 当试图对该文件描述符进行读写时, 如果当时没有东西可读,或者暂时不可写, 程序就进入等待状态, 直到有东西可读或者可写为止.而对于非阻塞状态, 如果没有东西可读, 或者不可写

java NIO中的Reactor相关知识汇总 (转)

一.引子 nio是java的IO框架里边十分重要的一部分内容,其最核心的就是提供了非阻塞IO的处理方式,最典型的应用场景就是处理网络连接.很多同学提起nio都能说起一二,但是细究其背后的原理.思想往往就开始背书,说来说去都是那么几句,其中不少人并不见的真的很理解.本人之前就属于此类,看了很多书和博客,但是大多数都只是讲了三件套和怎么使用,很少会很细致的讲背后的思想,那本次我们就来扒一扒吧.     很多博客描述nio都是这么说的:基于Reactor模式实现的多路非阻塞高性能的网络IO.那么我们就

高性能IO设计中的Reactor模式与Proactor模式

在高性能的IO设计中,有两个比较著名的模式Reactor和Proactor模式,其中Reactor模式用于同步I/O,而Proactor运用于异步I/O操作.在比较这两个模式之前,我们首先要搞明白几个概念.什么是阻塞和非阻塞?什么是同步和异步?同步和异步是针对应用程序和内核的交互而言的,同步指的是用户进程触发IO操作并等待或者轮询的去查看IO操作是否就绪,而异步是指用户进程触发IO操作以后便开始做自己的事情,而当IO操作已经完成的时候会得到IO完成的通知(异步的特点就是通知).而阻塞和非阻塞是针

ACE反应器(Reactor)模式(3)

转载于:http://www.cnblogs.com/TianFang/archive/2006/12/18/595938.html 在服务器端使用Reactor框架 使用Reactor框架的服务器端结构如下: 服务器端注册两种事件处理器,ClientAcceptor和ClientService ,ClientService类负责和客户端的通信,每一个ClientService对象对应一个客户端的Socket连接. ClientAcceptor专门负责被动接受客户端的连接,并创建ClientSe

ACE反应器(Reactor)模式(4)

转载于:http://www.cnblogs.com/TianFang/archive/2006/12/18/596012.html 定时器的实现 通过Reactor机制,还可以很容易的实现定时器的功能,使用方式如下. 编写一个事件反应器,重载handle_timeout()方法,该方法是定时器的触发时间到时,会自动触发该方法. 通过Reactor的schedule_timer()方法注册定时器. 启动reacotr的handle_events()事件分发循环. 当不想使用定时器时,可以通过Re

ObjectARX中三维多段线转二维多段线的方法

Acad::ErrorStatus AcDb3dPolylineToAcDb2dPolyline(AcDbObjectId objId, int flag /* =0 */) { Acad::ErrorStatus es; AcDbEntity *pEnt = NULL; double elev = 0.0; es = acdbOpenObject(pEnt, objId, AcDb::kForWrite); int i = 0; if (pEnt->isKindOf(AcDb3dPolylin