gpt4 book ai didi

ios - 通过保留透明区域并移除彩色区域来使用 UIImage mask UIView

转载 作者:行者123 更新时间:2023-11-28 15:24:43 25 4
gpt4 key购买 nike

我有一张图片:

enter image description here

我想将其应用到 UIView 以使波形(透明区域)着色。我尝试了以下方法:

let image = UIImage(named: "waveform")!

let view = UIView(frame: CGRect(x: 0, y: 0, width: image.size.width, height: image.size.height))

let mask = CALayer()
mask.frame = view.bounds
mask.contents = image.cgImage!

view.layer.mask = mask
view.layer.masksToBounds = true
view.backgroundColor = UIColor.green

但这给了我相反的效果,波形被切断了:

enter image description here

我希望波形的外部区域是透明的,内部是彩色的。我计划将 UIView 放在另一个 View 之上,所以我认为它需要是一个掩码。

我尝试使用 CIImage 按照类似问题中的建议反转透明和彩色区域:

let cgImage = image.cgImage!
let ciImage = CIImage(cgImage: cgImage)
let filter = CIFilter(name: "CIColorInvert")!
filter.setValue(ciImage, forKey: kCIInputImageKey)

mask.contents = filter.outputImage!.cgImage

...但这导致了一个空白的 View (透明背景)。

如有任何帮助,我们将不胜感激。

最佳答案

这是一种方法...

func getImageWithInvertedPixelsOfImage(image: UIImage) -> UIImage {
let rect = CGRect(origin: CGPoint(), size: image.size)

UIGraphicsBeginImageContextWithOptions(image.size, false, 2.0)
UIGraphicsGetCurrentContext()!.setBlendMode(.copy)
image.draw(in: rect)
UIGraphicsGetCurrentContext()!.setBlendMode(.sourceOut)
UIGraphicsGetCurrentContext()!.setFillColor(UIColor.green.cgColor)
UIGraphicsGetCurrentContext()!.fill(rect)

let result = UIGraphicsGetImageFromCurrentImageContext()
UIGraphicsEndImageContext()
return result!
}

// I named your original image "WaveMask"
let iWave = UIImage(named: "WaveMask")
let invWave = getImageWithInvertedPixelsOfImage(image: iWave!)

// invWave is now Green where it was alpha, and alpha where it was gray
// and can now be used as a mask

关于ios - 通过保留透明区域并移除彩色区域来使用 UIImage mask UIView,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45424222/

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