python openCv(五)多张图像堆叠在一起

将多张图片堆叠在一起从而进行显示

  • 直接在一个画布上显示所有照片
  • 采用np.stack的方式 hstack vstack 方式进行堆叠从而进行显示

import cv2
from matplotlib  import pyplot as plt
import numpy as np 

img = cv2.imread("dog.png")
data1 = img.copy()

# 使用堆栈的方法 图像的大小必须一致
# 避免信息出错

data = cv2.resize(img,(200,200))

data1 = cv2.bitwise_not(data)
data2 = cv2.GaussianBlur(data, (0, 0), 10)
data3 = cv2.flip(data,1)

# 方法一:采用画布的方式进行显示
h,w,_ = data.shape
four_view = np.zeros((h * 2 + 10, w * 2 + 10, 3), np.uint8)
four_view[:, :] = 255  # 给所有通道的像素值赋值255
img_list = [data,data1,data2,data3]
for i in range(len(img_list)):
    row = i // 2
    col = i % 2
    # print(row, col)
    # 将小图像复制到大画布上。
    np.copyto(four_view[(h + 10) * row:h * (row + 1) + 10 * row, (w + 10) * col:w * (col + 1) + 10 * col],
                img_list[i])
cv2.imshow('result', four_view)
cv2.waitKey(0)

# 方法2:使用numpy的水平堆叠和竖直堆叠完成所有图像的堆叠,最后一起显示
vs1 = np.hstack((data, data1))  # 水平堆叠
vs2 = np.hstack((data2, data3))  # 水平堆叠
result = np.vstack((vs1, vs2))  # 竖直堆叠

cv2.imshow('anwsers', result)
cv2.waitKey(0)

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值