【计算机视觉】opencv入门学习笔记Part.1

  • 1 前言
    • 1.1 opencv概述(摘取自百度百科)
    • 1.2 图像概念引入
    • 1.3 安装opencv库
  • 2 图像基本操作
    • 2.1 图像的读取
    • 2.2 图像的显示
    • 2.3 图像的保存
    • 2.4 图像的复制
  • 3 视频的读取
  • 4 ROI区域
    • 4.1 截取图像
    • 4.2 提取颜色通道
    • 4.3 合并颜色通道
    • 4.3 仅保留B/G/R通道

1 前言

1.1 opencv概述(摘取自百度百科)

opencv全称Open Source Computer Vision Library
opencv是一个基于BSD许可(开源)发行的跨平台计算机视觉和机器学习软件库
可以运行在Linux、Windows、Android和Mac OS操作系统上
它轻量级而且高效——由一系列 C 函数和少量 C++ 类构成
同时提供了Python、Ruby、MATLAB等语言的接口,实现了图像处理和计算机视觉方面的很多通用算法。
在可用时利用MMX和SSE指令, 如今也提供对于C#、Ch、Ruby,GO的支持

1.2 图像概念引入

在python当中每个彩色图像相当于一个三维列表
这个三维列表中,有三个二维列表,分别对应R、G、B三个颜色通道
而一维列表中的每一个数值对应一个像素点,数值大小代表亮度,取值为0~255
需要注意的是在opencv读取图片颜色通道顺序为B、G、R

1.3 安装opencv库

按win+r打开控制台输入 pip install opencv-python

2 图像基本操作

(将该图片下载到与项目文件同级的目录下)

2.1 图像的读取

  • cv2.IMREAD_COLOR:彩色图像
  • cv2.IMREAD_GRAYSCALE:灰色图像
#导入cv2包
import cv2#读取名为lena.jpg的图像默认为彩色,赋值给名为的img变量
img = cv2.imread('lena.jpg')
#参数为(263, 263, 3),分别对应宽、高、颜色通道数量
print("img:", end="")
print(img.shape)#读取名为lena.jpg的图像选择读取方式为灰度,赋值给名为的imgGray变量
imgGray = cv2.imread('lena.jpg', cv2.IMREAD_GRAYSCALE)
#参数为(263, 263),分别对应宽、高,灰度图像没有颜色通道数量
print("imgGray:", end="")
print(imgGray.shape)

2.2 图像的显示

import cv2#读取图像
img = cv2.imread('lena.jpg')
print("img:", end="")
print(img.shape)
imgGray = cv2.imread('lena.jpg', cv2.IMREAD_GRAYSCALE)
print("imgGray:", end="")
print(imgGray.shape)#图像的显示,第一个参数为窗口名,也可以创建多个窗口
cv2.imshow('imgGray', imgGray)
#等待键盘时间,毫秒级,0表示任意键终止
cv2.waitKey(0)
#销毁所有窗口
cv2.destroyAllWindows()

2.3 图像的保存

import cv2#以灰度形式读取图像
imgGray = cv2.imread('lena.jpg', cv2.IMREAD_GRAYSCALE)
#将灰度图像保存到本地同级路径名为lenaGray.jpg
cv2.imwrite('lenaGray.jpg', imgGray)

2.4 图像的复制

import cv2#读取图像
img = cv2.imread('lena.jpg')
#用copy函数复制与原图一模一样的图片(不会保存到本地)
imgCopy = img.copy()
#显示图像
cv2.imshow('imgCopy', imgCopy)
cv2.waitKey(0)
cv2.destroyAllWindow

3 视频的读取

(下载下方视频文件)
https://www.aliyundrive.com/s/MHpVMUA43Zr

  • cv2.VideoCapture可以捕获摄像头
  • 本地摄像头可用数字来控制不同的设备,如0、1
  • 也可以调用网络摄像头,在参数列表中指定地址即可
  • 还可以读取视频文件,直接指定文件路径
import cv2#指定路径读取视频文件
vc = cv2.VideoCapture('test.mp4')
#判断视频是否读取成功
while vc.isOpened():#读取视频中的每一帧图像,返回的第一个参数为是否读取到,第二个参数为读取到的图像ret, frame = vc.read()#显示图像cv2.imshow('video', frame)#通过waitKey函数控制视频播放速度, 0xFF相当与按下ESC键退出if cv2.waitKey(20) & 0xFF == 27:break#释放vc资源
vc.release()
#销毁所有窗口
cv2.destroyAllWindows()

4 ROI区域

ROI(region of interest),感兴趣区域。机器视觉、图像处理中
从被处理的图像以方框、圆、椭圆、不规则多边形等方式
勾勒出需要处理的区域,称为感兴趣区域,ROI

4.1 截取图像

import cv2#读取图像
img = cv2.imread('lena.jpg')
#通过切片的方式截取图像,宽、高各200个像素点
imgPart = img[0:200, 0:200]
#显示图像
cv2.imshow('imgPart', imgPart)
cv2.waitKey(0)
cv2.destroyAllWindow

4.2 提取颜色通道

import cv2#读取图像
img = cv2.imread('lena.jpg')
#用split函数提取B、G、R三个颜色通道的列表
b, g, r = cv2.split(img)

4.3 合并颜色通道

import cv2#读取图像
img = cv2.imread('lena.jpg')
#提取B、G、R颜色通道
b, g, r = cv2.split(img)
#用merge函数以B、G、R的顺序合并颜色通道
imgMerge = cv2.merge((b, g, r))
#显示图像
cv2.imshow('imgMerge ', imgMerge )
cv2.waitKey(0)
cv2.destroyAllWindow

