这两个问题是在写 https://github.com/pqpo/SmartCropper 的时候遇到的,厚脸皮的求个 start !
已知四个点的坐标,如何确定这四个点分别为 左上,右上,右下,左下。主观上很容易确定,四个顶点依次相连,然后判断一下是左倾还是右倾,根据倾斜程度以 45 度作为临界点确定。
接下来是判断是否为凸四边形,这个相对容易一些,确定出顶点位置之后,对角线相连,如果另外两个顶点分别位于对角线两侧,那么这个四边形就是凸四边形。
![]() | 1 Chingim 2017-08-07 17:12:28 +08:00 via Android 这是问问题吗? |
![]() | 2 em84 2017-08-07 17:13:39 +08:00 你开始了 |
![]() | 3 momocraft 2017-08-07 17:16:13 +08:00 如果这四个点是正方形 (0, 1) (1, 0) (2, 1) (1, 2) ,应该选哪个为左上? |
![]() | 4 jmc891205 2017-08-07 17:20:06 +08:00 我来做的话我就取纵坐标最大的两个点 其中横坐标小的那个是左上 大的那个是右上 左下右下类似 |
5 QAPTEAWH 2017-08-07 17:23:46 +08:00 扫描线? 好像先要证明“左上,右上,右下,左下”确实可被定义,可能只有凸四边形能定义这个? |
![]() | 6 yunkchen 2017-08-07 17:27:27 +08:00 谜底就在谜面里? |
![]() | 7 RLib 2017-08-07 17:55:54 +08:00 角点检测 goodFeaturesToTrack 或者多边形逼近 approxPolyDP,计算最小包围矩形 minAreaRect,得到一个 angle 和 4 个点,去比较下距离就得出了 |
![]() | 8 RLib 2017-08-07 17:59:04 +08:00 答偏了撤回 |
12 am241 2017-08-07 18:34:48 +08:00 via Android 求各顶点和四边形重心连线的角度,做排序 |
![]() | 13 pqpo OP @RLib 是否可以这样,将 4 点作为 boundingRect 的输入计算外接矩形(非最小外接矩形),这样产生的矩形四个顶点应该是按顺序的,以确定左上为例,距离这个外接矩形左上顶点距离最近的即为左上。 |
![]() | 14 willchen 2017-08-07 20:47:14 +08:00 如果是凸四边形, 任意取一点 和 剩下的 3 点构成的三角形的线段的直线 判断位置关系 是否可行? |
15 Cbdy 2017-08-07 20:55:05 +08:00 我说一个 作一个边法向量分别为(1,1),(1,-1)的平行四边形作为该多边形的外接多边形,该多边形与平行四边形的交点即为所求点。。 试试看= =# |