几何尺寸与公差论坛------致力于产品几何量公差标准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, 10:32 PM   #1
yang686526
高级会员
 
注册日期: 06-11
帖子: 14579
精华: 1
现金: 224494 标准币
资产: 234494 标准币
yang686526 向着好的方向发展
默认 【转帖】大虾帮忙看看程序吧

大虾帮忙看看程序吧
大虾帮忙看看程序吧
整个程序主要是为了从dwg文件中得到图块的包罗矩形的两个点.(不知道有没有其他的方法)
下面怎么老是得不到 包络矩形的两个点呢?
只会得到**error on get the extents point...
不知道是那里出问题了?大虾们帮忙看看吧
//插入图形

acad::errorstatus es;
cstring filename="e:\\autocad\\dwgfile\\qq.dwg";//已经存在的文件
acdbdatabase *pnewdb=new acdbdatabase(adesk::kfalse);
es=pnewdb->readdwgfile(filename,_sh_denyno,false);
if(es!=acad::eok)
{
acutprintf("\nthe file %s cannot be opend",filename);
return;
}

acdbdatabase *pdb;
pdb=acdbhostapplicationservices()->workingdatabase();
cstring pblockname="testblock";
acdbobjectid blockid;

if((es=pdb->insert(blockid, pblockname,pnewdb,true))==acad::eok)
{ acutprintf("\ninsert ok\n");
delete pnewdb;}
else
{ afxmessagebox("insert failed");
delete pnewdb;
return; }

acgepoint3d pt(100.0,
你这种好象要通过事务处理才能实现
哦,可是必须要事务处理吗?
不能把图块读到当前数据库中,再对图块操作吗?
好了,问题解决了。这样就得到了。谢谢easypower 的答复
acad::errorstatus es;
cstring filename="e:\\autocad\\dwgfile\\qq.dwg";//已经存在的文件
acdbdatabase *pnewdb=new acdbdatabase(adesk::kfalse);
es=pnewdb->readdwgfile(filename,_sh_denyno,false);
if(es!=acad::eok)
{
acutprintf("\nthe file %s cannot be opend",filename);
return;
}

acdbdatabase *pdb;
pdb=acdbhostapplicationservices()->workingdatabase();
cstring pblockname="testblock";
acdbobjectid blockid;

if((es=pdb->insert(blockid, pblockname,pnewdb,true))==acad::eok)
{ acutprintf("\ninsert ok\n");
delete pnewdb;}
else
{ afxmessagebox("insert failed");
delete pnewdb;
return; }
//
acdbextents exts;
//
acdbblockreference *pblkref = new acdbblockreference;
pblkref->setblocktablerecord(blockid);//指向blockid;
//
pblkref->getgeomextents(exts);
acutprintf("\nthe maxpoint=%0.4f,%0.4f",exts.maxpoint()[x],exts.maxpoint()[y]);
acutprintf("\nthe minpoint=%0.4f,%0.4f",exts.minpoint()[x],exts.minpoint()[y]);
//
pblkref->close();

不过,如果程序这样写
if(pblkref->getgeomextents(exts)!=acad::eok)
{
acutprintf("\nerror\n");
}
if中的语句会是“假”,得到error,不知道为什么啊?
yang686526离线中   回复时引用此帖
GDT自动化论坛(仅游客可见)
回复


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

高级搜索
显示模式

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

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



所有的时间均为北京时间。 现在的时间是 12:14 AM.


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