OpenCV-Python速查表:从导入图像到人脸检测
wptr33 2025-08-02 22:19 2 浏览
——本文对图像裁剪、调整大小、旋转、阈值、模糊、在图像上绘图和书写、人脸检测和使用轮廓图像检测对象都进行了解释。
什么是OpenCV-Python?
OpenCV是一个开源的计算机视觉(computer vision)和机器学习库。它拥有超过2500个优化算法,包括经典和最先进的计算机视觉和机器学习算法。它有很多语言接口,包括Python、Java、c++和Matlab。
这里,我们将处理Python接口。
安装
- 在Windows上, 请在这里查看指南。地址:https://opencv-python-tutroals.readthedocs.io/en/latest/py_tutorials/py_setup/py_setup_in_windows/py_setup_in_windows.html
- 在 Linux上, 请在这里查看指南。地址:https://docs.opencv.org/trunk/d7/d9f/tutorial_linux_install.html
图像导入&显示
警告1: 通过openCV读取图像时,它不是以RGB 颜色空间来读取,而是以BGR 颜色空间。有时候这对你来说不是问题,只有当你想在图片中添加一些颜色时,你才会遇到问题。
有两种解决方案:
- 将R — 第一个颜色值(红色)和B — 第三个颜色值(蓝色) 交换, 这样红色就是 (0,0,255) 而不是(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%后
这个调整大小函数会保持原始图像的尺寸比例。
更多图像缩放函数,请查看这里。(
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 译者:好酒不上头
相关推荐
- Windows10 编译OpenCV4.5源码
-
在OpenCV4.5+VisualStudio2017开发环境配置...
- 什么是OpenCV?有哪些基础图像处理操作?
-
一、OpenCV简介OpenCV是一款由Intel公司俄罗斯团队发起并参与和维护的一个计算机视觉处理开源软件库,支持与计算机视觉和机器学习相关的众多算法,并且正在日益扩展。...
- 学习Opencv-第9节-读写图像
-
1、读图像---imread()Matimread(conststring&filename,ingflags=1)定义中包含两个参数,一个图像文件名,一个flag标志位,返回的是一个Ma...
- 基于opencv的视觉巡线实现
-
前言这段时间在和学弟打软件杯的比赛,有项任务就是机器人的视觉巡线,这虽然不是什么稀奇的事情,但是对于一开始不了解视觉的我来说可以说是很懵了,所以现在就想着和大家分享一下,来看看是如何基于opencv来...
- OpenCV学习之图像读取与显示
-
1、OpenCV的特点(1)总体描述...
- OpenCV+Python裁剪图像
-
最近使用OpenCV+Python做了一个程序,功能是自动将照片中的文本部分找出来并裁剪/旋转保存为新的图片。这个功能用专业些的说法就是选择并提取感兴趣区域(ROI(RegionofInteres...
- OpenCV-Python速查表:从导入图像到人脸检测
-
——本文对图像裁剪、调整大小、旋转、阈值、模糊、在图像上绘图和书写、人脸检测和使用轮廓图像检测对象都进行了解释。什么是OpenCV-Python?OpenCV是一个开源的计算机视觉(computer...
- Python图像处理:OpenCV基础教程
-
OpenCV(OpenSourceComputerVisionLibrary)是一个开源计算机视觉和机器学习软件库。它提供了大量的图像和视频处理功能,可以用于各种应用场景,比如人脸识别、物体检...
- OpenCV学堂深度学习系统化学习路线图专题(2023版)
-
参考资料:aixuetang.xyz/15842...
- OpenCV4系统化学习路线图与教程
-
获课:bcwit.top/15489...
- 使用OpenCV库操作摄像头拍照、调节参数和视频录制
-
需求使用OpenCV做功能,播放摄像头(usb和网络),对摄像头设备进行参数调整(亮度、对比度、饱和度、色调、增益、曝光度)调节,拍照和录像。原理使用OpenCV打开摄像头(可打开USB和网路哦摄像...
- Python图像处理:用OpenCV实现照片的趣味特效与编辑!
-
在当今数字化时代,图像处理已经成为了我们生活中不可或缺的一部分,无论是社交媒体上的照片美化,还是专业领域的图像分析,都离不开图像处理技术。Python作为一门强大的编程语言,搭配OpenCV库,为我们...
- OpenCV-1: 读取图片,显示图片,保存图片
-
目标1在这里,将学习如何读取图像,如何显示图像以及如何将其保存回去将学习以下功能:...
- JAVA学习笔记——fileUpload文件上传
-
一、什么是fileUpload?fileUpload是apache的commons组件提供的上传组件,它最主要的工作就是帮我们解析request.getInpustream()。可以参考在线API文档...
- 如何在Windows10中配置java的JDK环境
-
今天给大家分享一下如何配置java的JDK环境。操作步骤如下:1.下载好jdk的安装文件,我下载的是jdk-10.0.1_windows-x64_bin.exe这个版本的安装文件;2.使用鼠标...
- 一周热门
-
-
因果推断Matching方式实现代码 因果推断模型
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
git pull命令使用实例 git pull--rebase
-
git 执行pull错误如何撤销 git pull fail
-
面试官:git pull是哪两个指令的组合?
-
git pull 和git fetch 命令分别有什么作用?二者有什么区别?
-
git fetch 和git pull 的异同 git中fetch和pull的区别
-
git pull 之后本地代码被覆盖 解决方案
-
还可以这样玩?Git基本原理及各种骚操作,涨知识了
-
git命令之pull git.pull
-
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)