如何获取代表轮廓形状的向量的坐标,该轮廓形状存储为二维 numpy 像素数组?

Posted

技术标签:

【中文标题】如何获取代表轮廓形状的向量的坐标,该轮廓形状存储为二维 numpy 像素数组?【英文标题】:How do I get the coordinates of the vectors that represent a contour shape which I have stores as a 2D numpy array of pixels? 【发布时间】:2022-01-20 05:27:53 【问题描述】:

我有一个 1000x1000 的 2D numpy 数组,可以将其视为图像的像素。没有形状的单元格为 0,形状为某个值,表示强度的值。可以这样绘制:

plt.matshow(data, origin='lower')

当只考虑超过某个阈值的数据时,可以将数据视为形状,如下所示:

fig, ax = plt.subplots()

cluster_contour_threshold = 60
y,x = np.argwhere(data > cluster_contour_threshold).T

ax.scatter(x, y)
ax.set_xlim((0, 1000))
ax.set_ylim((0, 1000))

我想要的是获取代表此形状轮廓的坐标列表。像这样的:

[
  [x0,y0],
  [x1,y1],
  [x2,y2]
]

到目前为止,我最好的尝试是使用 canny,但这并不完全正确:

from skimage import feature
import numpy as np
import matplotlib.pyplot as plt

fig, ax = plt.subplots()

c = feature.canny(data)
y,x = np.argwhere(c).T


ax.scatter(x, y)
ax.set_xlim((0, 1000))
ax.set_ylim((0, 1000))

【问题讨论】:

我想只是points = np.argwhere(c)? 这会给你所有有数据的点,而不是轮廓。 【参考方案1】:

我用 skimage 解决了这个问题。

from skimage import measure

contours = measure.find_contours(data, 0.8)

# Display the image and plot all contours found
fig, ax = plt.subplots()
ax.imshow(data, cmap=plt.cm.gray)

for contour in contours:
    ax.plot(contour[:, 1], contour[:, 0], linewidth=2)

ax.axis('image')
ax.set_xticks([])
ax.set_yticks([])

【讨论】:

以上是关于如何获取代表轮廓形状的向量的坐标,该轮廓形状存储为二维 numpy 像素数组?的主要内容,如果未能解决你的问题,请参考以下文章

opencv 9 -- 轮廓 近似方法

OpenCV 将任意轮廓的形状转换为矩形

opencvsharp_基于轮廓的形状匹配中匹配坐标与旋转角度

opencvsharp_基于轮廓的形状匹配中匹配坐标与旋转角度

如何识别形状轮廓中的关节?

图像轮廓之形状匹配