平面内四个点,怎样保证能构建四角面?

比如

verts = [(1,1),(1,-1),(-1,-1)]

最后一个点为lastV = (x,y)
怎样保证能创建这样的面
image.png
而不是这样
image.png

要求这四个点坐标不变,最小限度修改顶点顺序(逆时针,否则面法线就会朝内)?
有什么好办法吗?

阅读 1.8k
1 个回答

这个可以通过通过计算判断顺序是否合适啊,判断规则就是任意作为边的线段不能和其它作为边的线段相交。
而以往3点构成了3条线段,新增加点可以拆除原一条线段,增加2条线段,则新增的线段不能和以往或新增的线段(共4条线段)有交点(需要注意是线段的交点,而不是线的交点)。

线段方程,已知2点很容易得出,
(y-y1)/(x-x1)=(y2-y1)/(x2-x1) | x2≠x1,x∈(x1,x2),y∈(y1,y2)
而线段是否有交点也可以利用2个方程组方便的计算出来。

这样就可以判断取消的原3角形边是否正确啦,从而构造出正确的四边形。

这个是计算机图形学基本的计算啦。可能在计算机图形处理库中有一些常用工具可以利用。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进