Opencv—图像处理基础(python)

Opencv图像处理实战

Opencv(Python) 随便记记

一、图像的读取,显示和保存

唯一想提的就是,读取的时候通过更改第二个参数,可以设置读取图像的方式:

cv.IMREAD_COLOR加载彩色图像默认
cv.IMREAD_GRAYSCALE加载灰度图像
cv.IMREAD_UNCHANGED加载图像,包括α通道

二、获取图像属性

a = cv2.imread()

row, col, chn = a. shape —返回图像的行数列数和通道数

三、图像加法

1、numpy加法

方法: img1 + img2

若图像1+图像2,对应像素点的像素值和<=255,值为对应的像素值之和;对应像素点的像素和>255,结果为对255取模

2、opencv加法

方法:cv2.add(img1, img2)

当像素值之和小于等于255时不变,当结果大于255时则为255

四、图像融合

方法:img = cv.addWeighted(img1, alpha, img2, beta, gamma)

图像融合:结果图像=图像1 * 系数1+图像2 * 系数2 + 亮度调节量

最后一个参数不可以省略(可以写0,表示没有要调节的亮度要求)

五、图像类型转换

常用的三种转换方式:

cv2.COLOR_BGR2GRAY

cv2.COLOR_BGR2RGB

cv2.COLOR_GRAY2BGR

import cv2 as cv
a = cv.imread("",cv.IMREAD_UNCHANGED)
b = cv.cvtColor(a, cv2.COLOR_BGR2RGB)

六、图像缩放

方法1:dst = cv2.resize(src, dsize, fx, fy)

src表示原始图像,dsize表示目标大小(列,行),fx和fy表示缩放大小

dst = cv2.resize(src, (122,122))
dst = cv2.resize(src, None, fx=0.5, fy=0.7)

可以看出两种调整大小的方式选择一种即可,若选择dsize则后面不需要设置参数,若选择缩放参数,则dsize置None,缩放大小调整也是按照列和行的顺序

七、图像翻转

方法:dst = cv2.flip(src, flipCode)

flipCode可以为0:表示以x轴为旋转轴翻转,>0则以y轴为对称轴及逆行翻转,<0水平轴翻转一次然后竖直轴也翻转一次

八、阈值分割

分割方法处理方法
二进制阈值分割像素值比阈值大,处理为最大值;比阈值小,处理为零
反二进制阈值分割像素值大于阈值处理为0,小于等于阈值处理为最大值(255)
截断阈值分割像素值大于阈值则处理为阈值,小于等于阈值则不处(保持)
反 阈值化为0像素值大于等于阈值的处理为0,其他保持不变
阈值化为0像素值大于等于阈值则保持不变,小于阈值处理为0

方法:

retval, dst = cv2.threshold(src, thresh, maxval, type)

参数说明:retval和thresh都是阈值,一般情况下一致

dst表示图像处理之后的结果,src表示源图像,maxval表示最大值(1或者255,常用255),type表示类型,指定上述五种(实际上不止五种)的阈值分割方法

cv2.THRESH_BINARY 对应二进制阈值化

cv2.THRESH_BINARY_INV 对应反二进制阈值化

cv2.THRESH_TRUNC 对应截断阈值分割

cv2.THRESH_TOZERO 对应阈值化为0

cv2.THRESH_TOZERO_INV 对应反阈值化为0

九、图像平滑处理(使图像更加平滑,降噪)

滤波类型描述方法
均值滤波取一个核内所有的点的像素值相加除以像素点的个数dst = cv2.blur(src, disze) (disze一般是一个表示核大小的元组,比如(3,3))
方框滤波根据选择进行滤波操作,最后一个参数为true的时候等价于均值滤波dst = cv2.boxFilter(src, depth, dsize, normalize) (depth为目标深度,通常为-1表示和原始图像相同,最后一个参数为布尔类型,true表示取平均,false表示只求和)
高斯滤波加权平均,即核内每一个像素点的像素值乘对应的权重取和后求平均值dst = cv2.GaussianBlur(src, dsize, sigmaX) (sigMax用来控制权重,表示X方向的方差,一般设为0,系统自动计算方差)
中值滤波核内所有像素值按照大小排列,取中值进行赋值操作dst = cv2.medianBlur(src, size) size是一个整型的奇数

