文章目录
图像通道拆分是将BGR拆分为三个独立的单通道。
通道合并是将独立的单通道合并为BGR图像。
边界填充是是对图像的四周以不同的方式进行扩充。
代码
import cv2
import numpy as np
from matplotlib import pyplot as plt
src = cv2.imread(r'F:\OPENCV\Opencv\lenna.jpg', cv2.IMREAD_COLOR)
if src is None:
print('image is empty')
# cv2.split(),比较费时
B, G, R = cv2.split(src)
# cv2.merge()
img = cv2.merge([R, G, B])
plt.rcParams['font.sans-serif'] = ['SimHei']
titles1 = ['img(bgr)', 'B通道', 'G通道', 'R通道', 'img(rbg)']
images1 = [src, B, G, R, img]
plt.figure(1, figsize=(3, 2))
for j in range(len(images1)):
plt.subplot(2, 3, j + 1)
plt.imshow(images1[j], 'gray')
plt.title(titles1[j])
plt.xticks([])
plt.yticks([])
# 边界填充
# cv2.copyMakeBorder(src, top, bottom, left, right, borderType, value)
# src:原始图像; top, bottom, left, right分别为边界像素数目;
# borderType: 添加的边界类型
# cv2.BORDER_CONSTANT:添加有颜色的边界,当使用这种方式时,还需要设定颜色值value(默认为黑色)
# cv2.BORDER_DEFAULT 和cv2.BORDER_REFLECT_101:边界元素的镜像,cb|abc|ba
# cv2.BORDER_REFLECT :边界元素的镜像,cba|abc|cba
# cv2.BORDER_REPLICATE:重复首尾的元素,aaa|abc|ccc
# cv2.BORDER_WRAP: bc|abc|ab
dst = cv2.copyMakeBorder(src, 20, 30, 40, 50, cv2.BORDER_CONSTANT, value=(255, 255, 255))
dst1 = cv2.copyMakeBorder(src, 20, 30, 40, 50, cv2.BORDER_DEFAULT)
dst2 = cv2.copyMakeBorder(src, 20, 30, 40, 50, cv2.BORDER_REFLECT_101)
dst3 = cv2.copyMakeBorder(src, 20, 30, 40, 50, cv2.BORDER_REFLECT101)
dst4 = cv2.copyMakeBorder(src, 20, 30, 40, 50, cv2.BORDER_REFLECT)
dst5 = cv2.copyMakeBorder(src, 20, 30, 40, 50, cv2.BORDER_REPLICATE)
dst6 = cv2.copyMakeBorder(src, 20, 30, 40, 50, cv2.BORDER_WRAP)
titles = ['src', 'BORDER_CONSTANT', 'BORDER_DEFAULT', 'BORDER_REFLECT_101',
'BORDER_REFLECT101', 'BORDER_REFLECT', 'BORDER_REPLICATE', 'BORDER_WRAP']
images = [src, dst, dst1, dst2, dst3, dst4, dst5, dst6]
plt.figure(2, figsize=(8, 6))
for i in range(len(images)):
plt.subplot(3, 3, i + 1)
plt.imshow(images[i][:, :, ::-1], 'gray')
plt.title(titles[i])
plt.xticks([])
plt.yticks([])
plt.show()
结果显示
figure1
figure2