图像基本操作

一、图片读取

二、图片保存

三、图片展示

四、图片缩放

五、四种常用插值方式的比较

六、视频读取

七、颜色通道提取


opencv,Open Source Computer Vision Library.OpenCV于1999年由Intel建立。OpenCV是一个基于BSD许可(开源)发行的跨平台计算机视觉库,可以运行在Linux、Windows、MacOS操作系统上。它轻量级而且高效——由一系列 C 函数和少量C++类构成,同时提供了Python、Ruby、MATLAB等语言的接口,实现了图像处理和计算机视觉方面的很多通用算法。

一、图片读取

cv2.imread(path, flag)

flag默认为1。另外一个需要注意的是opencv是以bgr三通道打开图像,注意bgr与rgb的相互转换。



import cv2

img = cv2.imread('path', cv2.IMREAD_COLOR)
img = cv2.imread('path', 0)
# flag有三种模式
# cv2.IMREAD_COLOR, flag=1, 加载一副彩色的图像,透明度会被忽略,如jpg图像。默认使用这种模式打开
# cv2.IMREAD_GRAYSCALE, flage=0, 以灰度加载一张图像
# cv2.IMREAD_UNCHANGED, 加载一副彩色图像,同时还会有透明度通道,如png图像



二、图片保存

cv2.imwrite(存储路径, 图像变量, [, 存盘标识])



cv2.imwrite('path', img)
cv2.imwrite('path', img, cv2.IMWRITE_JPEG_QUALITY=95)
# 存盘标识有三种。最常用的就是保存为.jpg和.png两种
# 1.cv2.IMWRITE_JPEG_QUALITY   设置图片格式为jpeg,或jpg,其值0-100,数值越大质量越高,默认95
# 2.cv2.IMWRITE_WEBP_QUALITY      
# 3.cv2.IMWRITE_PNG_COMPRESSION 设置图片格式为png,其值0-9,为压缩等级,默认为3



这就意味着,保存图片的过程中都是有损压缩过的,图像精度会有影响。比如一个严格意义上的二值图像,0或255,但是保存之后就不止只有0和255了。

三、图片展示

cv2.imshow('window_name', img)



# 特别注意的是cv2.nameWindow中的第一个参数要和cv2.imshow中的第一个参数一致。
# 大致可以理解为先打开一个窗口,命名一个名字,然后进行展示图像。
# 第二个参数有两种模式:
# cv2.WINDOW_NORMAL标识窗口大小可调节,或者使用另外一种模式
# cv2.WINDOW_AUTOSIZE根据原图大小进行展示
cv2.namedWindow('window_name', cv2.WINDOW_NORMAL)
cv2.imshow('image', img)
cv2.waitKey(0)
cv2.destoryAllWindows()



四、图片缩放

cv2.resize(src, dsize, interpolation=)

图片的缩放一般使用的方式有两种:第一种就是缩放成固定大小;第二种就是按比例缩放

缩放过程中有五种插值方式:

  1. cv2.INTER_NEAREST 最近邻插值
  2. cv2.INTER_LINEAR 线性插值
  3. cv2.INTER_AREA 基于局部像素的重采样,区域插值
  4. cv2.INTER_CUBIC 基于邻域4x4像素的三次插值
  5. cv2.INTER_LANCZOS4 基于8x8像素邻域的Lanczos插值
cv2.resize(img, (300, 300), interpolation=cv2.INTER_LINEAR) # 默认的使用双线性插值
cv2.resize(img, fx=0.5, fy=0.5)



五、四种常用插值方式的比较

OpenCV的resize函数支持多种插值方式,这里主要比较下面四个常用的插值方式。 参考资料:《OpenCV中resize函数五种插值算法的实现过程》




python opencv查看图像通道数 opencv查看图片大小_opencv 特殊颜色区域


1、最近邻插值

最近邻插值是最简单的插值方法,选取离目标点最近的点作为新的插入点。

变换后:


python opencv查看图像通道数 opencv查看图片大小_opencv 保存图片_02


2、双线性插值

线性插值是以距离为权重的一种插值方式。如果想要深入地理解,可以先回顾一下线性插值。


python opencv查看图像通道数 opencv查看图片大小_opencv shape函数_03


3、区域插值

区域插值共分三种情况,图像放大时类似于双线性插值,图像缩小(x轴、y轴同时缩小)又分两种情况,此情况下可以避免波纹出现。因此对图像进行缩小时,为了避免出现波纹现象,推荐采用区域插值方法。

如果要缩小图像,通常推荐使用INTER_AREA插值效果最好,而要放大图像,通常使用INTER_CUBIC(速度较慢,但效果最好),或者使用INTER_LINEAR(速度较快,效果还可以)

4、三次样条插值

可以在看过双线性插值之后,再来看三次样条插值。


python opencv查看图像通道数 opencv查看图片大小_opencv 特殊颜色区域_04


六、视频读取

  • cv2.VideoCapture可以捕获摄像头,用数字来控制不同的设备,例如0,1
  • 如果是视频文件,直接指定路径即可。
import cv2

vc =cv2.VideoCapture(0)
if vc.isOpened():
    open, 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', gray)
        cv2.imshow('result', frame)
        if cv2.waitKey(10) & 0xFF == 27:
            break
vc.release()
cv2.destroyAllWindows()


七、颜色通道提取与合并

  • cv2.split()
  • cv2.merge()
import cv2

# 颜色通道提取
img = cv2.imread('lena.jpg')
b, g, r = cv2.split(img)
print(b.shape)
print(g.shape)
print(r.shape)

# 颜色通道合并
img = cv2.merge((b, g, r))

# 只保留R
cur_img = img.copy()
cur_img[:, :, 0] = 0
cur_img[:, :, 1] = 0
cv2.imshow('cur_img', cur_img)

cv2.waitKey(0)
cv2.destroyAllWindows()


python opencv查看图像通道数 opencv查看图片大小_opencv中的imwrite如何保存_05