• 2021年1月1日 AutoCAD.Net/C#.Net QQ群:193522571修改多段线的凸度


     

    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;
    }
    }

    }

  • 相关阅读:
    jQuery实现图片前进后退
    jQuery写日历
    python列表模拟栈
    python 列表去重
    Linux的文件系统
    新建vss数据库
    关于业务用例和系统用例
    从零开始使用Linux命令
    svn的安装与配置
    数塔 动态规划
  • 原文地址:https://www.cnblogs.com/NewAutoMan/p/6384468.html
Copyright © 2020-2023  润新知