十、图像形态学操作(主要针对二值图像)

1、图像腐蚀

将一个卷积核从原始图像的每一个像素点进行遍历,以卷积核接触到的像素点如果是黑色,则将该点变为黑色(赋值为1)

方法: dst = cv2.erode(src, kernel, iterations) kernel表示卷积核,iterations表示迭代次数

kernel = np.ones((5,5), np.unit8) #生成一个卷积核
dst = cv2.erode(img, kernel, iterations = 1)
#图像腐蚀去掉毛刺,卷积次数缺省值为1,如果去掉毛刺多则增加迭代次数

2、图像膨胀

图像膨胀是图像腐蚀的逆操作。

【课程简介】 本课程基于面向PythonOpenCV,以OpenCV的官方文档的知识脉络为主线,介绍了OpenCV函数的具体使用方法、函数所使用的算法的具体原理。 在介绍函数使用时,提供了大量的程序案例演示。 在介绍具体原理时,采用了通俗易懂的语言贴近生活的示例来说明问题,尽量避免涉及过于复杂抽象的公式。 课程包含数字图像处理的常用知识点,覆盖面全,方便学员系统深入全面地掌握OpenCV。 【你将收获什么】 1.  掌握数字图像的在计算机内表示的方法处理的基本原理。掌握数字图像的表示方法是进行图像处理的前提基础,能够为后续的智能图像处理打下坚实基础。 2.  使用OpenCV开源库对于提升工作效率具有很大的帮助。OpenCV是优秀的开源库,提供了大量的函数帮助我们提升工作效率。大多数情况下,我们直接调用函数就能够满足我们的需求。同时,它的函数具有较好的交互性,能够根据需要更好地掌控图像处理的具体细节。 3.  学习图像处理的常用算法。课程不仅介绍函数的具体使用,也介绍了常用算法的基本原理,帮助学习者更好地理解图像处理的基本逻辑、方法,快速入门图像处理领域。 【我将如何教你】 1)在“黑盒”“白盒“之间取得平衡  可以将OpenCV看成“黑盒”,不用关心其函数是如何实现的。在需要实现某一个功能时,直接调用其对应的函数即可,像使用Photoshop的各种功能一样。也可以将OpenCV看成“白盒”,关注其每一个函数的具体实现,认真研究每一个函数的具体实现方法实现细节。这两种方式都是学习图像处理的很好方式,但是大多数课程过于强调其中某一种,要么忽略了算法的实现、要么忽略了使用方法。本课程尽量将OpenCV在“黑盒”“白盒”之间取得平衡。既介绍算法的原理方法,又将重点放在如何调用函数上,让学习者能够更加游刃有余地在计算机视觉项目中使用OpenCV来解决具体的问题。 2)将枯燥的算法采用具体的案例介绍  在图像处理中,有大量的算法保证了图像处理的准确、高效。OpenCV将一些常用的算法进行了封装,我们可以直接调用OpenCV的函数来使用对应的算法。但是,深入地理解算法能够帮助学习者更好地使用OpenCV函数。本课程尝试抛弃传统的使用复杂公式介绍算法的形式,尽量通过简单、通俗易懂的生活中实例来帮助学习者理解算法的基本逻辑 3)案例驱动、强调实战 OpenCV是一个庞大的资源库,提供了非常多的函数帮助我们高效地处理问题。初学者使用OpenCV的最大困惑就是熟练地掌握了每一个函数的调用方法,但是在解决实际问题时,不知道具体应该使用哪个函数。本课程通过大量的具体案例帮助学习快速掌握每个函数的应用场景,快速掌握OpenCV的核心使用方法技巧。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值