Opencv(Python版)-1 图像视频读写

了解opencv基本函数功能
canny

在窗口显示图像

使用函数**cv2.imread()**读取图像,有两个参数,第一个是图像的路径,第二个是以什么方式读取图像,一共有三种图像。

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

img = cv2.imread('sea.jpg')
cv2.imshow('image',img)
cv2.waitKey()
cv2.destroyWindow()

在窗口显示摄像头帧

Opencv的namedWindow(),imshow(),DestroyWindow()函数允许指定窗口名来创建,显示和销毁窗口。
waitKey()函数来获取键盘输入,通过setMouseCallback()函数来获取鼠标输入。以下代码用来打开摄像头,实时显示摄像头帧。

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 to 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()

根据官方文档
要捕获视频,需要创建一个VideoCapture对象。 它的参数可以是设备索引或视频文件的名称。 设备索引只是指定哪个摄像头的数量。 通常会连接一台摄像机(如我的情况)。 所以我只传递0(或-1)。 您可以通过传递1来选择第二个摄像头,依此类推。 之后,您可以逐帧捕获。 但最后,不要忘记发布捕获。
cap.read()返回一个bool(True / False)。 如果正确读取帧,则它将为True。 因此,可以通过检查此返回值来检查视频的结尾。
还可以使用cap.get(propId)方法访问此视频的某些功能,其中propId是0到18之间的数字。每个数字表示视频的属性(如果它适用于该视频),完整的详细信息可以 在这里可以看到:物业标识符。 其中一些值可以使用cap.set(propId,value)进行修改。 价值是您想要的新价值。例如,我可以通过cap.get(3)和cap.get(4)来检查框架宽度和高度。 它默认给我640x480。 但我想将其修改为320x240。 只需使用ret = cap.set(3,320)和ret = cap.set(4,240)。

下面这个代码也是打开摄像头并显示帧,按下esc关闭窗口

import cv2
import numpy as np
import pickle
import matplotlib.pyplot as plt

cap = cv2.VideoCapture(0)

while True:
    ret, frame = cap.read()
    # Our operations on the frame come here
    frame = cv2.GaussianBlur(frame, (3, 3), 0)
    frame = cv2.Canny(frame, 70, 200)
    #frame = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
    # Display the resulting frame
    cv2.imshow('frame', frame)
    if cv2.waitKey(1) & 0xFF == 27:
        break

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

frame = cv2.GaussianBlur(frame, (3, 3), 0),这条代码的意思是对获得的帧加一个高斯模糊,使图像更加平滑。
me
frame = cv2.Canny(frame, 70, 200),这条代码的作用是对图像进行边缘检测。
canny
frame = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY),使图像转变为灰度图像。
gray

从文件播放视频

和从摄像头拍摄相同,只要用视频文件名更改相机索引即可,cv2.waitKey()使用适当的时间, 如果它太小,视频将非常快,如果它太高,视频将会很慢(嗯,这就是你可以用慢动作显示视频)。在正常情况下,25毫秒就可以了。

> import numpy as np
import cv2

cap = cv2.VideoCapture('vtest.avi')

while(cap.isOpened()):
    ret, frame = cap.read()

    gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)

    cv2.imshow('frame',gray)
    if cv2.waitKey(25) & 0xFF == ord('q'):
        break

cap.release()
cv2.destroyAllWindows()

保存视频

创建一个VideoWriter对象。指定输出文件名(例如:output.avi)。FourCC是用于指定视频编解码器的4字节代码。可以在fourcc.org中找到可用代码列表。它取决于平台。然后应该传递每秒帧数(fps)和帧大小。最后一个是isColor标志。如果是True,则编码器需要彩色帧,否则它适用于灰度帧。

import numpy as np
import cv2

cap = cv2.VideoCapture(0)

# Define the codec and create VideoWriter object
fourcc = cv2.VideoWriter_fourcc(*'XVID')
out = cv2.VideoWriter('output.avi',fourcc, 20.0, (640,480))

while(cap.isOpened()):
    ret, frame = cap.read()
    if ret==True:
        #frame = cv2.flip(frame,0)

        # write the flipped frame
        out.write(frame)

        cv2.imshow('frame',frame)
        if cv2.waitKey(1) & 0xFF == ord('q'):
            break
    else:
        break

# Release everything if job is finished
cap.release()
out.release()
cv2.destroyAllWindows()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值