环境配置:Anaconda3+Python3.7.2+OpenCV3.4.1+JetBrains PyCharm 2018.3.4 x64
-
Anaconda3:
- 官网下载:https://www.anaconda.com/
- 清华镜像站(推荐):
使用帮助说明:https://mirrors.tuna.tsinghua.edu.cn/help/anaconda/
下载地址:https://mirrors.tuna.tsinghua.edu.cn/anaconda/archive/Anaconda3-5.3.1-Windows-x86_64.exe
-
Pycharm:http://www.jetbrains.com/pycharm/download/
-
OpenCV:
- 使用anaconda管理包
- conda install opencv
-
代码:图片和视频的加载与保存
# -*- coding: utf-8 -*-
# By:iloveluoluo
# 2019.3.21
import cv2 as cv
import numpy as np
def get_image_info(image):
"""image information"""
print(type(image)) # <class 'numpy.ndarray'> = C++中Mat
print(image.shape) # (高,宽,通道数)
print(image.size) # 总的像素数(高*宽*通道数)
print(image.dtype) # 每个像素点,每个通道占的位数
img_date = np.array(image)
print(img_date) # 输出数组信息
def img_demo():
"""image display"""
img = cv.imread('E:/MyFile/Picture/date/zly.jpg') # 读取图片
get_image_info(img)
gray = cv.cvtColor(img, cv.COLOR_BGR2GRAY) # 转灰度图
# get_image_info(img)
cv.namedWindow("img", cv.WINDOW_AUTOSIZE) # 调用cv.imshow会自动创建
# cv.namedWindow("gray", cv.WINDOW_AUTOSIZE)
while True:
cv.imshow("img", img)
# cv.imshow("gray", gray)
key = cv.waitKey(1)
if key == 27: # Esc退出
break
cv.imwrite('E:/MyFile/Picture/out/image_demo.png', gray) # 保存灰度图片
def video_demo():
"""video display"""
capture = cv.VideoCapture(0) # 默认笔记本摄像头
while True:
ret, frame = capture.read() # 返回值,每一帧图像
frame = cv.flip(frame, 1) # 镜像变换左右,上下1或-1
cv.imshow("video", frame)
key = cv.waitKey(1)
if key == 27: # Esc退出
break
elif key == ord('s'): # 's'键保存截图
cv.imwrite('E:/MyFile/Picture/out/video_demo.png', frame) # 保存灰度图
video_demo()
# cv.destroyWindow("video") # 可以指定销毁窗口
cv.destroyAllWindows()