天气与日历 切换到窄版

 找回密码
 立即注册
中国膜结构网
十大进口膜材评选 十大国产膜材评选 十大膜结构设计评选 十大膜结构公司评选
查看: 81|回复: 0

AcDbCurve::extend 延长指定多义线的前后长度

[复制链接]

该用户从未签到

主题

0

回帖

2912

积分

管理员

积分
2912
发表于 2024-6-22 09:46:18 | 显示全部楼层 |阅读模式
int myExtendPolyline(AcDbPolyline* pl,double sOff,double eOff)
{
        ASSERT(pl);
        if (pl->numVerts() < 2)
        {
                return 0;
        }
        if (sOff > 0)
        {
                AcGePoint3d sPt,sPt2;
                pl->getStartPoint(sPt);
                pl->getPointAt(1,sPt2);

                double td1,td2;
                pl->getDistAtPoint(sPt,td1);
                pl->getDistAtPoint(sPt2,td2);
                double off = td2 - td1;
               
                double sParam = fabs(sOff) / off;

                if(pl->extend(-sParam) != Acad::eOk)
                {
                        ASSERT(0);
                        return 0;
                }
        }
        if (eOff > 0)
        {
                AcGePoint3d ePt,ePt2;
                pl->getEndPoint(ePt);
                pl->getPointAt(pl->numVerts() - 2,ePt2);

                double td1,td2;
                pl->getDistAtPoint(ePt2,td1);
                pl->getDistAtPoint(ePt,td2);
                double off = td2 - td1;

                double eparam = fabs(eOff) / off;
                if(pl->extend(eparam) != Acad::eOk)
                {
                        ASSERT(0);
                        return 0;
                }
        }

        return 1;
}

 

 

 

 

AcDbCurve::extend 延长指定多义线的前后长度
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|中国膜结构网|中国膜结构协会|进口膜材|国产膜材|ETFE|PVDF|PTFE|设计|施工|安装|车棚|看台|污水池|中国膜结构网_中国空间膜结构协会

GMT+8, 2024-11-1 12:36 , Processed in 0.146414 second(s), 26 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表