我在下面的代碼中找到了,它使用canny邊緣檢測和hough算法檢測所有線條。下面的代碼用於屏蔽我需要從中獲取點的線,但由於這是圖像,我不知道如何獲取x和y軸比例(我在這裏x1 = 0,x2 = 4, y1 = 0,y2 = 45),這樣我就可以得到該屏蔽線的x和y軸點。任何方法來做到這一點?提前致謝。從python-opencv中獲取圖像的x,y點
下面是我使用的代碼。
import numpy as np
import cv2
img = cv2.imread('linearline.png', 1)
hsv = cv2.cvtColor(img, cv2.COLOR_BGR2HSV)
lower_range = np.array([18, 100, 100], dtype=np.uint8)
upper_range = np.array([38, 255, 255], dtype=np.uint8)
mask = cv2.inRange(hsv, lower_range, upper_range)
edges = cv2.Canny(mask,50,150,apertureSize = 3)
cv2.imshow('edgesimage',edges)
print img.shape[1]
print img.shape
minLineLength=img.shape[1]-300
lines = cv2.HoughLinesP(image=edges,rho=0.02,theta=np.pi/500,
threshold=10,lines=np.array([]),minLineLength=minLineLength,maxLineGap=100)
a,b,c = lines.shape
for i in range(a):
cv2.line(img, (lines[i][0][0], lines[i][0][1]), (lines[i][0][2],
lines[i][0][3]), (0, 0, 255), 3, cv2.LINE_AA)
cv2.imshow('result', img)
cv2.waitKey(0)
cv2.destroyAllWindows()
我不能上傳我的linearline.png圖形,但它是一種x-y圖。
編輯:這是我使用link
那麼你的輸出是一行嗎? –
這段代碼的輸出是一個蒙版行,但我需要那個蒙版行 – MargS