【Python Opencv】图片与视频的操作

文章目录

  • 前言
  • 一、opencv图片
    • 1.1 读取图像
    • 1.2 显示图像
    • 1.3 写入图像
    • 1.4 示例代码
  • 二、Opencv视频
    • 2.1 从相机捕获视频
      • 获取摄像头
      • 一帧一帧读取
      • 显示图片
      • VideoCapture 中的get和set函数
      • 示例代码
    • 2.2 从文件播放视频
      • 示例代码
    • 2.3 保存视频
      • 示例代码
  • 总结


前言

在计算机视觉和图像处理中,使用OpenCV库可以进行各种强大的图片和视频操作。无论是简单的图像加载和显示,还是复杂的视频处理和分析,OpenCV提供了丰富的工具和函数。本文将介绍如何使用Python和OpenCV进行图片和视频的基本操作,包括读取、显示、保存以及视频的处理等。


一、opencv图片

目标
在这里,您将学习如何阅读图像、如何显示图像以及如何将其保存回来
您将学习以下函数:cv2.imread(), cv2.imshow() , cv2.imwrite()

1.1 读取图像

使用函数 cv.imread() 读取图像。图像应位于工作目录中,或者应提供图像的完整路径。

第一个参数是图片名称
第二个参数是一个标志,它指定了图像的读取方式。

cv.IMREAD_COLOR :加载彩色图像。图像的任何透明度都将被忽略。它是默认标志。
cv.IMREAD_GRAYSCALE:以灰度模式加载图像
cv.IMREAD_UNCHANGED : 加载图像,包括 alpha 通道

注意
除了这三个标志,您可以分别传递整数 1、0 或 -1。

import cv2
import numpy as np

img = cv2.imread("./opencv.jpg",cv2.IMREAD_UNCHANGED)

在这里插入图片描述

警告

即使图像路径错误,它也不会抛出任何错误,但会给您print imgNone

1.2 显示图像

使用函数 cv.imshow()在窗口中显示图像。窗口会自动适应图像大小。

第一个参数是一个窗口名称,它是一个字符串。第二个论点是我们的形象。您可以根据需要创建任意数量的窗口,但使用不同的窗口名称。

cv2.imshow("opencv",img)

cv2.waitKey(0)
cv2.destroyAllWindows()

在这里插入图片描述

cv.waitKey()是一个键盘绑定函数。它的论点是以毫秒为单位的时间。该函数等待任何键盘事件的指定毫秒。如果在这段时间内按任意键,程序将继续。如果传递 0,它将无限期地等待击键。它还可以设置为检测特定的击键,例如,如果按下了 a 键等,我们将在下面讨论。

注意
除了绑定键盘事件外,此函数还处理许多其他 GUI 事件,因此您必须使用它来实际显示图像。

destroyAllWindows就是把全部的窗口都释放内存。

cv.destroyAllWindows() 只是销毁我们创建的所有窗口。如果要销毁任何特定窗口,请使用函数 cv.destroyWindow(),在其中传递确切的窗口名称作为参数。

注意
在特殊情况下,您可以创建一个空窗口,稍后将图像加载到其中。在这种情况下,您可以指定窗口是否可调整大小。它是通过函数 cv.namedWindow() 完成的。默认情况下,该标志为 cv.WINDOW_AUTOSIZE。但是,如果指定要cv.WINDOW_NORMAL的标志,则可以调整窗口大小。当图像尺寸过大以及向窗口添加跟踪栏时,这将很有帮助。

1.3 写入图像

使用函数 cv.imwrite() 保存图像。

第一个参数是文件名,第二个参数是要保存的图像。

cv.imwrite('messigray.png',img)

在这里插入图片描述

这会将图像以 PNG 格式保存在工作目录中。

1.4 示例代码

示例代码的要求为读取一个图像,以灰度图的方式读取,且写入图像到文件夹下

import cv2
import numpy as np

img = cv2.imread("./opencv.jpg",cv2.IMREAD_GRAYSCALE)

cv2.imshow("opencv",img)

cv2.imwrite("./opencv-gray.jpg",img)

cv2.waitKey(0)
cv2.destroyAllWindows()

在这里插入图片描述

二、Opencv视频

2.1 从相机捕获视频

通常,我们必须使用相机捕获实时流。OpenCV 为此提供了一个非常简单的接口。让我们从相机中捕获视频,将其转换为灰度视频并显示。只需一个简单的任务即可开始。

