读取图片
- 引入包。注意opencv读取的格式是BGR,而matplotlib读取的是RGB格式。
import cv2 #opencv读取的格式是BGR
import matplotlib.pyplot as plt
import numpy as np
- 读取测试。注意opencv(cv)读取的格式是BGR,而matplotlib(plt)读取的是RGB格式。使用matplotlib时要进行格式变换
cv读取图片
img=cv2.imread('output.jpg')
cv2.imshow('image',img)
cv2.waitKey(0)
cv2.destroyAllWindows()
plt读取图片
img=cv2.imread('output.jpg')
#BGR转RGB
img_rgb2 = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)
plt.figure("Image") # 图像窗口名称
plt.imshow(img_rgb2 )
plt.axis('on') # 关掉坐标轴为 off
plt.title('image') # 图像题目
plt.show()
关于cv2.imread()函数
# 参数:
# filepath:读入imge的完整路径
# flags:标志位,{cv2.IMREAD_COLOR,cv2.IMREAD_GRAYSCALE,cv2.IMREAD_UNCHANGED}
# cv2.IMREAD_COLOR:默认参数,读入一副彩色图片,忽略alpha通道,可用1作为实参替代
# cv2.IMREAD_GRAYSCALE:读入灰度图片,可用0作为实参替代
# cv2.IMREAD_UNCHANGED:顾名思义,读入完整图片,包括alpha通道,可用-1作为实参替代
# PS:alpha通道,又称A通道,是一个8位的灰度通道,该通道用256级灰度来记录图像中的透明度复信息,定义# 透明、不透明和半透明区域,其中黑表示全透明,白表示不透明,灰表示半透明
cv2.imread(filename, flags)
保存图片
cv2.imwrite('mycat.png',img)
- 读取视频
- 打开视频:
- cv2.VideoCapture可以捕获摄像头,用数字来控制不同的设备,例如0,1。
- 如果是视频文件,直接指定好路径即可。
# 打开视频
vc = cv2.VideoCapture('test.mp4')
# 检查是否打开正确
if vc.isOpened():
oepn, frame = vc.read()
else:
open = False
while open:
ret, frame = vc.read()
if frame is None:
break
if ret == True:
# 转化为灰度图
# gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
cv2.imshow('result', frame)
# waitKey()图像等待时间,可以控制视频快慢,0xFF == 27指定退出键
if cv2.waitKey(100) & 0xFF == 27:
break
vc.release()
cv2.destroyAllWindows()