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

几何尺寸与公差论坛------致力于产品几何量公差标准GD&T (GDT:ASME)|New GPS(ISO)研究/CAD设计/CAM加工/CMM测量 (http://www.dimcax.com/hust/index.php)
-   ObjectARX(C++) (http://www.dimcax.com/hust/forumdisplay.php?f=34)
-   -   【转帖】怎样实现拷贝,移动,镜像,偏移,阵列等 (http://www.dimcax.com/hust/showthread.php?t=7572)

yang686526 2009-04-18 01:43 PM

【转帖】怎样实现拷贝,移动,镜像,偏移,阵列等
 
怎样实现拷贝,移动,镜像,偏移,阵列等
怎样实现拷贝,移动,镜像,偏移,阵列等
怎样实现拷贝,移动,镜像,偏移,阵列等,但是我不想用acedcommand来调用autocad的命令,用arx怎么实现?
//移动实体
//移动实体
void ctszdwg::moveentity(const acdbobjectidarray& aryids,
acgepoint3d ptstart,
acgepoint3d ptend)
{
acgematrix3d xform1;
xform1.settranslation(acgevector3d(ptend-ptstart));
ads_name ssname;
ads_ssadd(null,null,ssname);
for(int i=0;i<aryids.length();i++)
{
acdbobjectid id=aryids.at(i);
ads_name name;
acdbgetadsname(name,id);
ads_ssadd(name,ssname,ssname);
ads_ssfree(name);
}
ads_xformss(ssname,xform1.entry);
ads_ssfree(ssname);
}
谢谢,
那怎么样拷贝,偏移?
顶一下
acdbobjectid cljdwg::getmirrorentity(const acdbobjectid id,
acgepoint3d ptmiraxisstart,
acgepoint3d ptmiraxisend)
{
acdbobjectid idmirror=acdbobjectid::knull;
acgematrix3d xform1;
//xform1.settomirroring(acgeline3d(ptmiraxisstart,ptmiraxisend));
acgeplane plan(ptmiraxisstart,acgepoint3d(ptmiraxisend.x,ptmiraxisend.y,-100),ptmiraxisend);
xform1.settomirroring(plan);

acdbentity* pent=null;
acdbopenobject(pent,id,acdb::kforread);
if(pent)
{
acdbentity* pent0=(acdbentity*)pent->clone();
pent->close();
pent0->transformby(xform1);
idmirror=addentity(pent0);
pent0->close();
}
return idmirror;
}
void cljdwg::rotateentity(const acdbobjectid id,
const acgepoint3d ptcenter,
const double dangle)
{
acdbobjectid idmirror=acdbobjectid::knull;
acgematrix3d xform1;
xform1.settorotation(dangle,acgevector3d(0,0,1),ptcenter);

acdbentity* pent=null;
acdbopenobject(pent,id,acdb::kforwrite);
if(pent)
{
pent->transformby(xform1);
pent->close();
}
}
多谢!
ding


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