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编程入门:从零到英雄
在这篇文章中,我们将一起踏上Python编程的奇幻之旅。无论你是编程新手,还是希望拓展技能的开发者,本教程都将为你提供一条清晰的道路,引导你从基础语法走向实际应用。通过精心设计的代码示例和练习,你将学会如何用Python解决实际问题,并准备好迎接更复杂的编程挑战。让我们一起探索这个强大的语言,开启你的编程生涯吧!
|
1月前
|
存储 数据采集 人工智能
Python编程入门:从零基础到实战应用
本文是一篇面向初学者的Python编程教程,旨在帮助读者从零开始学习Python编程语言。文章首先介绍了Python的基本概念和特点,然后通过一个简单的例子展示了如何编写Python代码。接下来,文章详细介绍了Python的数据类型、变量、运算符、控制结构、函数等基本语法知识。最后,文章通过一个实战项目——制作一个简单的计算器程序,帮助读者巩固所学知识并提高编程技能。
|
1月前
|
机器学习/深度学习 数据可视化 数据挖掘
使用Python进行数据分析的入门指南
本文将引导读者了解如何使用Python进行数据分析,从安装必要的库到执行基础的数据操作和可视化。通过本文的学习,你将能够开始自己的数据分析之旅,并掌握如何利用Python来揭示数据背后的故事。
|
2月前
|
机器学习/深度学习 数据可视化 数据挖掘
使用Python进行数据分析的入门指南
【10月更文挑战第42天】本文是一篇技术性文章,旨在为初学者提供一份关于如何使用Python进行数据分析的入门指南。我们将从安装必要的工具开始,然后逐步介绍如何导入数据、处理数据、进行数据可视化以及建立预测模型。本文的目标是帮助读者理解数据分析的基本步骤和方法,并通过实际的代码示例来加深理解。
72 3
|
4天前
|
人工智能 编译器 Python
python已经安装有其他用途如何用hbuilerx配置环境-附带实例demo-python开发入门之hbuilderx编译器如何配置python环境—hbuilderx配置python环境优雅草央千澈
python已经安装有其他用途如何用hbuilerx配置环境-附带实例demo-python开发入门之hbuilderx编译器如何配置python环境—hbuilderx配置python环境优雅草央千澈
python已经安装有其他用途如何用hbuilerx配置环境-附带实例demo-python开发入门之hbuilderx编译器如何配置python环境—hbuilderx配置python环境优雅草央千澈
|
1月前
|
IDE 程序员 开发工具
Python编程入门:打造你的第一个程序
迈出编程的第一步,就像在未知的海洋中航行。本文是你启航的指南针,带你了解Python这门语言的魅力所在,并手把手教你构建第一个属于自己的程序。从安装环境到编写代码,我们将一步步走过这段旅程。准备好了吗?让我们开始吧!
|
1月前
|
测试技术 开发者 Python
探索Python中的装饰器:从入门到实践
装饰器,在Python中是一块强大的语法糖,它允许我们在不修改原函数代码的情况下增加额外的功能。本文将通过简单易懂的语言和实例,带你一步步了解装饰器的基本概念、使用方法以及如何自定义装饰器。我们还将探讨装饰器在实战中的应用,让你能够在实际编程中灵活运用这一技术。
39 7
|
1月前
|
开发者 Python
Python中的装饰器:从入门到实践
本文将深入探讨Python的装饰器,这一强大工具允许开发者在不修改现有函数代码的情况下增加额外的功能。我们将通过实例学习如何创建和应用装饰器,并探索它们背后的原理和高级用法。
44 5
|
1月前
|
机器学习/深度学习 人工智能 算法
深度学习入门:用Python构建你的第一个神经网络
在人工智能的海洋中,深度学习是那艘能够带你远航的船。本文将作为你的航标,引导你搭建第一个神经网络模型,让你领略深度学习的魅力。通过简单直观的语言和实例,我们将一起探索隐藏在数据背后的模式,体验从零开始创造智能系统的快感。准备好了吗?让我们启航吧!
77 3
|
1月前
|
Python
Python编程入门:从零开始的代码旅程
本文是一篇针对Python编程初学者的入门指南,将介绍Python的基本语法、数据类型、控制结构以及函数等概念。文章旨在帮助读者快速掌握Python编程的基础知识,并能够编写简单的Python程序。通过本文的学习,读者将能够理解Python代码的基本结构和逻辑,为进一步深入学习打下坚实的基础。