OGeek|极客世界-中国程序员成长平台

标题: ios - 使用 GPUImageChromaKeyFilter 的视频在透明 GPUImageView 中播放时有色调? [打印本页]

作者: 菜鸟教程小白    时间: 2022-12-12 09:29
标题: ios - 使用 GPUImageChromaKeyFilter 的视频在透明 GPUImageView 中播放时有色调?

我有一个纯绿色背景的视频,我正在尝试使用 GPUImageChromaKeyFilter 使其透明。

当我有清晰的播放器 View 颜色时,结果是视频不是真正透明的,而是给背景着色:

Tint on clear

当我将背景改为白色时,绿色背景消失了,但显然 View 不透明:

No tint on white

我做错了什么?

我的代码是:

let movie = GPUImageMovie(URL: url)

let filter = GPUImageChromaKeyFilter()
filter.setColorToReplaceRed(0, green: 1, blue: 0)
movie.addTarget(filter)

let playerView = GPUImageView()
playerView.backgroundColor = UIColor.clearColor()
playerView.setBackgroundColorRed(0, green: 0, blue: 0, alpha: 0)

let trinity = (movieFile, filter, playerView)

filter.addTarget(playerView)
movie.startProcessing()

我正在存储电影、过滤器和 View 以避免 ARC 在退出范围时释放它们,我将 View 添加到正确的 super View 并使用自动布局定位它。

我使用的视频是 h264 视频 - https://dl.dropboxusercontent.com/u/1400954/Coin.mp4



Best Answer-推荐答案


我得到了这个工作。解决方法是使用 GPUImageChromaKeyBlendFilter。 它通过将第一个源中 setColorToReplaceRed 中指定颜色的像素替换为第二个源中的像素来混合两个源。

所以我制作了一个带有透明 UIImage 的 GPUImagePicture 并将过滤器作为目标添加到它。您可以使用透明 PNG 或构建 UIImage 并在代码中用透明填充它(空的 UIImage 将不起作用!)

现在一切正常!

Working!

代码是

let filter = GPUImageChromaKeyBlendFilter()
filter.setColorToReplaceRed(0, green: 1, blue: 0)

let movieFile = GPUImageMovie(URL: url)
movieFile.addTarget(filter)

let backgroundImage = UIImage(named: "MTransparent")
let sourcePicture = GPUImagePicture(image: backgroundImage, smoothlyScaleOutput: true)
sourcePicture.addTarget(filter)
sourcePicture.processImage()

let playerView = GPUImageView()
playerView.backgroundColor = UIColor.clearColor()
filter.addTarget(playerView)

movieFile.startProcessing()

关于ios - 使用 GPUImageChromaKeyFilter 的视频在透明 GPUImageView 中播放时有色调?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33244347/






欢迎光临 OGeek|极客世界-中国程序员成长平台 (http://ogeek.cn/) Powered by Discuz! X3.4