OpenCV这么简单为啥不学——1.1、图像处理(灰度图、模糊图片、GaussianBlur函数、提取边缘、边缘膨胀、边缘细化)

简介: OpenCV这么简单为啥不学——1.1、图像处理(灰度图、模糊图片、GaussianBlur函数、提取边缘、边缘膨胀、边缘细化)

OpenCV这么简单为啥不学——1.1、图像处理(灰度图、模糊图片、GaussianBlur函数、提取边缘、边缘膨胀、边缘细化)


前言

计算机视觉市场巨大而且持续增长,且这方面没有标准API,如今的计算机视觉软件大概有以下三种:

1、研究代码(慢,不稳定,独立并与其他库不兼容)

2、耗费很高的商业化工具(比如Halcon, MATLAB+Simulink)

3、依赖硬件的一些特别的解决方案(比如视频监控,制造控制系统,医疗设备)这是如今的现状,而标准的API将简化计算机视觉程序和解决方案的开发,OpenCV致力于成为这样的标准API。

OpenCV致力于真实世界的实时应用,通过优化的C代码的编写对其执行速度带来了可观的提升,并且可以通过购买Intel的IPP高性能多媒体函数库(Integrated Performance Primitives)得到更快的处理速度。

故而我们选择学习OpenCV,我们来一步步的学习OpenCV。


环境

在这里我们不仅仅需要cv2的环境,还需要numpy的环境,故而需要我们单独安装一下:

pip install numpy

win的环境与CentOS的有些区别,是库的区别,我本地是华为的库,CentOS是CSDN库,都能用。

灰度图

这里需要引入numpy做计算,也就是kernel的卷积核。

import cv2
import numpy as np
# 获取图片的数组
img = cv2.imread("800_600.jpg")
# 卷积核:一般用一个5行5列的全是1的数组
kernel = np.ones((5, 5), np.uint8)
# 生成灰度图
imgGray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
# 展示
cv2.imshow("Gray Image", imgGray)
cv2.waitKey(0)

实际效果:灰度

模糊图片

代码:可以修改模糊的强度,是一个奇数,取值范围建议1~151的奇数,不然就啥也看不清了。

import cv2
# 获取图片的数组
img = cv2.imread("800_600.jpg")
# 模糊图
imgBlur = cv2.GaussianBlur(img, (151, 151), 5)
# 展示
cv2.imshow("Gray Image", imgBlur)
cv2.waitKey(0)

模糊效果

GaussianBlur函数

高斯滤波是一种线性平滑滤波,适用于消除高斯噪声,广泛应用于图像处理的减噪过程。

语法:

dst=GaussianBlur(src,ksize,sigmaX [,dst [,sigmaY [,borderType]]])

参数:

src:图片

ksize:高斯内核大小。 ksize.width和ksize.height可以不同,但它们都必须为正数和奇数,也可以为零,然后根据sigma计算得出。

sigmaX:X方向上的高斯核标准偏差。

sigmaY:Y方向上的高斯核标准差;如果sigmaY为零,则将其设置为等于sigmaX;如果两个sigmas为零,则分别从ksize.width和ksize.height计算得出;为了完全控制结果,而不管将来可能对所有这些语义进行的修改,建议指定所有ksize,sigmaX和sigmaY。

import cv2
# 获取图片的数组
img = cv2.imread("800_600.jpg")
# 模糊图
imgBlur = cv2.GaussianBlur(img, (151, 151), 3, 17)
# 展示
cv2.imshow("Gray Image", imgBlur)
cv2.waitKey(0)

添加高斯核标准差效果:

提取边缘

代码:

import cv2
# 获取图片的数组
img = cv2.imread("800_600.jpg")
# 边缘提取
imgCanny = cv2.Canny(img, 150, 200)
# 展示
cv2.imshow("imgCanny", imgCanny)
cv2.waitKey(0)

有些像描边,可以用于扣除祛斑啥的这种单独的点点。

边缘膨胀

代码:

import cv2
import numpy as np
# 获取图片的数组
img = cv2.imread("800_600.jpg")
kernel = np.ones((5, 5), np.uint8)
# 边缘提取
imgCanny = cv2.Canny(img, 150, 200)
# 膨胀边缘
imgDialation = cv2.dilate(imgCanny, kernel, iterations=1)
# 展示
cv2.imshow("imgCanny", imgCanny)
cv2.imshow("imgDialation", imgDialation)
cv2.waitKey(0)

边缘膨胀,也就是强化了边缘。

边缘细化

代码:

