android之图片压缩

废话不多说,上代码:

(使用的方法很简单,把你的图片地址传进来,他就返回给你一个转换成base64的字串,2M可以压缩成76kb)

public static String myMethod(String imageUri){
    // 设置参数
    BitmapFactory.Options options = new BitmapFactory.Options();
    options.inJustDecodeBounds = true; // 只获取图片的大小信息,而不是将整张图片载入在内存中,避免内存溢出
    BitmapFactory.decodeFile(imageUri, options);
    int height = options.outHeight;
    int width= options.outWidth;
    int inSampleSize = 2; // 默认像素压缩比例,压缩为原图的1/2
    int minLen = Math.min(height, width); // 原图的最小边长
    if(minLen > 200) { // 如果原始图像的最小边长大于200dp(此处单位我认为是dp,而非px)
        float ratio = (float)minLen / 200.0f; // 计算像素压缩比例
        inSampleSize = (int)ratio;
    }
    options.inJustDecodeBounds = false; // 计算好压缩比例后,这次可以去加载原图了
    options.inSampleSize = inSampleSize; // 设置为刚才计算的压缩比例
    Bitmap bm = BitmapFactory.decodeFile(imageUri, options); // 解码文件
    return Bitmap2StrByBase64(bm);
}

/**
 * 将图片处理为base64字符串
 */
public static String Bitmap2StrByBase64(Bitmap bit) {
    ByteArrayOutputStream bos = new ByteArrayOutputStream();
    bit.compress(Bitmap.CompressFormat.PNG, 40, bos);//参数100表示不压缩
    byte[] bytes = bos.toByteArray();
    return Base64.encodeToString(bytes, Base64.DEFAULT);
}

如果还要压缩到更小:

压缩几百倍,但是图像会是真,如果只是上传一个个人头像的话可以使用,其他就不建议了,一下方法可压缩倒5kb一下,保守估计放大以后除非自己照的不然不好想明白。

注意,一下方法是传入一个图片的地址,返回一个压缩过的文件:

//传入地址,返回一个文件夹
public static File myMethod(String imageUri) {
    // 设置参数
    BitmapFactory.Options options = new BitmapFactory.Options();
    options.inJustDecodeBounds = true; // 只获取图片的大小信息,而不是将整张图片载入在内存中,避免内存溢出
    BitmapFactory.decodeFile(imageUri, options);
    int height = options.outHeight;//
    int width = options.outWidth;//
    int inSampleSize = 2; // 默认像素压缩比例,压缩为原图的1/2
    int minLen = Math.min(height, width); // 原图的最小边长
    if (minLen > 200) { // 如果原始图像的最小边长大于200dp(此处单位我认为是dp,而非px)
        float ratio = (float) minLen / 100.0f; // 计算像素压缩比例
        inSampleSize = (int) ratio;
    }
    options.inJustDecodeBounds = false; // 计算好压缩比例后,这次可以去加载原图了
    options.inSampleSize = inSampleSize; // 设置为刚才计算的压缩比例
    Bitmap bm = BitmapFactory.decodeFile(imageUri, options);

    // 解码文件,将文件转换成Base64字符串的时候的操作
    //return Bitmap2StrByBase64(bm);

    File file = Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_PICTURES);
    if (!file.exists()) {
        file.mkdirs();
    }
    File mFile = new File(file, System.currentTimeMillis() + ".jpg");
    return saveFile(bm, mFile.getAbsolutePath(), mFile.getName());
}

/**
 * 将Bitmap转换成文件
 * 保存文件
 * @param bm
 * @param fileName
 * @throws IOException
 */
public static File saveFile(Bitmap bm, String path, String fileName) {
    try {
        File dirFile = new File(path);
        if (!dirFile.exists()) {
            dirFile.mkdir();
        }
        File myCaptureFile = new File(path, fileName);
        BufferedOutputStream bos = new BufferedOutputStream(new FileOutputStream(myCaptureFile));
        bm.compress(Bitmap.CompressFormat.JPEG, 40, bos);//这里设置再次压缩的倍数,100是不再压缩
        bos.flush();
        bos.close();
        return myCaptureFile;
    } catch (IOException e) {
        e.printStackTrace();
        LogUtil.e("bitmap转换过程中出错"+ e.getMessage());
    }
    return null;
}



