环境:win10、Python 3.6.5
opencv 3.4.1.15 安装命令:打开cmd,输入以下命令:
pip install -i https://pypi.douban.com/simple opencv-python==3.4.1.15 opencv-contrib-python==3.4.1.15
1. 读取图片,转换为灰度图,显示、保存。
import cv2 as cv
"""
加载一个灰度图,显示图片,按下’s’键保存后退出,或者 按下 ESC 键退出不保存
"""
src = cv.imread("./picture/IMG_20191225_225522.jpg")
gray = cv.cvtColor(src,cv.COLOR_BGR2GRAY)
cv.namedWindow("input image",cv.WINDOW_AUTOSIZE)
cv.imshow("input image",src)
cv.imshow("gray image",gray)
k = cv.waitKey(0)
if k == 27: # wait for ESC key to exit
cv.destroyAllWindows()
elif k == ord('s'): # wait for 's' key to save and exit
cv.imwrite('./picture/gray.png',gray)
cv.destroyAllWindows()
2. 使用matplotlib显示彩色图片,OpenCV读取图像格式为BGR,matplotlib读取图像格式为RGB,通道需要进行转换。
import cv2 as cv
from matplotlib import pyplot as plt
"""
使用matplotlib显示彩色图片
"""
src = cv.imread("./picture/IMG_20191225_225522.jpg")
src = src[...,::-1] # or src = src[:,:,[2,1,0]] BGR-->RGB
plt.imshow(src,cmap='gray',interpolation='bicubic')
plt.xticks([]),plt.yticks([])
plt.show()
3. 使用摄像头捕获实时图像。
import cv2 as cv
"""
使用摄像头捕获实时图像
"""
cap = cv.VideoCapture(0)
while(True):
ret,frame = cap.read()
# gray = cv.cvtColor(frame,cv.COLOR_BGR2GRAY) #灰度
cv.imshow("frame",frame)
if cv.waitKey(1) & 0xFF == ord('q'):
break
cap.release()
cv.destroyAllWindows()
4. 摄像头视频实时显示并保存。
import cv2 as cv
"""
摄像头视频实时显示并保存
"""
cap = cv.VideoCapture(0)
# 定义编解码器并创建VideoWriter对象
fourcc = cv.VideoWriter_fourcc(*'XVID')
out = cv.VideoWriter('./picture/output.avi',fourcc,20.0,(640,480))
while(cap.isOpened()):
ret,frame = cap.read()
if ret == True:
# 此处读出的图像是反的,需要将图像镜像
frame = cv.flip(frame,1) # 0 垂直翻转,1 水平翻转, -1 水平垂直翻转
out.write(frame) #写入翻转的帧
cv.imshow("frame",frame)
if cv.waitKey(1) & 0XFF == ord('q'):
break
else:
break
# Release everything if job is finished
cap.release()
out.release()
cv.destroyAllWindows()