openCV 3计算机视觉 Python语言实现 笔记__第二章 处理文件、摄像头和图形用户界面

简介: openCV 3计算机视觉 Python语言实现 笔记__第二章 处理文件、摄像头和图形用户界面

第2章 处理文件、摄像头和图形用户界面

2.1 基本IO脚本

大多数的CV应用程序需要将将图像作为输入,同时也会将图像作为输出。

还可能使用摄像头作为输入源,也可能是其他输入源,如视频等。

2.1.1 读/写图像文件

OpenCv的imread()函数和 imwrite()函数支持各种静态图像文件格式。

都支持bmp格式,通常也支持png,jpeg和tiff格式

 

读取文件,保存为另一种格式:

import cv2

image = cv2.imread(
'mypic.png')
cv2.imwrite(
'mypic.jpg',image)

 

#tip:图像文件直接写文件名(相对路径)时需要将图片和程序在同一文件夹,

使用绝对路径(例如D://mypic.png),则图像可以不和程序在同一文件夹。

 

彩色图像变黑白:#将加载的图像作为灰度图像(丢失颜色信息),然后保存。

import cv2




grayImage = cv2.imread('lion.jpg',cv2.IMREAD_GRAYSCALE)


cv2.imwrite('liongray.jpg',grayImage)

 2.1.2 图像与原始字节之间的转换

一个字节(8比特,)能表示0到255(2^8)的整数。一个像素通常由每个通道的一个字节表示。

 一个OpenCV图像是.array类型的二维或三维数组。8位的灰度图像是一个含有字节值的二维数组;一个24位的BGR图像是一个三维数组。

可使用表达式访问这些值,如image[0,0],image[0,0,0].

第一个代表y坐标,第二个是x坐标,第三个值表示颜色。

*坐标以左上角为原点[0,0]

对于一个左上角有白色像素的8位灰度图像而言,image[0,0]的值为255。

对于一个左上角有蓝色像素的24位BGR图像而言,image[0,0]的值是[255,0,0]。

若一幅图像的每个通道为8位,可以将其转换为标准的一维Python bytearray格式:

byteArray = bytearray[image]

反之,也可以将相应的bytearray转换成numpy.array形式的图像:

grayImage = numpy.array(grayByteArray).reshape(height,width)

bgrImage = numpy.array(bgrByteArray).reshape(height,width,3)

2.1.3  使用numpy.array访问图像数据

先看一个最基础的例子:将BGR图像在(0,0)处的像素转换成白像素。

import cv2

import  numpy as np

img = cv2.imread('lion.png')

img[0,0]=[255,255,255]

如果想改变一个特定像素的颜色值,numpy.array提供的item()方法会非常方便。该函数由三个参数x,y,以及(x,y)位置的数组索引,该函数能返回索引位置的值。另一个方法时使用itemset()函数设置指定像素在指定通道的值,

itemset()有两个参数:一个三元组(x,y,索引)和要设定的值。

例如,将坐标(150,120)的当前值变成255:

import  cv2

import numpy as np

img = cv2.imread('lion.png')

print (img.item(150,120,0))



img.itemset((150,120,0),255)

print (img.item(150,120,0))

下面介绍一个常见的操作:操作通道:将指定通道(B、G或R)的所有值设置为0。

import  cv2

import numpy as np

img = cv2.imread('lion.png')

img[:,:,1] = 0



cv2.imwrite('lionWithoutG.png',img)

查看图片会发现图片没有绿色(可能看起来是一张红色的照片)

通过NumPy数组访问原始像素,可以做一些有趣的事情,例如设定感兴趣区域(Region Of Interest,ROI)。一旦设定,就可以做许多操作,如,将该区域和变量绑定,然后设定第二个区域,并将第一个区域的值分配给第二个区域。

(即拷贝图像到另一个位置)。

*两个区域大小形状相同

import  cv2

import numpy as np

img = cv2.imread('lion.png')

my_roi = img[0:100, 0:100] #点[0,0]和[100,100]形成的矩形区域

img[300:400, 300:400] = my_roi

cv2.imwrite('lionCopySome.png',img)

使用numpy.array获得一些图像的细节:

import  cv2

import numpy as np

img = cv2.imread('lion.png')

print(img.shape)

print(img.size)

print(img.dtype)

shpe:返回包含宽度、高度和通道数的数组,

size:图像像素的大小

dtype:Datatype 图像的数据类型,通常是一个无符号整数类型。

2.1.4 视频文件的读/写

 OpenCV提供了VideoCapture和VideoWriter类来支持各种格式的视频文件。通常情况下都支持AVI格式。 在到达文件末尾之前,VideoCapture可以通过read()函数来获取新的帧,每一帧都是一幅BGR格式的图像。

可以将一幅图像传递给VideoWriter的write()函数。该函数会将图像加到VideoWriter类指向的文件中。

下面是一个读取AVI文件中的帧,并采用YUV颜色编码将其写入另一个帧中:

import  cv2

videoCapture = cv2.VideoCapture('MyInpuyVid.avi')

fps = videoCapture.get(cv2.CAP_PROP_FPS)

size = (int (videoCapture.get(cv2.CAP_PROP_FRAME_WIDTH)),

       int (videoCapture.get(cv2.CAP_PROP_FRAME_HEIGHT)))

videoWriter = cv2.VideoWriter('myOutVid.avi',cv2.VideoWriter_fourcc('I','4','2','0'),

                            fps,size)

success, frame = videoCapture.read()

while success:

   videoWriter.write(frame)

   success,frame = videoCapture.read()

*(采用cv2.VideoWriter_fourcc('I','4','2','0'))生成的myOutVid.avi非常大,我原视频只有8分钟95MB,生成的就有16GB的视频文件。而其他的会好很多,大概400MB。

需要为VideoWriter类的构造函数指定视频文件名,视频解码器。

常用的视频解码器选项:

帧速率和帧大小也必须指定,因为需要从一个视频复制视频帧,这些属性可以通过VideoCapture类的get()函数得到。

2.1.5 捕获摄像头的帧

VideoCapture类可以获得摄像头的帧。但对摄像头而言,不是同文件名来构造VideoCapture类,而是传入摄像头的设备索引(device index)。

例子:捕获10秒摄像头视频信息,写入AVI文件:

import  cv2



cameraCapture = cv2.VideoCapture(0)           #打开笔记本自带摄像头

fps = 30                                      #假设帧速为30

size = (int(cameraCapture.get(cv2.CAP_PROP_FRAME_WIDTH)),

       int(cameraCapture.get(cv2.CAP_PROP_FRAME_HEIGHT)))

videoWriter = cv2.VideoWriter(

   'MyOutputVid.avi',cv2.VideoWriter_fourcc('X','V','I','D'),

   fps,size)

success,frame = cameraCapture.read()

numFrameRemaing = 10*fps-1                    #录制10秒

print(numFrameRemaing)

while success and numFrameRemaing>0:

   videoWriter.write(frame)

   success,frame = cameraCapture.read()

   numFrameRemaing-=1

cameraCapture.release()

当需要同步一组或一个多头摄像头时,使用grab()和retrive()方法替代read():

success0 = cameraCaputre0.grab()

success1 = cameraCaputre1.grab()

if success0 and success1:

     frame0 = cameraCapture0.retrieve()

     frame1 = cameraCapture1.retrieve()



2.1.6 在窗口显示图像

使用imshow()。imshow有两个参数,显示图像的帧名称(窗口名)以及图像本身。

以下几行代码可以显示一幅图像:

import cv2

import numpy as np

img = cv2.imread('lion.png')

cv2.imshow('my image',img)   #调用imshow,显示一个叫my image的窗口                              #,图像为img

cv2.waitKey()                #等待按键

cv2.destroyAllWindows()

2.1.7 在窗口显示摄像头帧

import  cv2

clicked = False

def onMouse(event,x,y,flags,param):

   global clicked

   if event == cv2.EVENT_LBUTTONUP:

           clicked = True

cameraCapture = cv2.VideoCapture(0)

cv2.namedWindow('MyWindow')

cv2.setMouseCallback('MyWindow',onMouse)

print("Showing camera feed. Click window or press any key yo stop")

success,frame = cameraCapture.read()

while success and cv2.waitKey(1) == -1 and not clicked:

   cv2.imshow('MyWindow',frame)

   success,frame =cameraCapture.read()

cv2.destroyWindow('MyWindow')

cameraCapture.release()


*waitKey()的参数为等待键盘触发的时间,返回值为-1(没有按下)或按下的ASCII码。


相关文章
Ubuntu安装笔记(一):安装显卡驱动、cuda/cudnn、Anaconda、Pytorch、Tensorflow、Opencv、Visdom、FFMPEG、卸载一些不必要的预装软件
这篇文章是关于如何在Ubuntu操作系统上安装显卡驱动、CUDA、CUDNN、Anaconda、PyTorch、TensorFlow、OpenCV、FFMPEG以及卸载不必要的预装软件的详细指南。
10545 4
基于计算机视觉(opencv)的运动计数(运动辅助)系统-源码+注释+报告
基于计算机视觉(opencv)的运动计数(运动辅助)系统-源码+注释+报告
228 3
Opencv错误笔记(一):通过cv2保存图片采用中文命名出现乱码
在使用OpenCV的cv2模块保存带有中文命名的图片时,直接使用cv2.imwrite()会导致乱码问题,可以通过改用cv2.imencode()方法来解决。
446 0
Opencv错误笔记(一):通过cv2保存图片采用中文命名出现乱码
AI计算机视觉笔记二十 九:yolov10竹签模型,自动数竹签
本文介绍了如何在AutoDL平台上搭建YOLOv10环境并进行竹签检测与计数。首先从官网下载YOLOv10源码并创建虚拟环境,安装依赖库。接着通过官方模型测试环境是否正常工作。然后下载自定义数据集并配置`mycoco128.yaml`文件,使用`yolo detect train`命令或Python代码进行训练。最后,通过命令行或API调用测试训练结果,并展示竹签计数功能。如需转载,请注明原文出处。
AI计算机视觉笔记二十六:YOLOV8自训练关键点检测
本文档详细记录了使用YOLOv8训练关键点检测模型的过程。首先通过清华源安装YOLOv8,并验证安装。接着通过示例权重文件与测试图片`bus.jpg`演示预测流程。为准备训练数据,文档介绍了如何使用`labelme`标注工具进行关键点标注,并提供了一个Python脚本`labelme2yolo.py`将标注结果从JSON格式转换为YOLO所需的TXT格式。随后,通过Jupyter Notebook可视化标注结果确保准确性。最后,文档展示了如何组织数据集目录结构,并提供了训练与测试代码示例,包括配置文件`smoke.yaml`及训练脚本`train.py`,帮助读者完成自定义模型的训练与评估。
2102 2
使用 OpenCV 和 Python 轻松实现人脸检测
本文介绍如何使用OpenCV和Python实现人脸检测。首先,确保安装了OpenCV库并加载预训练的Haar特征模型。接着,通过读取图像或视频帧,将其转换为灰度图并使用`detectMultiScale`方法进行人脸检测。检测到的人脸用矩形框标出并显示。优化方法包括调整参数、多尺度检测及使用更先进模型。人脸检测是计算机视觉的基础技术,具有广泛应用前景。
227 10
Ubuntu安装笔记(三):ffmpeg(3.2.16)源码编译opencv(3.4.0)
本文是关于Ubuntu系统中使用ffmpeg 3.2.16源码编译OpenCV 3.4.0的安装笔记,包括安装ffmpeg、编译OpenCV、卸载OpenCV以及常见报错处理。
559 2
Ubuntu安装笔记(三):ffmpeg(3.2.16)源码编译opencv(3.4.0)
目标检测笔记(六):如何结合特定区域进行目标检测(基于OpenCV的人脸检测实例)
本文介绍了如何使用OpenCV进行特定区域的目标检测,包括人脸检测实例,展示了两种实现方法和相应的代码。
271 1
目标检测笔记(六):如何结合特定区域进行目标检测(基于OpenCV的人脸检测实例)
Ubuntu安装笔记(二):ubuntu18.04编译安装opencv 3.4.0 opencv_contrib3.4.0
本文介绍了在Ubuntu 18.04系统上编译安装OpenCV 3.4.0及其扩展包opencv_contrib 3.4.0的详细步骤,包括下载源码、安装依赖、配置CMake和编译安装,以及常见问题的解决方法。
906 1
Ubuntu安装笔记(二):ubuntu18.04编译安装opencv 3.4.0 opencv_contrib3.4.0
基于图论的时间序列数据平稳性与连通性分析:利用图形、数学和 Python 揭示时间序列数据中的隐藏模式
本文探讨了如何利用图论分析时间序列数据的平稳性和连通性。通过将时间序列数据转换为图结构,计算片段间的相似性,并构建连通图,可以揭示数据中的隐藏模式。文章介绍了平稳性的概念,提出了基于图的平稳性度量,并展示了图分区在可视化平稳性中的应用。此外,还模拟了不同平稳性和非平稳性程度的信号,分析了图度量的变化,为时间序列数据分析提供了新视角。
244 0
基于图论的时间序列数据平稳性与连通性分析:利用图形、数学和 Python 揭示时间序列数据中的隐藏模式

推荐镜像

更多
登录插画

登录以查看您的控制台资源

管理云资源
状态一览
快捷访问