请注意,会失真……

转载被人的,但是看的太多就这一个有用的,并多了几行无用的代码让我给闪了,或许原著看到请指明是为什么。

谢谢前辈的分享!


下面继续添加,国内最合适不失真的图片压缩(目前我只会处理单张压缩)luban

单张压缩倍数大概事二十倍左右,不是太准确,会因为更清晰压缩倍数更少变动:

使用方法:

compile 'top.zibin:Luban:1.1.3'
压缩代码:

//传入上下文对象
Luban.with(HindInActivity.this).
        //传入压缩图片路径
        load(new File(capath)).
        //压缩结果监听
        setCompressListener(new OnCompressListener() {
            //开始压缩
            @Override
            public void onStart() {}
            //压缩成功
            @Override
            public void onSuccess(File file) {
                files.add(file);
            }
            //压缩出错
            @Override
            public void onError(Throwable e) {}
        }).launch();

谢谢前辈们的努力。

Luban(鲁班)——Android图片压缩工具,仿微信朋友圈压缩策略。项目描述目前做app开发总绕不开图片这个元素。但是随着手机拍照分辨率的提升,图片压缩成为一个很重要的问题。单纯对图片进行裁切,压缩已经有很多文章介绍。但是裁切成多少,压缩成多少却很难控制好,裁切过头图片太小,质量压缩过头则显示效果太差。于是自然想到app巨头“微信”会是怎么处理,Luban(鲁班)就是通过在微信朋友圈发送近100张不同分辨率图片,对比原图与微信压缩后的图片逆向推算出来的压缩算法。因为有其他语言也想要实现 Luban,所以描述了一遍算法步骤 因为是逆向推算,效果还没法跟微信一模一样,但是已经很接近微信朋友圈压缩后的效果,具体看以下对比!效果与对比内容原图LubanWechat截屏 720P720*1280,390k720*1280,87k720*1280,56k截屏 1080P1080*1920,2.21M1080*1920,104k1080*1920,112k拍照 13M(4:3)3096*4128,3.12M1548*2064,141k1548*2064,147k拍照 9.6M(16:9)4128*2322,4.64M1032*581,97k1032*581,74k滚动截屏1080*6433,1.56M1080*6433,351k1080*6433,482k导入compile 'io.reactivex:rxandroid:1.2.1' compile 'io.reactivex:rxjava:1.1.6' compile 'top.zibin:Luban:1.0.5'使用Listener方式Luban内部采用io线程进行图片压缩,外部调用只需设置好结果监听即可Luban.get(this)     .load(File)                     //传人要压缩图片     .putGear(Luban.THIRD_GEAR)      //设定压缩档次,默认三挡     .setCompressListener(new OnCompressListener() { //设置回调         @Override         public void onStart() {             //TODO 压缩开始前调用,可以在方法内启动 loading UI         }         @Override         public void onSuccess(File file) {             //TODO 压缩成功后调用,返回压缩后的图片文件         }         @Override         public void onError(Throwable e) {             //TODO 当压缩过去出现问题时调用         }     }).launch();    //启动压缩RxJava方式RxJava 调用方式请自行随意控制线程Luban.get(this)         .load(file)         .putGear(Luban.THIRD_GEAR)         .asObservable()         .subscribeOn(Schedulers.io())         .observeOn(AndroidSchedulers.mainThread())         .doOnError(new Action1() {             @Override             public void call(Throwable throwable) {                 throwable.printStackTrace();             }         })         .onErrorResumeNext(new Func1>() {             @Override             public Observable<? extends File> call(Throwable throwable) {                 return Observable.empty();             }         })         .subscribe(new Action1() {             @Override             public void call(File file) {                 //TODO 压缩成功后调用,返回压缩后的图片文件             }         }); 标签:Luban(鲁班)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值