若要捕获视频,需要创建 VideoCapture 对象。其参数可以是设备索引,也可以是视频文件的名称。设备索引只是指定哪个相机的数字。通常会连接一个摄像头(就像我的情况一样)。所以我只是传递 0(或 -1)。您可以通过传递 1 来选择第二个相机,依此类推。之后,您可以逐帧捕获。但最后,不要忘记释放捕获。

获取摄像头

首先,我们先要获取摄像头对象

cap = cv.VideoCapture(0)

在这里插入图片描述

他的参数就是你要获取的摄像头的编号

接下来我们需要判断摄像头是否打开:

if not cap.isOpened():
    print("Cannot open camera")
    exit()

在这里插入图片描述

一帧一帧读取

然后我们就要去一帧一帧读取图片了

# Capture frame-by-frame
ret, frame = cap.read()

在这里插入图片描述

使用read()函数可以读取一帧
返回值一为是否读取成功,返回值二为读取到的东西

接下来我们去判断ret是否有图片:

if not ret:
    print("Can't receive frame (stream end?). Exiting ...")
    break

在这里插入图片描述

显示图片

接下来我们直接显示即可

cv.imshow('frame', frame)

在这里插入图片描述

在最后,不要忘记了释放资源:

# When everything done, release the capture
cap.release()
cv.destroyAllWindows()

在这里插入图片描述

VideoCapture 中的get和set函数

您还可以使用 cap.get(propId) 方法访问此视频的某些功能,其中 propId 是 0 到 18 之间的数字。每个数字表示视频的一个属性(如果它适用于该视频),完整的详细信息可以在这里看到:cv::VideoCapture::get()。其中一些值可以使用 cap.set(propId, value) 进行修改。Value 是所需的新值。

例如,我可以通过 和 检查框架宽度和高度。默认情况下,它给我 640x480。但我想将其修改为 320x240。只需使用和.cap.get(cv.CAP_PROP_FRAME_WIDTH)cap.get(cv.CAP_PROP_FRAME_HEIGHT)ret = cap.set(cv.CAP_PROP_FRAME_WIDTH,320)ret = cap.set(cv.CAP_PROP_FRAME_HEIGHT,240)

注意
如果出现错误,请确保使用任何其他相机应用程序(如 Linux 中的 Cheese)相机工作正常。

示例代码

import numpy as np
import cv2 as cv
cap = cv.VideoCapture(0)
if not cap.isOpened():
    print("Cannot open camera")
    exit()
while True:
    # Capture frame-by-frame
    ret, frame = cap.read()
    # if frame is read correctly ret is True
    if not ret:
        print("Can't receive frame (stream end?). Exiting ...")
        break
    cv.imshow('frame', frame )
    if cv.waitKey(1) == ord('q'):
        break
# When everything done, release the capture
cap.release()
cv.destroyAllWindows()

在这里插入图片描述

2.2 从文件播放视频

它与从相机捕获相同,只需使用视频文件名更改相机索引即可。此外,在显示框架时,请为.如果太少,视频会非常快,如果太高,视频会很慢(嗯,这就是你如何以慢动作显示视频)。在正常情况下,25 毫秒是可以的。cv2.waitKey()

示例代码

import numpy as np
import cv2 as cv
cap = cv.VideoCapture('vtest.avi')
while cap.isOpened():
    ret, frame = cap.read()
    # if frame is read correctly ret is True
    if not ret:
        print("Can't receive frame (stream end?). Exiting ...")
        break
    gray = cv.cvtColor(frame, cv.COLOR_BGR2GRAY)
    cv.imshow('frame', gray)
    if cv.waitKey(1) == ord('q'):
        break
cap.release()
cv.destroyAllWindows()

在这里插入图片描述

直接在读取摄像头的这个VideoCapture对象里面写路径即可。

注意
确保安装了正确版本的 ffmpeg 或 gstreamer。有时,使用Video Capture是一件令人头疼的事情,主要是由于ffmpeg / gstreamer的错误安装。

2.3 保存视频

因此,我们捕获视频,逐帧处理,然后保存该视频。对于图像,它非常简单,只需使用 .这里需要更多的工作。cv.imwrite()

这一次,我们创建一个 VideoWriter 对象。我们应该指定输出文件名(例如:output.avi)。然后我们应该指定 FourCC 代码(详见下一段)。然后应传递每秒帧数 (fps) 和帧大小。最后一个是isColor标志。如果是,编码器需要彩色帧,否则它适用于灰度帧。True

