几何尺寸与公差论坛------致力于产品几何量公差标准GD&T (GDT:ASME)|New GPS(ISO)研究/CAD设计/CAM加工/CMM测量  


返回   几何尺寸与公差论坛------致力于产品几何量公差标准GD&T (GDT:ASME)|New GPS(ISO)研究/CAD设计/CAM加工/CMM测量 » 仿射空间:CAX软件开发(三)二次开发与程序设计 » CAD二次开发 » AutoCAD二次开发 » ObjectARX(C++)
用户名
密码
注册 帮助 会员 日历 银行 搜索 今日新帖 标记论坛为已读


回复
 
主题工具 搜索本主题 显示模式
旧 2009-04-16, 09:14 PM   #1
yang686526
高级会员
 
注册日期: 06-11
帖子: 14579
精华: 1
现金: 224494 标准币
资产: 234494 标准币
yang686526 向着好的方向发展
默认 【转帖】反应器实例

反应器实例
反应器实例
exam10a.cpp代码:
#include "rxobject.h"
#include "rxregsvc.h"
#include "rxdlinkr.h"
#include "rxditer.h"
#include "aced.h"
#include "dbmain.h"
#include "dbdict.h"
#include "dbidmap.h"
#include "dbapserv.h"
#include "adslib.h"
void printdbevent(const acdbobject *,const char * eventstr);
void printobj(const acdbobject * pobj);
void watchdb();
void clearreactors();
extern "c"
acrx::appretcode acrxentrypoint(acrx::appmsgcode ,void *);
class mydbreactor;
long gentacc =0;
mydbreactor *gpdbr=null;
class mydbreactor ublic acdbdatabasereactor
{
public:
virtual void objectappended(const acdbdatabase * dwg,
const acdbobject *dbobj);
virtual void objectmodifier(const acdbdatabase * dwg,
const acdbobject *dbobj);
virtual void objecterased(const acdbdatabase * dwg,
const acdbobject * dbobj,adesk::boolean perased);
};
void mydbreactor:bjectappended(const acdbdatabase * db,
const acdbobject *pobj)
{
printdbevent(pobj,"objectappended");
acutprintf("db==%lx\n",(long)db);
gentacc++;
acutprintf("entity count=%d\n",gentacc);
}
void mydbreactor:bjectmodifier(const acdbdatabase *db,
const acdbobject *pobj)
{
printdbevent(pobj,"objectmodified");
acutprintf("db==%=%lx\n",(long)db);
}
void mydbreactor:bjecterased(const acdbdatabase * db,
const acdbobject *pobj,
adesk::boolean perased)
{
if(perased)
{
printdbevent(pobj,"objecterased");
gentacc--;
}
else
{
printdbevent(pobj,"object (un)erased");
gentacc++;
}
acutprintf("db=%lx\n",(long)db);
acutprintf("entity count=%d\n",gentacc);
}
void printdbevent(const acdbobject * pobj,
const char * pevent)
{
acutprintf("event::acdbdatabasereactor::%s",pevent);
printobj(pobj);
}
void printobj(const acdbobject *pobj)
{
if(pobj==null)
{
acutprintf("(null)");
return;
}
acdbhandle objhand;
char handbuf[17];
pobj->getacdbhandle(objhand);
objhand.getintoasciibuffer(handbuf);
acutprintf("\n (class==%s,handle==%s,id==%lx,db==%lx)",
pobj->isa()->name(),handbuf,
pobj->objectid().asoldid(),pobj->database());
}
void watchdb()
{
if(gpdbr==null)
{
gpdbr=new mydbreactor();
}
acdbhostapplicationservices()->workingdatabase()
->addreactor(gpdbr);
acutprintf("added database reactor to"
"acdbhostapplicationservices()->workingdatabase().\n");
}
void clearreactors()
{
if(acdbhostapplicationservices()->workingdatabase()!=null)
{
acdbhostapplicationservices()->workingdatabase()
->removereactor(gpdbr);
delete gpdbr;
gpdbr=null;
}
}
acrx::appretcode
acrxentrypoint(acrx::appmsgcode msg,void * appid)
{
switch(msg)
{
case acrx::kinitappmsg:
acrxdynamiclinker->unlockapplication(appid);
acrxdynamiclinker->registerappnotmdiaware(appid);
acedregcmds->addcommand("exam10a",
"watch",
"watch",
acrx_cmd_transparent,
watchdb);
acedregcmds->addcommand("exam10a",
"clear",
"clear",
acrx_cmd_transparent,
clearreactors);
break;
case acrx::kunloadappmsg:
clearreactors();
acedregcmds->removegroup("exam10a");
break;
}
return acrx::kretok;
}
exam10a.def代码:
library exam10a
description "exam10a application"
exports
acrxentrypoint private
acrxgetapiversion private

开发环境:vc++6.0
使用环境:autocad2
调试和使用通过。与大家共免。
vc++ 中的环境要设置一下。
yang686526离线中   回复时引用此帖
GDT自动化论坛(仅游客可见)
回复


主题工具 搜索本主题
搜索本主题:

高级搜索
显示模式

发帖规则
不可以发表新主题
不可以回复主题
不可以上传附件
不可以编辑您的帖子

vB 代码开启
[IMG]代码开启
HTML代码关闭



所有的时间均为北京时间。 现在的时间是 07:49 PM.


于2004年创办,几何尺寸与公差论坛"致力于产品几何量公差标准GD&T | GPS研究/CAD设计/CAM加工/CMM测量"。免责声明:论坛严禁发布色情反动言论及有关违反国家法律法规内容!情节严重者提供其IP,并配合相关部门进行严厉查处,若內容有涉及侵权,请立即联系我们QQ:44671734。注:此论坛须管理员验证方可发帖。
沪ICP备06057009号-2
更多