4.3 仅保留B/G/R通道

import cv2#读取图像
img = cv2.imread('lena.jpg')#仅保留B通道
img_B = img.copy()
img_B[:, :, 1] = 0
img_B[:, :, 2] = 0#仅保留G通道
img_G = img.copy()
img_G[:, :, 0] = 0
img_G[:, :, 2] = 0#仅保留R通道
img_R = img.copy()
img_R[:, :, 0] = 0
img_R[:, :, 1] = 0#通过hconcat将三张图片拼接
imgStack = cv2.hconcat([img_B, img_G, img_R])#显示图像
cv2.imshow('imgStack', imgStack)
cv2.waitKey(0)
cv2.destroyAllWindow

【计算机视觉】opencv入门学习笔记Part.1相关推荐

  1. 【OpenCV入门学习笔记2】:Mat对象

    b站:https://www.bilibili.com/video/BV1uW411d7Wf?p=5 我在b站的学习笔记和实验代码的整理如下: 示例代码: Matdemo //------------ ...

  2. 【OpenCV入门学习笔记1】:Mat对象的指针操作和掩膜操作

    b站:https://www.bilibili.com/video/BV1uW411d7Wf?p=5 下面是我在b站上看视频学习的笔记和操作的示例代码 实例代码 #include<opencv2 ...

  3. OpenCV入门学习笔记之Harris角点检测与SIFT特征匹配算法

    1. 写在前面 这篇文章整理两个图像处理中非常重要的算法,一个是Harris角点检测算法,另一个是SIFT特征匹配算法,这两个算法本质上还是去找图像里面的关键特征点,帮助我们后续更好的理解图像以及做各 ...

  4. 激光SLAM入门学习笔记

    激光SLAM入门学习笔记 激光SLAM入门学习笔记 一.推荐阅读书籍 二.推荐公众号.知乎.博客 1.公众号 2.知乎 3.博客 三.推荐阅读论文&代码(参考泡泡机器人) 2D激光SLAM 3 ...

  5. opencv进阶学习笔记3:像素运算和图像亮度对比度调节

    基础版传送门: python3+opencv学习笔记汇总目录(适合基础入门学习) 进阶版目录: python+opencv进阶版学习笔记目录(适合有一定基础) 像素运算 要求两张图大小,以及格式(np ...

  6. 原创 OpenCV3编程入门 学习笔记(总)

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/qq_36163358/article/ ...

  7. OpenCV3编程入门 学习笔记(总)

    OpenCV3编程入门 学习笔记 2018.12.12-2018.12.29 此博客为在看过毛星云版<OpenCV3编程入门>后所总结的一本笔记,可供复习使用. 文章目录 OpenCV3编 ...

  8. dubbo入门学习笔记之入门demo(基于普通maven项目)

    注:本笔记接dubbo入门学习笔记之环境准备继续记录; (四)开发服务提供者和消费者并让他们在启动时分别向注册中心注册和订阅服务 需求:订单服务中初始化订单功能需要调用用户服务的获取用户信息的接口(订 ...

  9. Crypto++入门学习笔记(DES、AES、RSA、SHA-256)

    Crypto++入门学习笔记(DES.AES.RSA.SHA-256) 背景(只是个人感想,技术上不对后面的内容构成知识性障碍,可以skip): 最近,基于某些原因和需要,笔者需要去了解一下Crypt ...

最新文章

  1. jQuery验证控件jquery.validate.js使用说明+中文API
  2. 数据结构实验之图论三:判断可达性(dfs/bfs)
  3. shell中trap捕捉到信号的处理
  4. BUUCTF (pwn) bjdctf_2020_YDSneedGrirlfriend(UAF)
  5. .NET Core快速入门教程 1、开篇:说说.NET Core的那些事儿
  6. 沉降观测曲线图 沉降观测汇总_这些沉降观测要求,工程人必须掌握!
  7. PHP出现 Notice: Undefined index:...的原因及解决办法
  8. CentOS 7系统升级备份恢复实验记录
  9. Windows 10 S 已死,S 模式长存!
  10. 计算机毕业设计中JAVA 23种开发模式详解(代码举例)
  11. 苍蓝契约服务器维护,苍蓝誓约萌新玩家新手任务及刷初始方法
  12. 为什么存储服务器硬盘格式化不,硬盘为什么不能格式化
  13. 见面会 | 创新工场执行董事王嘉平:高性能可伸缩性区块链系统揭秘!
  14. Python每日一记179文氏图绘制
  15. 《数据库系统概论》:DBA的职责有些
  16. 匈牙利算法编程c语言,华为oj之素数伴侣---匈牙利算法
  17. bash 将二进制转换为十进制_PowerShell把IP地址转换成二进制的方法
  18. Retina U-Net论文简析
  19. 王俊杰:苏宁AI在智慧零售上的应用
  20. 2018信用服务业市场:天眼查、企查查、启信宝、企查猫处第一梯队

热门文章

  1. 英语中定语和状语的区别
  2. PHP入门需要多久?
  3. sim卡iccid编辑软件_5G超级SIM卡 能握在自己手中的 才是最安全的
  4. 计算机WORD函数求乘积,Word表格函数运用:加减乘除、求和、求积超简单,大神都不一定会!...
  5. unity 动画控制器
  6. Python-Selenium:如何通过click在新的标签页打开链接?
  7. php完全开发手册下载,thinkphp5完全开发手册
  8. 用Q-learning算法实现自动走迷宫机器人
  9. 蓝桥杯 ALGO-1003 礼物
  10. 网易有道,能否看透“K12双减”风浪?