【问题标题】:How to join two alpha images horizontally and vertically?如何水平和垂直连接两个 alpha 图像?
【发布时间】:2021-06-13 05:19:54
【问题描述】:

我使用 alpha 蒙版创建了直角三角形图像。我想垂直和水平地加入它们。 面具:An alpha mask for right angle triangles

Another alpha mask for right angle triangles

切片图像是: Right Angle Triangles using the first alpha mask

Right Angle Triangles using the second alpha mask

我想通过以下方式合并两个直角三角形:

Desired Output

但是,我的输出不正确: Incorrect output

我想要一些有关如何解决此问题的指导,以便获得所需的输出。

连接三角形的代码: 我使用了以下示例:Masking two images and merge into one image

def mirror_triangles_one():
  x=first_array[0] #The first array contains right angle triangles sliced using alpha mask one
  y=second_array[2] #The second array contains right angle triangles sliced using alpha mask two
  x_im=x
  x_im.paste(y, (-4, 0), y)
  x_im.save('mirror_five.png')
  return x_im

原图-Original Image

【问题讨论】:

  • 请将所需的相应两张图片作为单独图片发布。用白色遮住每个以填充一个矩形。然后简单地使用 np.hstack 水平追加。
  • 用白色来填充矩形是什么意思。我将图像分割成正方形,然后应用蒙版得到直角三角形图像。
  • 我的意思是确保带有三角形图像的矩形的另一半是白色或任何你想要的颜色。我没有展示您如何使用蒙版从输入图像变为三角形图像。
  • 我使用了 put alpha 函数,因此当蒙版应用于图像时,它会显示三角形。
  • 我建议裁剪图像,创建一个白色图像,然后执行 alpha 函数,使三角形的另一侧为白色。然后简单地堆叠两个图像。

标签: python opencv image-processing python-imaging-library masking


【解决方案1】:

下面是我在 Python/OpenCV/Numpy 中的做法。但我不得不裁剪你的图像,所以结果不会准确。假设您已将三角形图像填充为白色矩形,则一个简单的 hstack 是两个图像。请注意,它们必须具有相同的高度。

左:

对:

import cv2
import numpy as np

# read right image
right = cv2.imread('right.png')
rhh, rww = right.shape[:2]

# read left image
left = cv2.imread('left.png')
lhh, lww = left.shape[:2]

# compute min height and crop images to same height
minh = min(rhh,lhh)
right = right[0:minh, 0:rww]
left = left[0:minh, 0:lww]

# stack horizontally
result = np.hstack([left,right])

# save result
cv2.imwrite('left_right_result.jpg', result)

# display result
cv2.imshow('result', result)
cv2.waitKey(0)
cv2.destroyAllWindows()

结果:

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2017-03-06
    • 1970-01-01
    • 2013-05-18
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-04-19
    相关资源
    最近更新 更多