python入门(六) opencv的安装,图片操作,绘制文字图形,视频操作

简介: python入门(六) opencv的安装,图片操作,绘制文字图形,视频操作

课程目标

  • 安装 OpenCV
  • OpenCV 读取、缩放、翻转、写入图像
  • OpenCV 在图像上绘制文字、几何图形
  • OpenCV 视频操作

认识openCV

OpenCV(Open Source Computer Vision) 是计算机视觉和机器学习软件库

Intel 1999年 创建,用C++语言编写 (提供了Python、Ruby、MATLAB等接口),OpenCV 支持对图像缩放、旋转、绘制文字图形等基础操作

OpenCV 库包含了很多计算机视觉领域常见算法: 目标检测、目标跟踪等.

如何安装openCV

安装

conda install -c conda-forge opencv

conda install opencv (换源后)或pip install opencv-python

检查是否安装成功:

OpenCV 读取、缩放、翻转、写入图像

进入jupyter-lab,代码如下:

读取图片

缩放图片

翻转图片

写入图片

openCV绘制图形和文字

创建一个纯黑色的底图

画一个矩形

再画一个正方形

再画一个圆形

再画一个实心圆

画一条线

画多边形

在真实的图片上加载图形

在真实的图片上加载文字

字体包位置:

写个文字的工具方法:

# 导入PIL对应包
import cv2
from PIL import Image, ImageDraw, ImageFont
import numpy as np
# 绘制中文
def cv2AddChineseText(img, text, position, textColor=(0, 255, 0), textSize=30):
    img = Image.fromarray(cv2.cvtColor(img, cv2.COLOR_BGR2RGB))
    draw = ImageDraw.Draw(img)
    # 字体的格式
    fontStyle = ImageFont.truetype(
        "./../font/simsun.ttc", textSize, encoding="utf-8")
    # 绘制文本
    draw.text(position, text, textColor, font=fontStyle)
    # 转换回OpenCV格式
    return cv2.cvtColor(np.asarray(img), cv2.COLOR_RGB2BGR)

OpenCV 视频操作

演示在python的窗口中显示图片

# 演示在python的窗口中显示图片
# 导入opencv
import cv2
import numpy as np
# 读取图片
img = cv2.imread('./../img/cat.jpg')
# 显示图片
while True:
    cv2.imshow('Demo',img)
    # 等待10毫秒 ,如果等待至少10ms,并且用户按了ESC键 (ord(''))
    #if cv2.waitKey(10) & 0xFF == 27:
    if cv2.waitKey(10) & 0xFF == ord('q'):
        break
# 关闭所有的窗口
cv2.destroyAllWindows()

OpenCV读取摄像头视频流, 并且显示

"""
OpenCV读取摄像头视频流, 并且显示
"""
# 导入OpenCV
import cv2
import numpy as np
#调用摄像头
cap = cv2.VideoCapture(0)
while True:
    # 返回frame
    rec,frame = cap.read()
    # 镜像
    frame = cv2.flip(frame, 1)
    # 灰度显示
    gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
    # 显示画面
    cv2.imshow('Demo', frame)
    #退出条件: q
    if cv2.waitKey(10) & 0xFF == ord('q'):
        break
cap.release()
cv2.destroyAllWindows()

OpenCV读取视频文件

"""
OpenCV读取视频文件
"""
# 导入opencv的包
import cv2
import numpy as np
# 读取文件
cap = cv2.VideoCapture('./../video/myDemo.mp4',0)
if not cap.isOpened():
    print('文件不存在或者编码错误')
while cap.isOpened():
    # 读取每一帧
    ret, frame = cap.read()    
    if ret:
        # 显示画面
        cv2.imshow('Demo', frame)
        #退出条件
        if cv2.waitKey(10) & 0xFF == ord('q'):
            break
    else:   
        # 画面播放完毕,自动退出
        break  
cap.release()
cv2.destroyAllWindows()

OpenCV读取摄像头视频流, 并且显示和保存为mp4文件

"""
OpenCV读取摄像头视频流, 并且显示
保存为mp4文件
"""
# 导入OpenCV
import cv2
import numpy as np
#调用摄像头
cap = cv2.VideoCapture(0)
#编码
#DIVX,X264
fourcc = cv2.VideoWriter_fourcc(*'X264')
fps = 20
# 获取摄像头实际大小
width = int(cap.get(cv2.CAP_PROP_FRAME_WIDTH))
height = int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT))
writer = cv2.VideoWriter('../video/myDemo.mp4',fourcc,fps,(width,height))
while True:
    # 返回frame
    rec,frame = cap.read()
    # 镜像
    frame = cv2.flip(frame, 1)
    # 灰度显示
    gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
    # 写入画面到文件
    writer.write(frame)
    # 显示画面
    cv2.imshow('Demo', frame)
    #退出条件: q
    if cv2.waitKey(10) & 0xFF == ord('q'):
        break
writer.release()    
cap.release()
cv2.destroyAllWindows()

OpenCV在摄像头视频流上添加文字和图形

"""
OpenCV在摄像头视频流上添加文字和图形
"""
# 导入opencv等包
import cv2
import numpy as np
import time
# 导入自定义模块
import drawUtils
# 读取摄像头
cap = cv2.VideoCapture(0)   
# 当前Unix时间戳
start_time = time.time()
while True:
    # 读取每一帧    
    ret, frame = cap.read()   
    # 对frame进行操作
    frame = cv2.flip(frame, 1)
    # 画一个矩形
    cv2.rectangle(frame, (20,200),(120,300),(255,0,255),10)
    now = time.time()
    fps_text = int(1/( now - start_time))
    start_time = now
    frame_text = "帧率: " + str(fps_text)
    # print(fps_text)
    #显示帧率
    frame = drawUtils.cv2AddChineseText(frame, frame_text, (20,50),(0,255,0),30)
    # 显示画面
    cv2.imshow('Demo', frame)   
    #退出条件 ESC
    if cv2.waitKey(10) & 0xFF == 27:
        break
