2

我是GPUImage库的新手。

我正在使用它从相机获取帧并实时过滤它们。我正在为我正在开发的过滤器使用不同的过滤器参数。

我想出了如何使用不同的过滤器并行过滤相机图像,但我现在想做的是输出一个结果图像,其中 4 个过滤后的图像平铺在一起以制作一个大的输出图像。

我的想法是我可以链接GPUImageTransformFilter实例和GPUImageAddBlendFilter实例来获得组合图像。例如,在缩小两个图像并将它们并排放置的最简单情况下:

self.transform1 = [[GPUImageTransformFilter alloc] init];
_transform1.affineTransform = CGAffineTransformScale(CGAffineTransformIdentity, 0.5, 0.5);

self.transform2 = [[GPUImageTransformFilter alloc] init];
_transform2.affineTransform = CGAffineTransformTranslate(CGAffineTransformScale(CGAffineTransformIdentity, 0.5, 0.5), 1.0, 0.0);

self.blendFirst1 = [[GPUImageAddBlendFilter alloc] init];

[_transform1 addTarget:_blendFirst1];
[_transform2 addTarget:_blendFirst1];

然而,这会导致两个图像被缩放并相互重叠,结果被转换到图像的边缘而另一半为空。

我将不胜感激有关如何缩放和平铺较小图像以制作大图像的任何指示。

非常感谢!

4

1 回答 1

4

虽然您可以使用变换来做到这一点,但您正在查看三个混合以将您的四个图像放入一个静止帧中。这不会是完成这项工作的最快或最节省内存的途径。

相反,我建议继承 GPUImageTwoInputFilter 或基于此创建一个全新的多输入过滤器,然后使用该过滤器将所有四个图像拉入以进行渲染。人们已经通过这样做制作了三个或四个过滤器输入混合,这可能是您最有效的路径。

过滤器的片段着色器可以渲染四个四边形,每个输入图像一个,或者具有选择性地从四个纹理中采样的着色器以在给定像素处提供适当的颜色。前者会更快,但可能需要您编写更多的 OpenGL ES 代码来修改基本混合过滤器。后者将对顶点和片段着色器使用简单的调整,但这些着色器中的条件可能会减慢速度。

于 2012-12-17T18:16:37.343 回答