当前位置:首页 > 天道酬勤 > 正文内容

pythonopencv中文教程(opencv多图像拼接)

张世龙2021年12月20日 13:33天道酬勤790

在——本文中,说明了图像的剪切、调整大小、旋转、阈值、模糊、对图像的描绘和写入、利用面部检测和轮廓图像的物体检测。

什么是OpenCV-Python?

OpenCV是一个开放源代码的计算机视觉和机器学习库。 拥有2500多种优化算法,包括经典最先进的计算机视觉和机器学习算法。 有许多语言界面,如Python、Java、c和Matlab。

在这里,我们将处理Python接口。

安装

在Windows上,请在此确认指南。 地址: https://opencv-python-tutroals.readthedocs.io/en/latest/py _ tutorials/py _ setup/py _ setup _ in _位址

警告通过1:opencv读取图像时,不是在RGB颜色空间,而是在BGR颜色空间读取。 有时这对你来说不是问题。 只有当sdddd想给图像添加颜色时才会出现问题。

有两个解决方案:

r -交换第一个颜色值(红色)和b -第三个颜色值)蓝色),使其变为0,0 ),而不是255,0,0 )。 将色彩空间更改为RGB:

使用rgb_image而不是image继续处理代码。

要关闭显示警告2:图像的窗口,请按任意按钮。 关闭按钮可能会导致窗口冻结。 在Jupyter笔记本上运行代码时发生。

为了简单起见,在整个教程中,使用此方法查看图像:

资料来源: Pixabay

裁剪

资料来源: Pixabay

裁剪后的凉爽的太阳

其中,image [ 10:500,500:200 ]是image[y:y h,x:x w]。

调整大小

资料来源: Pexels

大小改为20%后

.com/origin/pgc-image/08115db07ac54b9c956fea75044bd879?from=pc">

这个调整大小函数会保持原始图像的尺寸比例。

更多图像缩放函数,请查看这里。(https://www.tutorialkart.com/opencv/python/opencv-python-resize-image/ )

旋转

左图: 图片来自Pexels的Jonathan Meyer。右图: 进行180度旋转之后的耍酷的太阳。

image.shape输出高度、宽度和通道。M是旋转矩阵——它将图像围绕其中心旋转180度。

-ve表示顺时针旋转图像的角度 & +ve逆表示逆时针旋转图像的角度。

灰度和阈值(黑白效果)

来源:Pexels

gray_image 是灰度图像的单通道版本。

这个threshold函数将把所有比127深(小)的像素点阴影值设定为0,所有比127亮(大)的像素点阴影值设定为255。

另一个例子:

这将把所有阴影值小于150的像素点设定为10和所有大于150的像素点设定为200。

更多有关thresholding函数的内容,请查看这里。(https://docs.opencv.org/3.4/d7/d4d/tutorial_py_thresholding.html )

左图:灰阶耍酷的太阳。右图:黑白耍酷的太阳。

模糊/平滑

左图:图像来自Pixabay。右图:模糊后的耍酷的太阳。

高斯模糊函数接受3个参数:

第一个参数是要模糊的图像。第二个参数必须是一个由两个正奇数组成的元组。当它们增加,模糊效果也会增加。第三个参数是sigmaX和sigmaY。当左边位于0时,它们会自动从内部大小计算出来。

更多关于模糊函数的内容,请查看这里。(https://docs.opencv.org/3.1.0/d4/d13/tutorial_py_filtering.html )

在图像上绘制矩形框或边框

左图:图像来自Pixabay。右图:脸上有一个矩形框的耍酷的太阳。

rectangle函数接受5个参数:

第一个参数是图像。第二个参数是x1, y1 -左上角坐标。第三个参数是x2, y2 -右下角坐标。第四个参数是矩形颜色(GBR/RGB,取决于你如何导入图像)。第五个参数是矩形线宽。

绘制一条线

左图:图像来自Pixabay。右图:两只耍酷的太阳用一条线分开。

line函数接受5个参数:

第一个参数是要画的线所在的图像。第二个参数是x1, y1。第三个参数是x2, y2。第四个参数是线条颜色(GBR/RGB,取决于你如何导入图像)。第五个参数是线宽。

在图片上写入文字

左图:图像来自Pixabay。右图:两只耍酷的太阳用一条线分开。

putText函数接受 七个参数:

第一个参数是要写入文本的图像。第二个参数是待写入文本。第三个参数是x, y——文本开始的左下角坐标。第四个参数是字体类型。第五个参数是字体大小。第六个参数是颜色(GBR/RGB,取决于你如何导入图像)。第七个参数是文本线条的粗细。

人脸检测

这里没有找到耍酷的太阳照片,很遗憾:(

图片来自Pixabay,作者:Free-Photos。

detectMultiScale函数是一种检测对象的通用函数。因为我们调用的是人脸级联,所以它会检测到人脸。

detectMultiScale函数接受4个参数:

第一个参数是灰阶图像。第二个参数是scaleFactor。因为有些人脸可能离镜头更近,所以看起来会比后台的人脸更大。比例系数弥补了这一点。检测算法使用一个移动窗口来检测对象。minNeighbors定义在当前对象附近检测到多少对象,然后再声明检测到人脸。与此同时,minsize给出了每个窗口的大小。

检测到两张人脸。

轮廓——一种对象检测方法

使用基于颜色的图像分割,你可以来检测对象。

cv2.findContours & cv2.drawContours 这两个函数可以帮助你做到这一点。

最近,我写了一篇非常详细的文章,叫做《使用Python通过基于颜色的图像分割来进行对象检测》。你需要知道的关于轮廓的一切都在那里。(https://towardsdatascience.com/object-detection-via-color-based-image-segmentation-using-python-e9b7c72f0e11 )

最终,保存图片

总结

OpenCV是一个非常容易使用的算法库,可以用于3D建模、高级图像和视频编辑、跟踪视频中的标识对象、对视频中正在做某个动作的人进行分类、从图像数据集中找到相似的图像,等等。

最重要的是,学习OpenCV对于那些想要参与与图像相关的机器学习项目的人来说是至关重要的。

英文原文:https://qiniumedia.freelycode.com/vcdn/1/%E4%BC%98%E8%B4%A8%E6%96%87%E7%AB%A0%E9%95%BF%E5%9B%BE3/opencv-python-cheetsheet.pdf 译者:好酒不上头

扫描二维码推送至手机访问。

版权声明:本文由花开半夏のブログ发布,如需转载请注明出处。

本文链接:https://www.zhangshilong.cn/work/25655.html

分享给朋友:

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。