用的UIImage面膜的UIView通过保持透明区域和取出彩色区域
问题描述:
我有一个形象:用的UIImage面膜的UIView通过保持透明区域和取出彩色区域
,我想申请到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
但是这给了我相反的效果,在波形切出:
我想波形的外侧区域是透明的,并且内部被着色。我打算把UIView
放在另一个视图之上,所以我认为它应该是一个面具。
我试着用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
+0
谢谢!我花了好几个小时试图解决这个问题,这完美地工作。时间阅读这些功能:) – Daven
我觉得你找这个[逆转的CALayer面具(https://stackoverflow.com/a/42238699/6689101) – zombie