在点之间划一条线,以便使用python

时间:2018-09-03 06:40:20

标签: python image-processing scikit-image cv2

Sample image to be processed

我想在白色斑点和绿色矩形之间的每个点(在每个斑点旁边)画一条线(绿色作为参考,这些斑点是扭曲的斑点,我想得到它们之间的区别)并绘制(表面图等)

此外,我使用此代码来检测斑点:

if circles is not None:
    circles = np.round(circles[0,:].astype("int"))
    for (x,y,r) in circles:
        cv2.circle(output2, (x,y),r,(0,255,0),2)

Sample image with detected spots

我如何知道每个点的中心以及如何将它们用作阵列/列表?刚开始时,因为根据我的阅读,这些对于绘制形状是必不可少的。谢谢

1 个答案:

答案 0 :(得分:1)

这是使用scikit-image Hough变换的解决方案。使用以下代码,您可以检测圆,找到中心和半径(可以以相同的方式使用cv2的相应函数)

import numpy as np
import matplotlib.pyplot as plt
from skimage import data, color, io
from skimage.transform import hough_circle, hough_circle_peaks
from skimage.feature import canny
from skimage.draw import circle_perimeter
from skimage.util import img_as_ubyte

image = color.rgb2gray(img_as_ubyte(io.imread('new images/FjOll.png')))
edges = canny(image, sigma=1)
hough_radii = [6] # detect circles of radius 6
hough_res = hough_circle(edges, hough_radii)
# select most prominent 25 circles
accums, cx, cy, radii = hough_circle_peaks(hough_res, hough_radii, total_num_peaks=20)
# Draw circles
fig, ax = plt.subplots(ncols=1, nrows=1, figsize=(10, 4))
image = color.gray2rgb(image)
for center_y, center_x, radius in zip(cy, cx, radii):
    circy, circx = circle_perimeter(center_y, center_x, radius)
    print(center_y, center_x, radius)
    image[circy, circx] = (255, 0, 0)
ax.imshow(image)
plt.show()
## detected circles: (center_y, center_x, radius)
# (171, 103, 6)
# (56, 38, 6)
# (16, 99, 6)
# (141, 128, 6)
# (126, 32, 6)
# (95, 159, 6)
# (120, 90, 6)
# (56, 96, 6)
# (57, 157, 6)
# (120, 158, 6)
# (140, 62, 6)
# (108, 64, 6)
# (77, 64, 6)
# (42, 68, 6)
# (106, 130, 6)
# (73, 128, 6)
# (38, 127, 6)
# (75, 130, 6)
# (88, 38, 6)
# (86, 93, 6)

enter image description here