opencv图像处理①

读取图片 

  • 引入包。注意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()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值