zoukankan      html  css  js  c++  java
  • 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;
    }
    }

    }

  • 相关阅读:
    Python基础综合练习
    熟悉常用的Linux操作
    大数据概述
    C语言简易文法(无左递归)
    自动机
    C语言简易文法
    词法分析实验报告
    词法分析
    综合练习:词频统计
    组合数据类型综合练习
  • 原文地址:https://www.cnblogs.com/NewAutoMan/p/6384468.html
Copyright © 2011-2022 走看看