首页 > 其他 > 详细

修改多段线的凸度

时间:2017-02-09 23:44:50      阅读:258      评论:0      收藏:0      [点我收藏+]

 技术分享

 

static void zffObjectARX_MyCommand5(void)
{
ads_point pick;
ads_name name;
if (acedEntSel(NULL,name,pick)!=RTNORM)
{
return;
}
AcGePoint3d ptClosest;
AcDbObjectId polyId;
double param;
AcDbPolyline* pPoly=NULL;
acdbGetObjectId(polyId,name);
acdbOpenObject(pPoly,polyId,AcDb::kForWrite);
pPoly->getClosestPointTo(asPnt3d(pick),ptClosest);
pPoly->getParamAtPoint(ptClosest,param);
int vernum=int(param);
int vernumEnd=int(param+1);
AcGePoint3d ptS,ptE;
pPoly->getPointAt(vernum,ptS);
pPoly->getPointAt(vernumEnd,ptE);
pPoly->close();
AcGePoint2d ptCur;


int track=1,type;
struct resbuf result;
while (track>0)
{
acedGrRead(track,&type,&result);
ptCur.x=result.resval.rpoint[X];
ptCur.y=result.resval.rpoint[Y];
AcGeCircArc2d arc(CPointUtil::ToPoint2d(ptS),ptCur,CPointUtil::ToPoint2d(ptE));
AcGePoint2d ptCenter=arc.center();
AcGeVector2d verS(ptS.x-ptCenter.x,ptS.y-ptCenter.y);
double angleS=verS.angle();
AcGeVector2d verE(ptE.x-ptCenter.x,ptE.y-ptCenter.y);
double angleE=verE.angle();
double bulge=(angleE-angleS)/pi();

acdbOpenObject(pPoly,polyId,AcDb::kForWrite);
pPoly->setBulgeAt(vernum,bulge);
pPoly->close();
if (type==3)
{
track=0;
}
}

}

修改多段线的凸度

原文:http://www.cnblogs.com/NewAutoMan/p/6384468.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!