FourCC 是用于指定视频编解码器的 4 字节代码。可用代码列表可在 fourcc.org 中找到。它依赖于平台。遵循编解码器对我来说效果很好。

在 Fedora 中:DIVX、XVID、MJPG、X264、WMV1、WMV2。(XVID 更可取。MJPG 产生高尺寸视频。X264 提供非常小尺寸的视频)
在 Windows 中:DIVX(更多待测试和添加)
在OSX中:MJPG(.mp4),DIVX(.avi),X264(.mkv)。
对于MJPG,FourCC代码以’cv.VideoWriter_fourcc(‘M’,‘J’,‘P’,‘G’)cv.VideoWriter_fourcc(*‘MJPG’)'的形式传递。or

在从相机捕获的代码下方,在垂直方向上翻转每一帧并保存。

示例代码

import numpy as np
import cv2 as cv
cap = cv.VideoCapture(0)
# Define the codec and create VideoWriter object
fourcc = cv.VideoWriter_fourcc(*'XVID')
out = cv.VideoWriter('output.avi', fourcc, 20.0, (640,  480))
while cap.isOpened():
    ret, frame = cap.read()
    if not ret:
        print("Can't receive frame (stream end?). Exiting ...")
        break
    frame = cv.flip(frame, 0)
    # write the flipped frame
    out.write(frame)
    cv.imshow('frame', frame)
    if cv.waitKey(1) == ord('q'):
        break
# Release everything if job is finished
cap.release()
out.release()
cv.destroyAllWindows()

在这里插入图片描述


总结

通过使用OpenCV,我们可以轻松进行图片和视频的各种操作。从基本的读取和显示到保存和处理视频,OpenCV提供了简单而强大的接口。图片和视频的处理是计算机视觉领域中的基础,而OpenCV为开发者提供了一个灵活而高效的工具集,使得这些任务变得更加容易实现。通过结合Python的简洁性和OpenCV的强大功能,我们可以在图像和视频处理的领域中取得令人瞩目的成果。希望这篇文章能够为你提供一个良好的入门,让你更好地理解和应用OpenCV。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/138487.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

蓝桥杯 选择排序

选择排序的思想 选择排序的思想和冒泡排序类似,是每次找出最大的然后直接放到右边对应位置,然后将最 右边这个确定下来(而不是一个一个地交换过去)。 再来确定第二大的,再确定第三大的… 对于数组a[],具体…

50个值得关注的生成式AI初创企业【2023】

在线工具推荐: Three.js AI纹理开发包 - YOLO合成数据生成器 - GLTF/GLB在线编辑 - 3D模型格式在线转换 - 可编程3D场景编辑器 生成式AI初创公司已成为科技界最新、最强大的参与者,它们利用自然语言处理、机器学习和其他形式的人工智能为各种业务用例生成…

总结MYSQL中VHARCHAR和TEXT

前几天在设计表结构时,针对表中的一个字段使用text还是使用varchar是受到了开发同学的挑战。本篇文章对text和varchar的区别做个总结。 VHARCHAR和TEXT对比 char(n)varchar(n)中括号中n代表字符的个数,并不代表字节个数,所以当使用了中文的…

实战 | 基于卷积神经网络的蘑菇识别微信小程序

一个不知名大学生,江湖人称菜狗 original author: Jacky Li Email : 3435673055qq.com Time of completion:2023.11.13 Last edited: 2023.11.13 导读:其实没啥难的,主要是随手搞了就发出来把,太久没有水过帖子了&…

LCA

定义 最近公共祖先简称 LCA(Lowest Common Ancestor)。两个节点的最近公共祖先,就是这两个点的公共祖先里面,离根最远的那个。 性质 如果 不为 的祖先并且 不为 的祖先,那么 分别处于 的两棵不同子树中&#…

Python高级语法---Python内存管理机制

文章目录 1. 内存管理基础引用计数2. 垃圾回收机制垃圾回收3. 使用weakref处理循环引用weakref模块总结Python是一种高级编程语言,其内存管理机制高效且用户友好。这篇文章将详细介绍Python的内存管理基础、垃圾回收机制,以及如何使用weakref模块处理循环引用。我们将通过简单…

同为科技(TOWE)主副控智能自动断电桌面PDU插排

在这个快节奏的现代社会,我们越来越需要智能化的产品来帮助我们提高生活质量和工作效率,同时,为各种家用电器及电子设备充电成为不少消费者新的痛点。桌面插排如何高效、安全地管理这些设备,成为了一个亟待解决的问题。同为科技&a…

