标签:scale 任意 cv2 元组 opencv shape rows 不同 imgarray
效果如图:
代码:
def ManyImgs(scale, imgarray): rows = len(imgarray) # 元组或者列表的长度 cols = len(imgarray[0]) # 如果imgarray是列表,返回列表里第一幅图像的通道数,如果是元组,返回元组里包含的第一个列表的长度 # print("rows=", rows, "cols=", cols) # 判断imgarray[0]的类型是否是list # 是list,表明imgarray是一个元组,需要垂直显示 rowsAvailable = isinstance(imgarray[0], list) # 第一张图片的宽高 width = imgarray[0][0].shape[1] height = imgarray[0][0].shape[0] # print("width=", width, "height=", height) # 如果传入的是一个元组 if rowsAvailable: for x in range(0, rows): for y in range(0, cols): # 遍历元组,如果是第一幅图像,不做变换 if imgarray[x][y].shape[:2] == imgarray[0][0].shape[:2]: imgarray[x][y] = cv2.resize(imgarray[x][y], (0, 0), None, scale, scale) # 将其他矩阵变换为与第一幅图像相同大小,缩放比例为scale else: imgarray[x][y] = cv2.resize(imgarray[x][y], (imgarray[0][0].shape[1], imgarray[0][0].shape[0]), None, scale, scale) # 如果图像是灰度图,将其转换成彩色显示 if len(imgarray[x][y].shape) == 2: imgarray[x][y] = cv2.cvtColor(imgarray[x][y], cv2.COLOR_GRAY2BGR) # 创建一个空白画布,与第一张图片大小相同 imgBlank = np.zeros((height, width, 3), np.uint8) hor = [imgBlank] * rows # 与第一张图片大小相同,与元组包含列表数相同的水平空白图像 for x in range(0, rows): # 将元组里第x个列表水平排列 hor[x] = np.hstack(imgarray[x]) ver = np.vstack(hor) # 将不同列表垂直拼接 # 如果传入的是一个列表 else: # 变换操作,与前面相同 for x in range(0, rows): if imgarray[x].shape[:2] == imgarray[0].shape[:2]: imgarray[x] = cv2.resize(imgarray[x], (0, 0), None, scale, scale) else: imgarray[x] = cv2.resize(imgarray[x], (imgarray[0].shape[1], imgarray[0].shape[0]), None, scale, scale) if len(imgarray[x].shape) == 2: imgarray[x] = cv2.cvtColor(imgarray[x], cv2.COLOR_GRAY2BGR) # 将列表水平排列 hor = np.hstack(imgarray) ver = hor return ver img1=cv2.imread("F:/google/qc.jpg") img2=cv2.cvtColor(img1,cv2.COLOR_BGR2GRAY) imgs=ManyImgs(1,([img1,img2],[img2,img2])) cv2.imshow("1",imgs) cv2.waitKey(0)
标签:scale,任意,cv2,元组,opencv,shape,rows,不同,imgarray 来源: https://www.cnblogs.com/XiaoGao128/p/13938552.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。