Я натолкнулся на код ниже, где обнаружил все линии, используя обнаружение canny edge и алгоритм hough. Код ниже используется для маскировки строки, откуда мне нужно получить точки, но поскольку это изображение, я не знаю, как получить масштаб оси x и y (i, e здесь x1 = 0, x2 = 4, y1 = 0, y2 = 45), чтобы в свою очередь я мог получить точки оси x и y для этой маскированной линии. Любой подход к этому? Заранее спасибо.Получение x, y точек с изображения в python-opencv
Ниже приведен код, который я использовал.
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, но его вид х-у участка.
Edited: Это изображение образец, который я использую link
так ваш вывод линии? –
Результат этого кода - это линия с маской, но мне нужны x, y точки этой маскированной линии – MargS