我希望能用白色填充这些多边形,然后通过循环遍历整个图像来重复执行此操作,因此我想知道在Python中使用OpenCV执行此操作的语法和函数。
这是我的输入图像。
alist=[]
img = cv2.imread('closing2.jpg',cv2.IMREAD_GRAYSCALE)
imo = cv2.imread('closing2.jpg',cv2.IMREAD_GRAYSCALE)
imr = cv2.imread('closing2.jpg',cv2.IMREAD_GRAYSCALE)*0
imac = imr
height , width = imo.shape[:2]
a,im = cv2.threshold(img,200,255,cv2.THRESH_BINARY)
# i=100
# p=[i,i]
points = []
for j in range(0,1000,50):
for i in range(0,1000,50):
p=[i,j]
poly = raypoly(im,p,5)
st = metrics(p,poly)
polyc=raypolyLimit(im,p,st,30)
# print(polyc)
# print(len(polyc))
# for m in range(len(polyc)):
# point = polyc[m]
# cv2.fillConvexPoly(im, point, 255)
plotpoly(polyc,imr)
plotpolypoints(polyc,imr,255,1)
# plotray(im,p,imr)
am = polyArea(polyc)
# print(am)
if am > 5:
alist.append(am)
# img[(i-5):(i+5),(j-5):(j+5)]=150
# plt.imshow(imf)
# plt.show()
imo = im * 0
plotpoly(polyc,imo)
plotpoly(polyc, im)
# plotArea(polyc,imo)
imf = imo*1000 +im
a,imf = cv2.threshold(imf,100.0,255.0,cv2.THRESH_BINARY)
cv2.imshow('Frame_1', imr)
cv2.imshow('Frame_3', imo)
cv2.imshow('Frame_4', imf)
cv2.imshow('Frame_5', im)
cv2.waitKey(1)
我使用了下面的函数,并得到以下结果:
cv2.floodFill(imo,None,(i,j),255)
但我的问题是,当多边形的数量达到一定程度时,整个图像会出现白色闪烁,我不知道如何修复它。
drawContours
?如果是后者,只需将thickness
设置为FILLED
。否则,您可能需要先使用findContours
找到这些多边形。(然后,您也可以使用floodFill
等方法。) - HansHirse