• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

ios - 更改 kCGImageAlphaOnly 渲染的 CGImage 的颜色

[复制链接]
菜鸟教程小白 发表于 2022-12-11 19:38:18 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

我正在尝试获取一些实际上只是黑色的带有 Alpha channel 的巨大 32 位 PNG,并以内存友好的方式将它们呈现在 iOS 应用程序中。

为此,我尝试在“仅限 alpha”的 CGContext 中重新渲染图像:

extension UIImage {
    func toLayer() -> CALayer? {
        let cgImage = self.cgImage!
        let height = Int(self.size.height)
        let width = Int(self.size.width)

        let colorSpace = CGColorSpaceCreateDeviceGray()
        let context = CGContext(data: nil, width: width, height: height, bitsPerComponent: 8, bytesPerRow: width, space: colorSpace, bitmapInfo: CGImageAlphaInfo.alphaOnly.rawValue)!

        context.draw(cgImage, in: CGRect(origin: .zero, size: self.size))
        let image = context.makeImage()!

        let layer = CALayer()
        layer.contents = image
        layer.contentsScale = self.scale

        return layer
    }
}

这太棒了!它将内存使用量从 180MB 降低到 18MB 左右,这实际上比我预期的要好。

问题是,图像的黑色(或现在不透明)部分不再是黑色,而是白色。

更改不透明位的颜色似乎应该是一个简单的解决方法,但我在网上找不到任何有关它的信息。你有什么想法吗?



Best Answer-推荐答案


我已经设法回答了我自己的问题。通过将仅 alpha 的图像设置为输出层的 maskcontents,我们可以将层的背景颜色设置为任何我们想要的(包括非灰度值) ,并且仍然保留内存优势!

我已经包含了最终代码,因为我肯定不是唯一对此方法感兴趣的人:

extension UIImage {
    func to8BitLayer(color: UIColor = .black) -> CALayer? {
        guard let cgImage = self.cgImage else { return nil }
        let height = Int(self.size.height * scale)
        let width = Int(self.size.width * scale)

        let colorSpace = CGColorSpaceCreateDeviceGray()
        guard let context = CGContext(data: nil, width: width, height: height, bitsPerComponent: 8, bytesPerRow: width, space: colorSpace, bitmapInfo: CGImageAlphaInfo.alphaOnly.rawValue) else {
            print("Couldn't create CGContext")
            return nil
        }

        context.draw(cgImage, in: CGRect(x: 0, y: 0, width: width, height: height))
        guard let image = context.makeImage() else {
            print("Couldn't create image from context")
            return nil
        }

        // Note that self.size corresponds to the non-scaled (retina) dimensions, so is not the same size as the context
        let frame = CGRect(origin: .zero, size: self.size)

        let mask = CALayer()
        mask.contents = image
        mask.contentsScale = scale
        mask.frame = frame

        let layer = CALayer()
        layer.backgroundColor = color.cgColor
        layer.mask = mask
        layer.contentsScale = scale
        layer.frame = frame

        return layer
    }
}

关于ios - 更改 kCGImageAlphaOnly 渲染的 CGImage 的颜色,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43876532/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap