gpt4 book ai didi

python - 从图像中提取水平和垂直线

转载 作者:行者123 更新时间:2023-12-02 16:48:02 26 4
gpt4 key购买 nike

我想提取2个蒙版中的水平和垂直线作为附加图像。

我已经尝试了形态学操作来做到这一点,

horizontalStructure = cv.getStructuringElement(cv.MORPH_RECT, (horizontal_size, 1))
verticalStructure = cv.getStructuringElement(cv.MORPH_RECT, (1, verticalsize))

但问题是,它检测到的线为矩形,然后以2条线的形式绘制,代表矩形的2个边。

有什么解决办法吗?

图片:
img

水平结果:

h

垂直结果:

v

编辑:这是我的另一张图片:

img

最佳答案

您对结构元素做了什么?您其余的代码在哪里?

我建议使用 cv2.morphologyEx 使用形态学开放,如下所示:

import cv2
import numpy as np
from skimage import io # Only needed for web reading images

# Web read image; use cv2.imread(...) for local images
img = cv2.cvtColor(io.imread('/image/jnCvG.jpg'), cv2.COLOR_RGB2GRAY)

# Get rid of JPG artifacts
img = cv2.threshold(img, 128, 255, cv2.THRESH_BINARY)[1]

# Create structuring elements
horizontal_size = 11
vertical_size = 11
horizontalStructure = cv2.getStructuringElement(cv2.MORPH_RECT, (horizontal_size, 1))
verticalStructure = cv2.getStructuringElement(cv2.MORPH_RECT, (1, vertical_size))

# Morphological opening
mask1 = cv2.morphologyEx(img, cv2.MORPH_OPEN, horizontalStructure)
mask2 = cv2.morphologyEx(img, cv2.MORPH_OPEN, verticalStructure)

# Outputs
cv2.imshow('img', img)
cv2.imshow('mask1', mask1)
cv2.imshow('mask2', mask2)
cv2.waitKey(0)
cv2.destroyAllWindows()

我得到以下两个口罩,对我来说看起来很不错:

Mask 1

Mask 2

希望有帮助!

----------------------------------------
System information
----------------------------------------
Platform: Windows-10-10.0.16299-SP0
Python: 3.8.1
NumPy: 1.18.1
OpenCV: 4.2.0
----------------------------------------

关于python - 从图像中提取水平和垂直线,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60169540/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com