opencv - 在 OpenCV 图像拼接中混合伪影

标签 opencv alpha blending image-stitching opencv-stitching

我正在使用 OpenCV 来混合一组预变形图像。作为输入,我有一些 4 channel 图像(*.png 或 *.tif),我可以从中提取一个 bgr 图像和一个带有与图像(白色)和背景(黑色)相关的区域的 alpha 蒙版。 image 和 mask 都是 Blender 模块的输入 cv::detail::Blender::blend .

当我使用羽毛(alpha)混合时,结果还可以,但是,我想避免重影效果。当我使用多波段时,图像边缘会出现一些伪影:

enter image description here

该问题与提出的 here 类似。 ,并解决了here .问题是,如果解决方案是创建一个二进制掩码(我已经从 alpha channel 中提取),它对我不起作用。如果我在两个图像之间的重叠处添加填充,它会从背景中获取像素,并且会使结果更加困惑。

我想这可能与 pyrUp 函数有关。和 pyrDown ,因为创建高斯和拉普拉斯金字塔的模糊可能应用于整个图像,而不仅仅是正 alpha 区域。无论如何,我不知道如何使用这些功能解决问题,也找不到另一个有效的解决方案。

当我使用另一种多分辨率混合实现时,它可以完美运行,但是,我对集成 OpenCV 的多波段实现非常感兴趣。知道如何解决这个问题吗?

最佳答案

关于opencv - 在 OpenCV 图像拼接中混合伪影,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35735241/

相关文章:

c++ - openCV警告组件数据类型不匹配

ios - 在彼此之上的相同 View 之间交叉淡入淡出

swift - 倒计时计时器后 UIPickerView 不会在其他 ViewController 上更新

c++ - cv::Scalar 不显示预期的颜色

android - 无法找到额外的模块OpenCV android studio(ximgproc)

algorithm - 是否有一种颜色混合算法可以像混合真实颜色一样工作?

python - 获取图像模式 PIL Python

opengl - 渐变色文本

c++ - 从当前捕获中获取设备 ID

android - OpenGL 与源和目标 alpha 混合