OpenCV学习第二课——对感兴趣区域进行分割(ROI)


1、图像ROI

import cv2 import numpy as np # 读入图片 # a = cv2.imread("E:\\image\\lenacolor.png") # cv2.imshow("original",a) # cv2.waitKey() # cv2.destroyAllWindows()

# 将一个图像的ROI(感兴趣区域)移到另一个图片中去
a = cv2.imread("E:\\image\\lenacolor.png")  # 图像A
 c = cv2.imread("E:\\image\\p1.jpg")  # 图像C
print(a.shape)  # (512, 512, 3) 整个图像是 512*512 ,从而大致判断你想要的区域位置
b = np.ones((101, 101, 3))  # 创建 一个ROI区域
 b = a[220:400, 250:360]  # 根据整个图像是由 512*512 大小 裁剪出来了ROI(脸部) # a[0:180, 0:110] = b

# c[0:180, 0:110] = b # 讲裁剪出来的脸部 放在图像C的0-180行,0-110列的位置
c[0:180, 0:110] = b # cv2.imshow("original", a)
cv2.imshow("original1", c) # 显示C # cv2.imshow("face", b)
cv2.waitKey() cv2.destroyAllWindows()

2、通道的拆分与合并

import cv2 import numpy as np # 通过分离BGR,合并成原来的图片 # a = cv2.imread("E:\\image\\lenacolor.png") # # b, g, r = cv2.split(a) # 讲图片拆分,所有彩色图片都是BGR合成的 # # cv2.imshow("original", a) # # cv2.imshow("B", b) # cv2.imshow("G", g) # cv2.imshow("R", r) # # m = cv2.merge([b, g, r]) # merge 合并通道 # # cv2.imshow("merge", m) # 显示通道 # cv2.waitKey() # # cv2.destroyAllWindows()


# 通过逐个分离BGR,合成只含B或G或R的图片
a = cv2.imread("E:\\image\\lenacolor.png") row, cols, chn = a.shape  # 获得图像a的行列通道数 # 提取b,G,R为0
b = cv2.split(a)[0] # split 提取特定的通道
g = np.zeros((row, cols), a.dtype) r = np.zeros((row, cols), a.dtype) cv2.imshow("original", a) m = cv2.merge([b, g, r])  # merge 合并通道,行程BGR图像
 cv2.imshow("merge", m)  # 显示通道
cv2.waitKey() cv2.destroyAllWindows()

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM