图像的基本操作
修改像素值
import cv2
img = cv2.imread('black.jpg')
for i in range(256):
img[100,i,:]=[255,255,255] #BGR三个通道的值都令为255白色
cv2.imshow('img',img)
cv2.waitKey(0)
读入一张纯黑的图像,更改其中的一行像素为白色。
1 这里可以发现img[i,j]中j才是代表行,这和c语言中的矩阵刚好相反。
2 这里仅仅修改了图片的像素值,并没有保存,所以原图还是没变。
获取图像信息
import cv2
import numpy as np
img = cv2.imread('lena.jpg')
cv2.imshow('lena',img)
cv2.waitKey(500)
print(img.shape) #输出形状:(263, 263, 3)
print(img.dtype) #输出类型:uint8
print(img.size) #输出总大小 263*263*3=207507
#截取一部分
face = img[100:200, 115:188]
cv2.imshow('face', face)
cv2.waitKey(500)
通道分割合并
import cv2
import numpy as np
img = cv2.imread('lena.jpg')
cv2.imshow('lena',img)
cv2.waitKey(500)
b,g,r=cv2.split(img)
cv2.imshow('b',b)
cv2.waitKey(500) #对b通道进行输出
for i in range(263): 将b通道所有值变为0再进行合并
b[i]=0
img=cv2.merge((b,g,r)) #合并三个通道
cv2.imshow('img',img)
cv2.waitKey(500) #对b通道进行输出
b通道: b通道为零进行合并后
split()函数比较耗时,更高效的方式是用numpy中的索引,直接提取B通道:
b = img[:, :, 0]
cv2.imshow('blue', b)
cv2.waitKey(0)