OpenCV-Python速查表:从导入图像到人脸检测
moboyou 2025-05-04 15:27 10 浏览
——本文对图像裁剪、调整大小、旋转、阈值、模糊、在图像上绘图和书写、人脸检测和使用轮廓图像检测对象都进行了解释。
什么是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 译者:好酒不上头
相关推荐
- cvpr 2024|注意力校准用于解缠结的文本到图像个性化
-
AttentionCalibrationforDisentangledText-to-ImagePersonalization研究背景近年来,大规模文本到图像(T2I)模型取得了显著进展,能...
- 1080P的显示,4K的享受?NVIDIA DSR游戏实测!
-
游戏玩家对画质的要求越来越高,因此每到新一代显卡推出的时候,除了游戏性能的提升之外,也会采用提升画质的新技术。NVIDIA最新的Geforce900系列显卡也不例外,一起推出的DSR技术号称可以在1...
- 「学习OpenCV4」OpenCV线性滤波与非线性滤波总结
-
本文分享内容来自图书《学习OpenCV4:基于Python的算法实战》,该书内容如下:第1章OpenCV快速入门;第2章图像读写模块imgcodecs;第3章核心库模块core;第4章...
- 增益映射耦合局部正则化的图像重构算法
-
朱莉(西安科技大学计算机学院,陕西西安710054)摘要:针对当前的图像重构方法在对多帧超分辨率图像复原时,存在明显的模糊效应与振铃效应的不足,提出增益映射控制耦合局部正则化的图像重构算法。首...
- 图像处理——5种常见的平滑滤波
-
平滑滤波是一种简单又常见的图像处理操作。平滑图像的目的有很多,但通常都是为了减少噪声和伪影。在OpenCV中共有5种平滑滤波操作,分别是以下几种:测试代码如下:#include<iostream...
- C# 图像处理技术——简单的滤波去噪
-
在C#中,可以使用System.Drawing命名空间中的类来进行图像处理和滤波去噪操作。以下是一个示例代码,演示如何使用平均滤波器进行简单的去噪处理:usingSystem.Drawing;us...
- Java,OpenCV,图像模糊,归一化均值滤波,中值滤波器,高斯模糊
-
图像模糊图像模糊是图像处理中最简单和常用的操作之一,其主要目的之一是给图像预处理的时候降低图像噪声。图像模糊方法可以总结如下:1、归一化均值滤波器(API为blur())2、高斯滤波器(API为Ga...
- 带频偏校准的GMSK解调器设计与实现
-
郑婧怡1,高绍全1,姜汉钧1,张春1,王志华1,2,贾雯2(1.清华大学微电子所,北京100084;2.深圳清华大学研究院,广东深圳518055)摘要:提出了一种在零中频低功耗蓝牙接收机中使用...
- 图像滤波去噪方法及应用场景
-
在图像处理中,不同滤波方法针对不同类型的噪声和场景具有特定优势。以下是三种常见滤波器的特点和应用场景总结:1.高斯滤波(GaussianFilter)原理:基于高斯函数的加权平均,对邻域像素进行平...
- 多体系统动力学仿真软件(DAP)
-
多体系统动力学仿真软件(DAP)-北京西交智众软件科技有限公司–DAP软件简介DAP(DynamicsAnalysisPlatform)软件,源自西南交通大学沈志云院士带队轨道交通运载系统全国...
- 精品博文图文详解Xilinx ISE14.7 安装教程
-
在软件安装之前,得准备好软件安装包,可从Xilinx官网上下载:http://china.xilinx.com/support/download/index.html/content/xilinx/z...
- 酷睿 Ultra 5 和 Ultra 7,或者i5和i7差距多大?
-
#我来唠家常#提到ultra,我觉得看这个题目,应该主打轻薄本,或者设计本。分两个问题看:ultra7或者i7的优势,ultra相对老款处理器的优势Ultra7的最大优势是:多了2个大核心,这两个大...
- 直流-直流(DC-DC)变换电路
-
直流-直流(DC-DC)变换电路,可以将一种直流电源经过变换电路后输出另一种具有不同输出特性的直流电源,可以是一种固定电压或可调电压的直流电。按照电路拓扑结构的不同,DC-DC变换电路可以分成两种形式...
- Energies CL致命错误
-
期刊基础信息·刊号:ISSN1996-1073·全称:Energies·影响因子:3.2·分区:Q2(能源与燃料类)·版面费:2200瑞士法郎·年发文量:约4500篇CoverLett...
- 基于心电脉搏信号的无创血压算法研究
-
洋洋,陈小惠(南京邮电大学自动化学院,江苏南京210023)摘要:针对人体血压无创检测问题,提出了一种基于心电信号(Electrocardiogram,ECG)与光电容积脉搏波(Photople...
- 一周热门
- 最近发表
- 标签列表
-
- curseforge官网网址 (16)
- 外键约束 oracle (36)
- oracle的row number (32)
- 唯一索引 oracle (34)
- oracle in 表变量 (28)
- oracle导出dmp导出 (28)
- oracle 数据导出导入 (16)
- oracle两个表 (20)
- oracle 数据库 使用 (12)
- 启动oracle的监听服务 (13)
- oracle 数据库 字符集 (20)
- powerdesigner oracle (13)
- oracle修改端口 (15)
- 左连接 oracle (15)
- oracle 标准版 (13)
- oracle 转义字符 (14)
- asp 连接 oracle (12)
- oracle安装补丁 (19)
- matlab三维图 (12)
- matlab归一化 (16)
- matlab求解方程 (13)
- matlab坐标轴刻度设置 (12)
- matlab脚本 (14)
- matlab求逆 (12)
- matlab多项式拟合 (13)