edges = cv2.Canny(gray_blur, 200, 1500, apertureSize = 5)
时间: 2024-03-30 15:34:14 浏览: 215
这段代码使用OpenCV的函数cv2.Canny()来检测图像中的边缘。具体来说,它输入一个灰度图像gray_blur和两个阈值参数(lower_threshold和upper_threshold),然后使用Canny算法进行边缘检测并将结果存储在edges中。apertureSize参数是可选的,它指定了用于计算图像梯度的Sobel算子的大小。在这个例子中,它被设置为5。
相关问题
low_threshold = 50 high_threshold = 150 edges = cv2.Canny(blur_gray, low_threshold, high_threshold)
这段代码是用于对经过高斯模糊处理的灰度图像进行Canny边缘检测,其中low_threshold和high_threshold分别表示Canny算法中的低阈值和高阈值,edges表示检测得到的边缘图像。具体来说,Canny边缘检测是一种广泛应用于计算机视觉领域的边缘检测算法,其主要思想是先对图像进行高斯模糊处理,然后计算图像中每个像素的梯度幅值和方向,根据梯度幅值来判断像素是否为边缘点,并根据高低阈值来判断边缘是否为真实的边缘。在这段代码中,low_threshold和high_threshold的不同取值会影响到得到的边缘图像的细节和噪声程度。
import cv2 img = cv2.imread('test.png') gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) blurred = cv2.GaussianBlur(gray, (3, 3), -5) edges_canny = cv2.Canny(blurred, 50, 150) # edges_thresh = cv2.adaptiveThreshold( # blurred, 255, # cv2.ADAPTIVE_THRESH_MEAN_C, # cv2.THRESH_BINARY_INV, 11, 2 # ) edges_thresh = cv2.adaptiveThreshold( blurred, 255, cv2.ADAPTIVE_THRESH_MEAN_C, cv2.THRESH_BINARY, 11, 2 ) combined = cv2.bitwise_and(edges_canny, edges_thresh) cv2.imshow("ART", combined) cv2.waitKey(0) 我要黑色线稿白色背景
这段代码是基于OpenCV库对图像进行边缘检测和自适应阈值处理,并尝试将两者的结果结合以创建一种类似于“线稿”的效果。为了确保最终结果是以**白色背景、黑色线条**的形式展示,我们需要特别关注两个方面:
1. **Canny 边缘检测** 的返回图像是黑白反转的(即默认为黑底白边),因此可以直接作为我们想要的线条部分;
2. 自适应二值化 `adaptiveThreshold` 使用了非反向二值化的设置 (`THRESH_BINARY`) ,这意味着对于原始较亮区域它会变成更暗的颜色,在这种情况下,需要保证该操作不会干扰到目标。
从您的描述来看,您希望得到的是白色的背景以及黑色轮廓的效果,这里需要注意几个点:
- Canny算子产生的边缘通常是黑色背景下有亮度变化的地方显示成白色,所以这一步已经接近于您所需要的形态,但如果您想进一步增强对比度可以考虑后续处理。
- 对于 `adaptiveThreshold` 函数,默认情况下生成的是黑色文字或物体(低灰度)位于白色背景上;但是由于你指定了 `cv2.THRESH_BINARY` 而不是 `cv2.THRESH_BINARY_INV` 参数,意味着输出将是深色前景浅色背景,这对于我们要达到的目标是有帮助的,因为我们可以利用这一点来做掩模操作。
然而,在最后组合两幅图片时使用了按位与运算(`bitwise_and`),这个选择可能会导致一些信息丢失,因为它只会保留两个输入数组中都存在的像素位置的数据,考虑到我们的目的是获取清晰可见的边界并且保持白色背景,建议改为按位或(`bitwise_or`)或者简单地相加再做归一化等其他方式来合并这两种特征提取的结果,同时也要检查每一步骤后的颜色模式是否符合预期。
此外,关于高斯模糊函数中的参数 `-5` 设置给第三个sigmaX参数是一个错误配置——通常应提供正值表示标准偏差大小,负数则会让系统自动计算一个合理的值出来,不过在这个例子里面更好的做法是指定具体的正数值如1或者直接设为零让API自行推断合适的宽度。
以下是调整后的参考代码片段,用于获得期望的黑白艺术风格效果图:
```python
import cv2
img = cv2.imread('test.png')
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
# 更改高斯核尺寸及Sigma值以优化模糊程度
blurred = cv2.GaussianBlur(gray, (7, 7), 0)
edges_canny = cv2.Canny(blurred, 50, 150)
# 确保自适应阈值处理采用正确的极性选项
edges_thresh = cv2.adaptiveThreshold(
blurred, 255,
cv2.ADAPTIVE_THRESH_MEAN_C,
cv2.THRESH_BINARY_INV, # 这里改成INV使得输出为白底黑字形式
11, 2
)
# 改用按位或运算代替原来的按位与运算
combined = cv2.bitwise_or(edges_canny, edges_thresh)
# 或者简单的叠加并限制最大值为255也可以实现类似效果
# combined = np.clip((edges_canny + edges_thresh)/2, a_min=0,a_max=255).astype(np.uint8)
cv2.imshow("ART", combined)
cv2.waitKey(0)
```
阅读全文
相关推荐
















