本文已收录于Opencv系列专栏: 深入浅出OpenCV ,专栏旨在详解Python版本的Opencv,为计算机视觉的开发与研究打下坚实基础。免费订阅,持续更新。
文章目录- 图像属性
- 1.图像格式
- 2.图像尺寸
- 图像尺寸
- 像素
- 读入图像cv2.imread()
- 显示图像cv2.imshow()
- 也可matplotlib导入图像
- 键盘绑定cv2.waitKey(0)
- 删除窗口cv2.destrovAllWindows()
- 保存图像cv2.imwrite()
- 3.图像分辨率
- 灰度转化
- RGB与 BGR 转化
- 1.图像格式
- 2.图像尺寸
- 图像尺寸
- 像素
- 读入图像cv2.imread()
- 显示图像cv2.imshow()
- 也可matplotlib导入图像
- 键盘绑定cv2.waitKey(0)
- 删除窗口cv2.destrovAllWindows()
- 保存图像cv2.imwrite()
- 3.图像分辨率
- 灰度转化
- RGB与 BGR 转化
图像属性
1.图像格式
图像压缩比: 通过编码器压缩后的图象数字大小和原图象数字大小的压缩比。
- BMP 格式 Windows系统下的标准位图格式,未经过压缩,一般图像文件会比较大。在很多软件中被广泛应用。
- JPEG 格式 也是应用最广泛的图片格式之一,它采用一种特殊的有损压缩算法,达到较大的压缩比可达到 2:1 甚至 40:1,互联网上最广泛使用的格式
- GIF 格式 不仅可以是一张静止的图片,也可以是动画,并且支持透明背景图像,适用于多种操作系统, 体型很小,网上很多小动画都是 GIF 格式。但是其色域不太广只支持 256 种颜色。
- PNG 格式 与JPG 格式类似,压缩比高于 GIF (因此png损失较小,质量更好),支持图像透明支持 Alpha 通道调节图像的透明度。
- TIFF 格式 它的特点是图像格式复杂、存贮信息多。在 Mac 中广泛使用, 非常有利于原稿的复制。很多地方将 TIFF 格式用于印刷。
2.图像尺寸
图像尺寸
- 图像尺寸的长度与宽度是以像素为单位的。
像素
- 像素是数码影像最基本的单位,每个像素就是一个小点,而不同颜色的点聚集起来就变成一幅照片。
- 灰度像素点数值范围在 0 到 255 之间, 0 表示黑、255 表示白,其它值表示处于黑白之间;
- 黑白照片只需一个通道表示即可。
- 彩色图用红、绿、蓝三通道的二维矩阵来表示。每个数值也是在 0 到 255 之间, 0 表示相应的基色,而 255 则代表相应的基色在该像素中取得最大值。
读入图像cv2.imread()
代码语言:javascript复制cv2.imread()
参数说明:
第一参数为待读路径;
第二个参数为读取方式,常见读取方式有三种
代码语言:javascript复制#导入opencv的python版本依赖库cv2
import cv2
#使用opencv中imread函数读取图片,
#0代表灰度图形式打开,1代表彩色形式打开
img = cv2.imread('split.jpg',1)
print(img.shape)
#print(img) 打印图像的数组
显示图像cv2.imshow()
代码语言:javascript复制cv2.imshow()
参数说明:
参数1 :窗口的名字
参数2 :图像数据名/变量名
代码语言:javascript复制#导入opencv依赖库
import cv2
#读取图像,读取方式为彩色读取
img = cv2.imread('split.jpg',1)
#
cv2.imshow('photo',img)
k = cv2.waitKey(0)
if k == 27: # 输入ESC键退出
cv2.destroyAllWindows()
elif k == ord('s'): # 输入S键保存图片并退出
cv2.imwrite('split_.jpg',img)
cv2.destroyAllWindows()
也可matplotlib导入图像
代码语言:javascript复制#加载第三方包
import cv2
from matplotlib import pyplot as plt
#使用Matplotlib导入图像
img = cv2.imread('test_image.png',0)
plt.imshow(img, cmap = 'gray', interpolation = 'bicubic')
#隐藏X、Y轴上的刻度
#plt.xticks([]), plt.yticks([])
plt.show()
键盘绑定cv2.waitKey(0)
代码语言:javascript复制#cv2.waitKey()是一个键盘绑定函数
#若为数字则是单位毫秒,若为0代表等待键盘输入。
cv2.waitKey(0)
删除窗口cv2.destrovAllWindows()
代码语言:javascript复制# cv2.destroyAllWindows() 删除窗口
# 默认值为所有窗口,参数一为待删除窗口名。
cv2.destrovAllWindows()
保存图像cv2.imwrite()
代码语言:javascript复制cv2.imwrite('split_.jpg',img)
参数说明:
参数1 :图像名(包括格式)
参数2 :待写入的图像数据变量名。
3.图像分辨率
- 分辨率: 单位长度中所表达或截取的像素数目。每英寸图像内的像素点数,单位是像素每英寸 (PPI) 。图像分辨率越高,像素的点密度越高,图像越清晰。
- 通道数:
图像的位深度,是指描述图像中每个pixel 数值所占的二进制位数。 位深度 越大则图像能表示的颜色数就越多,色彩越丰富逼真。
- 8 位:单通道图像,也就是灰度图,灰度值范围2**8=256
- 24 位:三通道 3*8=24
- 32 位:三通道加透明度 Alpha 通道
灰度转化
- 目的 将三通道图像(彩色图)转化为单通道图像(灰度图)。
- 公式 3---->1: GRAY = B * 0.114 G * 0.587 R * 0.299 1---->3: R = G = B = GRAY; A = 0
- 函数: cv2.cvtColor(img,flag)
- 参数说明
参数1 :待转化图像
参数2 :flag 就是转换模式
- cv2.COLOR_BGR2GRAY :彩色转灰度
- cv2.COLOR_GRAY2BGR:单通道转三通道
#导入opencv
import cv2
#读入原始图像,使用cv2.IMREAD_UNCHANGED
img = cv2.imread("girl.jpg",cv2.IMREAD_UNCHANGED)
#查看打印图像的shape
shape = img.shape
print(shape)
#判断通道数是否为3通道或4通道
if shape[2] == 3 or shape[2] == 4 :
#将彩色图转化为单通道图
img_gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
cv2.imshow("gray_image",img_gray)
cv2.imshow("image", img)
cv2.waitKey(1000) # 等待1000毫秒也就是1秒
cv2.destroyAllWindows()
RGB与 BGR 转化
Opencv读取图像是以BGR读取的,但是许多包是RGB读取,因此有些情况下需要转化。
转化的方法
opencv自带的方法转
代码语言:javascript复制cv2.cvtColor(img, cv2.COLOR_BGR2RGB)
numpy转
代码语言:javascript复制img[:,:,::-1] #列左右翻转
示例:
代码语言:javascript复制import cv2
import matplotlib.pyplot as plt
img = cv2.imread("test2.png", cv2.IMREAD_COLOR)
cv2.imshow("Opencv_win", img)
# 用opencv自带的方法转
img_cv_method = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)
# 用numpy转,img[:,:,::-1]列左右翻转
img_numpy_method = img[:,:,::-1] # 本来是BGR 现在逆序,变成RGB
# 用matplot画图
plt.subplot(1,3,1)# 划分一个1行3列的空间
plt.imshow(img_cv_method)
plt.subplot(1,3,2)
plt.imshow(img_numpy_method)
plt.subplot(1,3,3)
plt.imshow(img)
plt.savefig("./plt.png")
plt.show()
#保存图片
cv2.imwrite("opencv.png", img)
cv2.waitKey(0)
cv2.destroyAllWindows()