加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

swift 图片压缩

发布时间:2020-12-14 06:18:58 所属栏目:百科 来源:网络整理
导读:微信分享、微博分享等等,对图片大小有要求,所以需要压缩,把该方法放到Extension+UIImage即可! // 图片压缩 func compressImage(maxLength: Int) - UIImage { let tempMaxLength: Int = maxLength / 8 var compression: CGFloat = 1 guard var data = UII

微信分享、微博分享等等,对图片大小有要求,所以需要压缩,把该方法放到Extension+UIImage即可!

// 图片压缩
    func compressImage(maxLength: Int) -> UIImage {
        let tempMaxLength: Int = maxLength / 8
        var compression: CGFloat = 1
        guard var data = UIImageJPEGRepresentation(self,compression) where data.length > tempMaxLength else { return self }
        
        // Compress by size
        var max: CGFloat = 1
        var min: CGFloat = 0
        for _ in 0..<6 {
            compression = (max + min) / 2
            data = UIImageJPEGRepresentation(self,compression)!
            if CGFloat(data.length) < CGFloat(tempMaxLength) * 0.9 {
                min = compression
            } else if data.length > tempMaxLength {
                max = compression
            } else {
                break
            }
        }
        var resultImage: UIImage = UIImage(data: data)!
        if data.length < tempMaxLength { return resultImage }
        
        // Compress by size
        var lastDataLength: Int = 0
        while data.length > tempMaxLength && data.length != lastDataLength {
            lastDataLength = data.length
            let ratio: CGFloat = CGFloat(tempMaxLength) / CGFloat(data.length)
            print("Ratio =",ratio)
            let size: CGSize = CGSize(width: Int(resultImage.size.width * sqrt(ratio)),height: Int(resultImage.size.height * sqrt(ratio)))
            UIGraphicsBeginImageContext(size)
            resultImage.drawInRect(CGRect(x: 0,y: 0,width: size.width,height: size.height))
            resultImage = UIGraphicsGetImageFromCurrentImageContext()!
            UIGraphicsEndImageContext()
            data = UIImageJPEGRepresentation(resultImage,compression)!
        }
        return resultImage
    }

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读