b,g,r = cv2.split(img[, mv]) #图像拆分为 BGR 通道。
img
:图像数据,nparray 多维数组mv
:指定的分拆通道(可选)b,g,r
:分割成三个单通道图像,分别代表蓝色、绿色和红色通道,并将它们分别赋值给b、g和rimport cv2
imgFile = "img/lena.jpg"
img1 = cv2.imread(imgFile, flags=1) # flags=1 读取彩色图像(BGR)
# 通道拆分
b,g,r=cv2.split(img1)
# 显示图像
cv2.imshow("b", b)
cv2.imshow("g", g)
cv2.imshow("r", r)
cv2.waitKey(0)
cv2.destroyAllWindows()
import cv2
imgFile = "img/lena.jpg"
img1 = cv2.imread(imgFile, flags=1) # flags=1 读取彩色图像(BGR)
# 获取 B 通道
bImg = img1.copy() # 获取 BGR
bImg[:, :, 1] = 0 # G=0
bImg[:, :, 2] = 0 # R=0
# 获取 G 通道
gImg = img1.copy() # 获取 BGR
gImg[:, :, 0] = 0 # B=0
gImg[:, :, 2] = 0 # R=0
# 获取 R 通道
rImg = img1.copy() # 获取 BGR
rImg[:, :, 0] = 0 # B=0
rImg[:, :, 1] = 0 # G=0
# 显示图像
cv2.imshow("b", bImg)
cv2.imshow("g", gImg)
cv2.imshow("r", rImg)
cv2.waitKey(0)
cv2.destroyAllWindows() # 释放所有窗口
cv2.merge(mv[, dst]) #BGR 通道合并
mv
:要合并的单通道dst
:通道合并的图像,nparray 多维数组import cv2
imgFile = "img/lena.jpg"
img1 = cv2.imread(imgFile, flags=1) # flags=1 读取彩色图像(BGR)
# 通道拆分
b, g, r = cv2.split(img1)
# 通道合并
rgb = cv2.merge([r, g, b])
gbr = cv2.merge([g, b, r])
brg = cv2.merge([b, r, g])
# 显示图像
cv2.imshow("rgb", rgb)
cv2.imshow("gbr", gbr)
cv2.imshow("brg", brg)
cv2.waitKey(0)
cv2.destroyAllWindows() # 释放所有窗口