查看单个帖子
旧 2009-04-16, 05:35 PM   #1
yang686526
高级会员
 
注册日期: 06-11
帖子: 14579
精华: 1
现金: 224494 标准币
资产: 234494 标准币
yang686526 向着好的方向发展
默认 【转帖】[求助]请问在arx中如何判断一点在多段线的左边还是右边?

[求助]请问在arx中如何判断一点在多段线的左边还是右边?
[求助]请问在arx中如何判断一点在多段线的左边还是右边?
如题,谢谢!
转一下网上别人的解答
判断一个点在曲线的左侧还是右侧的算法经常要用到,其实通过arx来实现要更简单一些,先介绍一下算法:
1.首先根据所给的点pt,在曲线上找到距离此点最近的一个点ptoncurve(一般都是垂点)
2.求出最近点ptoncurve在曲线上的一阶导数deriv1,也就是切线方向。注意:这个切线和曲线的方向是相关的
3.求出pt和ptoncurve所形成的向量testvec(由ptoncurve指向pt)
4.求出与testvec正交的向量,可通过perpvector来实现,这个函数把向量testvec顺时针旋转90度后得到一个新向量
5.因为deriv1是和曲线方向相关的,所以判断两个向量(deriv1与testvec)是否同向即可判断出给定点在曲线的左侧还是右侧
下面是代码:
>> code
bool isleftofcurve(const acdbcurve* pcurve, acgepoint3d pt);{ acgepoint3d ptoncurve; pcurve->getclosestpointto(pt, ptoncurve); acgevector3d deriv1, testvec; pcurve->getfirstderiv(ptoncurve, deriv1); testvec = pt.asvector() - ptoncurve.asvector(); return (testvec.perpvector().iscodirectionalto(deriv1));}
呵呵,就是这样,搞定了,谢谢
yang686526离线中   回复时引用此帖
GDT自动化论坛(仅游客可见)