CopyOnWriteArrayList内存占用过多

目录 一、CopyOnWriteArrayList二、CopyOnWriteArrayList的适用场景三、CopyOnWriteArrayList内存占用过多的解决方法四、CopyOnWriteArrayList.add()源码分析 大家好,我是哪吒。 一、CopyOnWriteArrayList CopyOnWriteArrayList是Java中的一个线程安全的ArrayLis…

负债1320万美元的【思宏集团/Neo-Concep】申请900万美元纳斯达克IPO上市

来源:猛兽财经 作者:猛兽财经 猛兽财经获悉,总部位于香港的思宏集团Neo-Concept International Group Holdings Limited(简称:思宏集团)近期已向美国证券交易委员会(SEC)提交招股书&#xff0c…

基于SpringBoot+Redis的前后端分离外卖项目-苍穹外卖(四)

编辑员工和分类模块功能开发 1. 编辑员工1.1 需求分析与设计1.1.1 产品原型1.1.2 接口设计 1.2 代码开发1.2.1 回显员工信息功能1.2.2 修改员工信息功能 1.3 功能测试 2. 分类模块功能开发2.1 需求分析与设计2.1.1 产品原型2.1.2 接口设计2.1.3 表设计 2.2 代码实现2.2.1 Mappe…

ip数据包

数据报文格式 首部 版本(Version) 版本字段占4bit,通信双方使用的版本必须一致。对于IPv4,字段的值是4。 首部长度(Internet Header Length, IHL) 占4bit,首部长度说明首部有多少…

Clickhouse学习笔记(13)—— Materialize MySQL引擎

该引擎用于监听 binlog 事件,类似于canal、Maxwell等组件 ClickHouse 20.8.2.3 版本新增加了 MaterializeMySQL 的 database 引擎,该 database 能映射到 MySQL中的某个database ,并自动在ClickHouse中创建对应ReplacingMergeTree。 ClickHous…

MPLS VPN详解

了解MPLS VPN之前,要先了解一下MPLS。 了解MPLS之前,先回顾一下基于MAC地址的交换和基于IP地址的路由转发。 (上篇主要是介绍基于mac地址的交换、基于IP地址的路由转发、MPLS详解) (下篇主要是MPLS VPN的网络结构、…

前端基础------margin上下传递

1,出现的原因及解决方法 ◼ margin-top传递 如果块级元素的顶部线和块级父元素的顶部线重叠,那么这个块级元素的margin-top值会传递给父元素 ◼ margin-bottom传递 如果块级元素的底部线和块级父元素的底部线重叠,并且父元素的高度是…

【Proteus仿真】【51单片机】停车场车位管理系统

文章目录 一、功能简介二、软件设计三、实验现象联系作者 一、功能简介 本项目使用Proteus8仿真51单片机控制器,使用按键、LED、蜂鸣器、LCD1602、红外传感器、74HC595模块等。 主要功能: 系统运行后,LCD1602显示进入、驶出、剩余车位数&am…

1000道精心打磨的计算机考研题,408小伙伴不可错过

提示:408考研人看过来,超精选计算机考研1000题! 文章目录 前言1. 为什么是1000题?2. 有什么优势?【练学结合,助力强化】【难度适中,但不刁钻】【题目新颖,独具匠心】【考题预测&…

学生五科成绩统计

随机生成10名学生姓名(包括自己)和五科成绩,将数据存入*.csv,读取保存的*.csv文本数据计算每个学生总分和平均分,并存入*.csv文本;打印总分排名前三学生信息;查找10学生各科最高最低分、中位分、平均分。 (笔记模板由p…

Python参数传递,从入门到精通

Python是一种非常灵活的编程语言,以多种方式定义和调用函数。其中一个关键方面是参数传递的灵活性。在Python中,可以通过位置、关键字、默认值和可变长度参数等多种方式来传递参数。 1. 位置参数 位置参数是最常见的参数传递方式。当调用一个函数时&am…

curl使用

文章目录 前言一、curl use case二、下载操作我使用第一种方式:不验证证书,果然下载下来了。而且是下载到当前的工作文件夹。C:\Users\xxx\test.zip如果自己想指定文件地址 前言 使用 curl 工具 一、curl use case Simple Usage Get the main page fro…

ts学习02-数据类型

新建index.html <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</title> </h…