cap.release()
cv2.destroyAllWindows()

效果如下:

本人太帅,打码了哈哈。


大功告成!!!


相关文章
|
1月前
|
PyTorch Linux 算法框架/工具
pytorch学习一:Anaconda下载、安装、配置环境变量。anaconda创建多版本python环境。安装 pytorch。
这篇文章是关于如何使用Anaconda进行Python环境管理,包括下载、安装、配置环境变量、创建多版本Python环境、安装PyTorch以及使用Jupyter Notebook的详细指南。
249 1
pytorch学习一:Anaconda下载、安装、配置环境变量。anaconda创建多版本python环境。安装 pytorch。
|
1月前
|
XML 数据格式 Python
Python实用记录(五):labelImg安装和使用-----看这篇就够了!
这篇文章介绍了在Windows 10系统中使用Anaconda3安装labelImg工具的方法,包括通过pip安装相关包和从GitHub下载配置,以及一些使用技巧,如修改预定义类别和自动保存功能。
179 3
|
1月前
|
计算机视觉
Opencv学习笔记(八):如何通过cv2读取视频和摄像头来进行人脸检测(jetson nano)
如何使用OpenCV库通过cv2模块读取视频和摄像头进行人脸检测,并提供了相应的代码示例。
81 1
|
1月前
|
计算机视觉 Python
Python实用记录(一):如何将不同类型视频按关键帧提取并保存图片,实现图片裁剪功能
这篇文章介绍了如何使用Python和OpenCV库从不同格式的视频文件中按关键帧提取图片,并展示了图片裁剪的方法。
66 0
|
1月前
|
网络协议 Java Linux
PyAV学习笔记(一):PyAV简介、安装、基础操作、python获取RTSP(海康)的各种时间戳(rtp、dts、pts)
本文介绍了PyAV库,它是FFmpeg的Python绑定,提供了底层库的全部功能和控制。文章详细讲解了PyAV的安装过程,包括在Windows、Linux和ARM平台上的安装步骤,以及安装中可能遇到的错误和解决方法。此外,还解释了时间戳的概念,包括RTP、NTP、PTS和DTS,并提供了Python代码示例,展示如何获取RTSP流中的各种时间戳。最后,文章还提供了一些附录,包括Python通过NTP同步获取时间的方法和使用PyAV访问网络视频流的技巧。
181 4
PyAV学习笔记(一):PyAV简介、安装、基础操作、python获取RTSP(海康)的各种时间戳(rtp、dts、pts)
|
1月前
|
机器学习/深度学习 编解码 Python
python将照片集变成视频
`shigen`是一位坚持更新文章的博客作者,记录成长历程,分享认知见解,留住生活感动。他利用Python库`Pillow`和`MoviePy`开发了一个工具,能够批量处理照片并生成高质量视频。该工具支持多种分辨率、自定义播放时间和照片方向,并能自动调整照片比例以实现居中对齐。通过简单的代码实现了照片视频化的需求,适合强迫症患者使用。**与shigen一起,每天不一样!**个人IP:shigen。
43 9
python将照片集变成视频
|
1月前
|
机器学习/深度学习 Python
【10月更文挑战第5天】「Mac上学Python 6」入门篇6 - 安装与使用Anaconda
本篇将详细介绍如何在Mac系统上安装和配置Anaconda,如何创建虚拟环境,并学习如何使用 `pip` 和 `conda` 管理Python包,直到成功运行第一个Python程序。通过本篇,您将学会如何高效地使用Anaconda创建和管理虚拟环境,并使用Python开发。
64 4
【10月更文挑战第5天】「Mac上学Python 6」入门篇6 - 安装与使用Anaconda
|
1月前
|
IDE 开发工具 iOS开发
【10月更文挑战第3天】「Mac上学Python 3」入门篇3 - 安装Python与开发环境配置
本篇将详细介绍如何在Mac系统上安装Python,并配置Python开发环境。内容涵盖Python的安装、pip包管理工具的配置与国内镜像源替换、安装与配置PyCharm开发工具,以及通过PyCharm编写并运行第一个Python程序。通过本篇的学习,用户将完成Python开发环境的搭建,为后续的Python编程工作打下基础。
176 2
【10月更文挑战第3天】「Mac上学Python 3」入门篇3 - 安装Python与开发环境配置
|
28天前
|
数据安全/隐私保护 流计算 开发者
python知识点100篇系列(18)-解析m3u8文件的下载视频
【10月更文挑战第6天】m3u8是苹果公司推出的一种视频播放标准,采用UTF-8编码,主要用于记录视频的网络地址。HLS(Http Live Streaming)是苹果公司提出的一种基于HTTP的流媒体传输协议,通过m3u8索引文件按序访问ts文件,实现音视频播放。本文介绍了如何通过浏览器找到m3u8文件,解析m3u8文件获取ts文件地址,下载ts文件并解密(如有必要),最后使用ffmpeg合并ts文件为mp4文件。
|
1月前
|
Python
Python 三方库下载安装
Python 三方库下载安装
27 1