import cv2
import numpy as np
# 获取图片的数组
img = cv2.imread("800_600.jpg")
kernel = np.ones((5, 5), np.uint8)
# 边缘提取
imgCanny = cv2.Canny(img, 150, 200)
# 膨胀边缘
imgDialation = cv2.dilate(imgCanny, kernel, iterations=1)
# 边缘细化
imgEroded = cv2.erode(imgDialation, kernel, iterations=1)
# 展示
cv2.imshow("imgCanny", imgCanny)
cv2.imshow("imgDialation", imgDialation)
cv2.imshow("imgEroded", imgEroded)
cv2.waitKey(0)

实际效果:

整体对照

总结

很多参数细节都是需要我们自己来根据实际需求来调整的,包括后期的AI循环也是一个参数一个参数的调整出来的结果,搞这个东西要细心与耐心缺一不可。

相关文章
|
2月前
|
计算机视觉
Opencv学习笔记(十二):图片腐蚀和膨胀操作
这篇文章介绍了图像腐蚀和膨胀的原理、作用以及使用OpenCV实现这些操作的代码示例,并深入解析了开运算和闭运算的概念及其在图像形态学处理中的应用。
177 1
Opencv学习笔记(十二):图片腐蚀和膨胀操作
|
3月前
|
算法 计算机视觉
基于qt的opencv实时图像处理框架FastCvLearn实战
本文介绍了一个基于Qt的OpenCV实时图像处理框架FastCvLearn,通过手撕代码的方式详细讲解了如何实现实时人脸马赛克等功能,并提供了结果展示和基础知识回顾。
147 7
|
2月前
|
计算机视觉 Python
Opencv学习笔记(二):如何将整个文件下的彩色图片全部转换为灰度图
使用OpenCV库将一个文件夹内的所有彩色图片批量转换为灰度图,并提供了相应的Python代码示例。
39 0
Opencv学习笔记(二):如何将整个文件下的彩色图片全部转换为灰度图
|
2月前
|
计算机视觉 Python
Opencv学习笔记(一):如何将得到的图片保存在指定目录以及如何将文件夹里所有图片以数组形式输出
这篇博客介绍了如何使用OpenCV库在Python中将图片保存到指定目录,以及如何将文件夹中的所有图片读取并以数组形式输出。
201 0
Opencv学习笔记(一):如何将得到的图片保存在指定目录以及如何将文件夹里所有图片以数组形式输出
|
2月前
|
算法 计算机视觉
Opencv学习笔记(六):cv2.resize函数的介绍
这篇文章介绍了OpenCV库中cv2.resize函数的使用方法,包括其参数、插值方式选择以及实际代码示例。
446 1
Opencv学习笔记(六):cv2.resize函数的介绍
|
2月前
|
计算机视觉
Opencv错误笔记(一):通过cv2保存图片采用中文命名出现乱码
在使用OpenCV的cv2模块保存带有中文命名的图片时,直接使用cv2.imwrite()会导致乱码问题,可以通过改用cv2.imencode()方法来解决。
182 0
Opencv错误笔记(一):通过cv2保存图片采用中文命名出现乱码
|
2月前
|
计算机视觉
Opencv学习笔记(三):图像二值化函数cv2.threshold函数详解
这篇文章详细介绍了OpenCV库中的图像二值化函数`cv2.threshold`,包括二值化的概念、常见的阈值类型、函数的参数说明以及通过代码实例展示了如何应用该函数进行图像二值化处理,并展示了运行结果。
566 0
Opencv学习笔记(三):图像二值化函数cv2.threshold函数详解
|
2月前
|
Serverless 计算机视觉
语义分割笔记(三):通过opencv对mask图片来画分割对象的外接椭圆
这篇文章介绍了如何使用OpenCV库通过mask图像绘制分割对象的外接椭圆。首先,需要加载mask图像,然后使用`cv2.findContours()`寻找轮廓,接着用`cv2.fitEllipse()`拟合外接椭圆,最后用`cv2.ellipse()`绘制椭圆。文章提供了详细的代码示例,展示了从读取图像到显示结果的完整过程。
71 0
语义分割笔记(三):通过opencv对mask图片来画分割对象的外接椭圆
|
2月前
|
机器学习/深度学习 算法 计算机视觉
【Python篇】Python + OpenCV 全面实战:解锁图像处理与视觉智能的核心技能
【Python篇】Python + OpenCV 全面实战:解锁图像处理与视觉智能的核心技能
107 2
|
3月前
|
算法 计算机视觉
opencv图像形态学
图像形态学是一种基于数学形态学的图像处理技术,它主要用于分析和修改图像的形状和结构。
56 4