iOS 像素图转高清大图

本文介绍了两种使生成的高清大图更清晰的方法:使用最近邻插值算法和通过CoreGraphics画矩形。在比较两者时发现,内存使用相差无几,但在速度上,最近邻插值在放大倍数小的时候更快,而CoreGraphics在放大倍数大的时候表现更优。文章提供了具体代码供读者测试不同生成时间。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

iOS 像素图转高清大图


一张小的像素图转大图时会变得模糊

在这里插入图片描述

有两种方式可以使生成的大图更清晰

  1. 用最近邻插值算法生成大图
  2. 按其宽高和像素行列去取颜色,CoreGraphics 用颜色数组画多个矩形去绘制大图

比较

随机生成 20 张原图 64px * 64px(iOS 由颜色数组生成像素图),用上诉两种方式生成大图,比对生成速度和内存峰值:内存用量几乎完全一致,而速度上,放大倍数小时最近邻插值更快,放大倍数大时 CoreGraphics 更快。

因为最近邻插值算法的原理是找到原图像中对应的点后,找到离它最近的一个整数坐标的像素值作为目标图像对应位置处的像素值,当放大倍数越大,处理次数越多

而 CoreGraphics 画矩形,无论放大倍数多少,处理次数是一样的。

本文给出两种方式的具体代码,读者可自行传入倍数,测试生成时间

最近邻插值

CGInterpolationQuality 插值质量

kCGInterpolationDefault 默认

kCGInterpolationNone 无插值(最近邻插值

kCGInterpolationLow 插值质量低,图像渲染速度快

kCGInterpolationMedium 插值质量中等,渲染速度中等

kCGInterpolationHigh 插值质量高,渲染速度较慢

extension UIImage {
   
   
    func resize(to size: CGSize, interpolationQuality: CGInterpolationQuality = .none, isOpaque: Bool = false) -> UIImage? {
   
   
        let format = imageRendererFormat
        format.opaque = isOpaque
        return UIGraphicsImageRenderer(size: size, format: format).image {
   
    context in
            context.cgContext.interpolationQuality =
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值