如何解决如何对多边形使用polygonPointTest函数?
我正在尝试为多边形运行多边形点测试功能。我的代码如下所示,它仅适用于coutour吗?
import ast
import cv2
import numpy as np
point1 = (25,50)
t = "201.94,191.31;158.20,343.59;520.55,361.55;469.79,175.70" # closed polygon
pts = [*map(ast.literal_eval,t.split(';'))]
pts = np.array(pts)
cv2.pointPolygonTest(pts,point1,False)
我遇到错误了
---------------------------------------------------------------------------
error Traceback (most recent call last)
<ipython-input-454-bfdc7e835e9b> in <module>
----> 1 cv2.pointPolygonTest(pts,False)
error: OpenCV(4.3.0) /io/opencv/modules/imgproc/src/geometry.cpp:103: error: (-215:Assertion failed) total >= 0 && (depth == CV_32S || depth == CV_32F) in function 'pointPolygonTest'
解决方法
我正在使用不兼容类型的np array
,将其转换为np.int32
之后,我可以获得所需的输出。
import ast
import cv2
import numpy as np
point1 = (25,40)
t = "201.94,191.31;158.20,343.59;520.55,361.55;469.79,175.70" # closed polygon
pts = [*map(ast.literal_eval,t.split(';'))]
pts = np.array(pts,np.int32)
cv2.pointPolygonTest(pts,point1,False)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。