opencv-python 极速入门

简介: opencv-python 极速入门

opencv-python 极速入门


什么是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


图像导入&显示


c94f517893ba625d9f7b21373210d713.jpg


警告1: 通过openCV读取图像时,它不是以RGB 颜色空间来读取,而是以BGR 颜色空间。有时候这对你来说不是问题,只有当你想在图片中添加一些颜色时,你才会遇到问题。


有两种解决方案:


将R — 第一个颜色值(红色)和B  — 第三个颜色值(蓝色) 交换, 这样红色就是 (0,0,255) 而不是(255,0,0)。

将颜色空间变成RGB:


b6f45253b7dce5ccb292356d5ddd84c2.jpg


使用rgb_image代替image继续处理代码。


警告2: 要关闭显示图像的窗口,请按任意按钮。如果你使用关闭按钮,它可能会导致窗口冻结(我在Jupyter笔记本上运行代码时发生了这种情况)。

为了简单起见,在整个教程中,我将使用这种方法来查看图像:


9fee14c141fbbdca71022a3d6e861d57.jpg


1d818dd62368da6a009425eebb95e06b.jpg


来源:Pixabay


裁剪

c0abe1dbf22dc8a66a31b3d6956a8eee.jpg

来源:Pixabay


a2d9778ea34a681a52b630c1b13edae7.jpg


裁剪后的狗狗

e99653c887ad4e28cf008c81c4de6ee8.jpg


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


调整大小

16aaa91b7105beda40c59908bd08fb34.jpg

来源:Pexels


8690d8b2022c71c0ed36b209330e5c50.jpg

调整大小到20%后


1d95cb167038299b0c20436c098902aa.jpg

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

更多图像缩放函数,请查看这里。


https://www.tutorialkart.com/opencv/python/opencv-python-resize-image/


旋转


05e6fff609d7273f16209ccec9caadc8.jpg


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

ff301ca42ff69a498173ad832df48438.jpg

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

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


灰度和阈值(黑白效果)

image.jpeg


来源:Pexels


e786f99ee24a43b09dff3e08f44859c7.jpg

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

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

另一个例子:

a3bd7844ca4f10f65af50f039d43b7f7.jpg

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

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


d3432452c8d303840501078a76145485.jpg


左图:灰阶狗狗。右图:黑白狗狗。


模糊/平滑

e73b32fa5bc755de24e6492930e4c19f.jpg

左图:图像来自Pixabay。右图:模糊后的狗狗。


5fccb88ee9af031a7195db10c6317b2a.jpg


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


第一个参数是要模糊的图像。

第二个参数必须是一个由两个正奇数组成的元组。当它们增加,模糊效果也会增加。

第三个参数是sigmaX和sigmaY。当左边位于0时,它们会自动从内部大小计算出来。

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


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


b0936fa3070a539c766db9e2596fdc00.jpg

左图:图像来自Pixabay。右图:脸上有一个矩形框的狗狗。


4bf497d6907918aa26778a7bf00ad583.jpg

rectangle函数接受5个参数:

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


绘制一条线


3165ce66db216e76a7cc12d0ede1cea6.jpg


左图:图像来自Pixabay。右图:两只狗狗用一条线分开。


55855b1dec10954cad3be586a403ad2a.jpg


line函数接受5个参数:


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


在图片上写入文字

1b8021d04a9e4bd361feccf7a0dbadf7.jpg


左图:图像来自Pixabay。右图:两只狗狗用一条线分开。


c11ac002ad788c41160fceeb3b9c85f0.jpg

putText函数接受 七个参数:

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


人脸检测


