gpt4 book ai didi

ios - 带有 GPUImageChromaKeyFilter 的视频在透明 GPUImageView 中播放时有色调?

转载 作者:塔克拉玛干 更新时间:2023-11-02 09:59:29 25 4
gpt4 key购买 nike

我有一个纯绿色背景的视频,我正在尝试使用 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

最佳答案

我得到了这个工作。解决方案是使用 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com