• 最新swift4.0 图片进行尺寸大小及体积压缩


    ///图片压缩方法

       class func resetImgSize(sourceImage : UIImage,maxImageLenght : CGFloat,maxSizeKB : CGFloat) -> Data {

        var maxSize = maxSizeKB

        var maxImageSize = maxImageLenght

        

        if (maxSize <= 0.0) {

            maxSize = 1024.0;

        }

        if (maxImageSize <= 0.0)  {

            maxImageSize = 1024.0;

        }

        //先调整分辨率

        var newSize = CGSize.init( sourceImage.size.width, height: sourceImage.size.height)

        let tempHeight = newSize.height / maxImageSize;

        let tempWidth = newSize.width / maxImageSize;

        if (tempWidth > 1.0 && tempWidth > tempHeight) {

            newSize = CGSize.init( sourceImage.size.width / tempWidth, height: sourceImage.size.height / tempWidth)

        }

        else if (tempHeight > 1.0 && tempWidth < tempHeight){

            newSize = CGSize.init( sourceImage.size.width / tempHeight, height: sourceImage.size.height / tempHeight)

        }

        UIGraphicsBeginImageContext(newSize)

        sourceImage.draw(in: CGRect.init(x: 0, y: 0, newSize.width, height: newSize.height))

        let newImage = UIGraphicsGetImageFromCurrentImageContext()

        UIGraphicsEndImageContext()

        var imageData = UIImageJPEGRepresentation(newImage!, 1.0)

        var sizeOriginKB : CGFloat = CGFloat((imageData?.count)!) / 1024.0;

        //调整大小

        var resizeRate = 0.9;

        while (sizeOriginKB > maxSize && resizeRate > 0.1) {

            imageData = UIImageJPEGRepresentation(newImage!,CGFloat(resizeRate));

            sizeOriginKB = CGFloat((imageData?.count)!) / 1024.0;

            resizeRate -= 0.1;

        }

        return imageData!

       }

  • 相关阅读:
    JavaScript学习——使用JS实现首页轮播图效果
    JavaScript学习——使用JS完成注册页面表单校验
    JavaScript基础
    HTML&CSS——使用DIV和CSS完成网站首页重构
    HTML&CSS——网站注册页面
    java ------------ 集合(四) Collections类
    Java ---------- 集合(三) Map接口
    java ---------- 集合(二) Set 接口和Iterator 接口
    Java ---------- 集合
    idea -------- 常用快捷键
  • 原文地址:https://www.cnblogs.com/qizhuo/p/8242589.html
Copyright © 2020-2023  润新知