这里没有找到狗狗照片,很遗憾:(


2ee91b511ed093d08736247018664333.jpg

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


9dcf1f89015ab68ca998a5f0f3855cd3.jpg

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


detectMultiScale函数接受4个参数:


第一个参数是灰阶图像。

第二个参数是scaleFactor。因为有些人脸可能离镜头更近,所以看起来会比后台的人脸更大。比例系数弥补了这一点。

检测算法使用一个移动窗口来检测对象。minNeighbors定义在当前对象附近检测到多少对象,然后再声明检测到人脸。

与此同时,minsize给出了每个窗口的大小。


2d87caa05caacfda155cc0603c45c6dd.jpg


检测到两张人脸。


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


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


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


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


最终,保存图片


88d2c948a4a8905f38ac7a40cdef0a0c.jpg


总结


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

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

相关文章
|
2天前
|
机器学习/深度学习 数据可视化 数据挖掘
使用Python进行数据分析的入门指南
【9月更文挑战第33天】本文旨在为初学者提供一个关于使用Python进行数据分析的全面概述。我们将从基本的安装和设置开始,逐步介绍数据处理、数据可视化以及机器学习的基本概念和应用。文章将通过实际代码示例来展示如何使用Python及其相关库来解决常见的数据分析问题。
|
8天前
|
Python
Python 编程入门:打造你的第一个程序
【9月更文挑战第27天】编程,就像是在数字世界里绘画。想象一下,你手中的键盘是画笔,屏幕是画布,而代码则是你的颜料。这篇文章将带你走进编程的世界,学习如何使用 Python 这门语言来创建你的第一个程序。我们将从基础的语法开始,逐步深入到条件判断和循环结构,最终完成一个简单的猜数字游戏。无论你是否有编程经验,这里的内容都将为你打开一扇新的大门。
|
8天前
|
人工智能 数据挖掘 开发者
Python编程入门:从零到英雄
【9月更文挑战第27天】本文旨在通过浅显易懂的语言,为初学者介绍Python编程的基础知识和实用技巧。我们将一起探索Python的世界,了解其语法、数据结构,并通过实际示例学习如何编写简单的Python程序。无论你是编程新手,还是希望拓展技能的开发者,这篇文章都将为你打开一扇通往Python编程世界的大门。
|
6天前
|
Python
? Python 装饰器入门:让代码更灵活和可维护
? Python 装饰器入门:让代码更灵活和可维护
12 4
|
9天前
|
存储 人工智能 数据挖掘
Python编程入门:从基础到实战
【9月更文挑战第26天】 在这篇文章中,我们将一起探索Python编程的奇妙世界。无论你是初学者还是有一定经验的开发者,这篇文章都将为你提供有价值的信息和技巧。我们将从Python的基本语法开始,然后逐步深入到更复杂的主题,如函数、类和模块。最后,我们将通过一个实际的项目来应用我们所学的知识。让我们一起开始这段Python编程之旅吧!
|
6天前
|
数据可视化 Python
使用Python进行数据可视化:从入门到精通
【8月更文挑战第60天】本文是一篇面向初学者的Python数据可视化教程,旨在帮助读者掌握如何使用Python及其强大的库(如Matplotlib和Seaborn)来创建引人入胜的数据可视化。我们将从基础开始,逐步深入,最终达到能够独立完成复杂数据可视化项目的水平。无论你的背景如何,只要你对数据可视化感兴趣,这篇文章都将为你开启一段新的学习之旅。
|
9天前
|
数据采集 人工智能 数据挖掘
Python编程入门:从基础到实战的快速指南
【9月更文挑战第25天】本文旨在为初学者提供一个简明扼要的Python编程入门指南。通过介绍Python的基本概念、语法规则以及实际案例分析,帮助读者迅速掌握Python编程的核心技能。文章将避免使用复杂的专业术语,而是采用通俗易懂的语言和直观的例子来阐述概念,确保内容的可读性和实用性。
|
7天前
|
Python
Python 装饰器入门:让代码更灵活和可维护
Python 装饰器入门:让代码更灵活和可维护
12 1
|
9天前
|
设计模式 开发者 Python
Python中的装饰器:从入门到精通
【9月更文挑战第25天】本文深入浅出地介绍了Python装饰器的使用,包括其定义、语法和实际应用。通过实例演示如何利用装饰器增强函数功能,同时探讨了装饰器的高级用法如带参数的装饰器和装饰器嵌套。最后,文章强调了在设计装饰器时应避免的常见陷阱。
|
9天前
|
前端开发 开发者 Python
从零到一:Python Web框架中的模板引擎入门与进阶
在Web开发的广阔世界里,模板引擎是连接后端逻辑与前端展示的重要桥梁。对于Python Web开发者而言,掌握模板引擎的使用是从零到一构建动态网站或应用不可或缺的一步。本文将带你从基础入门到进阶应用,深入了解Python Web框架中的模板引擎。
14 3
下一篇
无影云桌面