Android开发之图片压缩工具类完整实例

 更新时间:2017年11月24日 10:41:58   作者:勤修戒定慧  
这篇文章主要介绍了Android开发之图片压缩工具类,结合完整实例形式分析了Android针对图片压缩的相关属性设置与转换操作实现技巧,需要的朋友可以参考下

本文实例讲述了Android图片压缩工具类。分享给大家供大家参考,具体如下:

这里共享一个图片压缩工具类:

package com.sanweidu.TddPay.util2;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
public class ImaZipUtil {
  /**
   * 压缩图片到指定宽高,并进行质量压缩,最终大小保持在100K以下
   *
   * @param sourceBm
   * @param targetWidth
   * @param targetHeight
   * @return
   */
  public static Bitmap zipPic(Bitmap sourceBm, float targetWidth, float targetHeight) {
    BitmapFactory.Options newOpts = new BitmapFactory.Options();
    // 开始读入图片,此时把options.inJustDecodeBounds 设回true了
    newOpts.inJustDecodeBounds = true;
    // 可删除
    newOpts.inPurgeable = true;
    // 可共享
    newOpts.inInputShareable = true;
    // 转成数组
    ByteArrayOutputStream baos = new ByteArrayOutputStream();
    sourceBm.compress(Bitmap.CompressFormat.JPEG, 100, baos);
    byte[] temp = baos.toByteArray();
    // 此时返回bm为空
    Bitmap bitmap = BitmapFactory.decodeByteArray(temp, 0, temp.length, newOpts);
    newOpts.inJustDecodeBounds = false;
    int w = newOpts.outWidth;
    int h = newOpts.outHeight;
    // 现在主流手机比较多是800*480分辨率,所以高和宽我们设置为
    float hh = targetHeight;
    float ww = targetWidth;
    // 缩放比。由于是固定比例缩放,只用高或者宽其中一个数据进行计算即可
    int be = 1;// be=1表示不缩放
    // 如果宽度大的话根据宽度固定大小缩放
    if (w > h && w > ww) {
      be = (int) (newOpts.outWidth / ww);
    } else if (w < h && h > hh) {
      // 如果高度高的话根据宽度固定大小缩放
      be = (int) (newOpts.outHeight / hh);
    }
    if (be <= 0) {
      be = 1;
    }
    // 设置缩放比例
    newOpts.inSampleSize = be;
    // 重新读入图片,注意此时已经把options.inJustDecodeBounds 设回false了
    bitmap = BitmapFactory.decodeByteArray(temp, 0, temp.length, newOpts);
    // 压缩好比例大小后再进行质量压缩
    return compressImage(bitmap);
  }
  /**
   * @Description 质量压缩方法
   * @author XiongJie
   * @param image
   * @return
   */
  public static Bitmap compressImage(Bitmap image) {
    ByteArrayOutputStream baos = new ByteArrayOutputStream();
    // 质量压缩方法,这里100表示不压缩,把压缩后的数据存放到baos中
    image.compress(Bitmap.CompressFormat.JPEG, 100, baos);
    int options = 100;
    // 循环判断如果压缩后图片是否大于100kb,大于继续压缩
    while (baos.toByteArray().length / 1024 > 100) {
      // 重置baos即清空baos
      baos.reset();
      // 这里压缩options%,把压缩后的数据存放到baos中
      image.compress(Bitmap.CompressFormat.JPEG, options, baos);
      // 每次都减少10
      options -= 10;
    }
    // 把压缩后的数据baos存放到ByteArrayInputStream中
    ByteArrayInputStream isBm = new ByteArrayInputStream(baos.toByteArray());
    // 把ByteArrayInputStream数据生成图片
    Bitmap bitmap = BitmapFactory.decodeStream(isBm, null, null);
    return bitmap;
  }
  /**
   * 只进行分辨率压缩,不进行图片的质量压缩
   *
   * @param sourceBm
   * @param targetWidth
   * @param targetHeight
   * @return
   */
  public static Bitmap zipPicWithoutCompress(Bitmap sourceBm, float targetWidth, float targetHeight) {
    BitmapFactory.Options newOpts = new BitmapFactory.Options();
    // 开始读入图片,此时把options.inJustDecodeBounds 设回true了
    newOpts.inJustDecodeBounds = true;
    // 可删除
    newOpts.inPurgeable = true;
    // 可共享
    newOpts.inInputShareable = true;
    // 转成数组
    ByteArrayOutputStream baos = new ByteArrayOutputStream();
    sourceBm.compress(Bitmap.CompressFormat.JPEG, 100, baos);
    byte[] temp = baos.toByteArray();
    // 此时返回bm为空
    Bitmap bitmap = BitmapFactory.decodeByteArray(temp, 0, temp.length, newOpts);
    newOpts.inJustDecodeBounds = false;
    int w = newOpts.outWidth;
    int h = newOpts.outHeight;
    // 现在主流手机比较多是800*480分辨率,所以高和宽我们设置为
    float hh = targetHeight;
    float ww = targetWidth;
    // 缩放比。由于是固定比例缩放,只用高或者宽其中一个数据进行计算即可
    // be=1表示不缩放
    int be = 1;
    if (w > h && w > ww) {
      // 如果宽度大的话根据宽度固定大小缩放
      be = (int) (newOpts.outWidth / ww);
    } else if (w < h && h > hh) {
      // 如果高度高的话根据宽度固定大小缩放
      be = (int) (newOpts.outHeight / hh);
    }
    if (be <= 0) {
      be = 1;
    }
    // 设置缩放比例
    newOpts.inSampleSize = be;
    // 重新读入图片,注意此时已经把options.inJustDecodeBounds 设回false了
    bitmap = BitmapFactory.decodeByteArray(temp, 0, temp.length, newOpts);
    // 压缩好比例大小后再进行质量压缩
    return bitmap;
  }
}

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android图形与图像处理技巧总结》、《Android开发入门与进阶教程》、《Android调试技巧与常见问题解决方法汇总》、《Android基本组件用法总结》、《Android视图View技巧总结》、《Android布局layout技巧总结》及《Android控件用法总结

希望本文所述对大家Android程序设计有所帮助。

相关文章

  • viewpager实现自动循环轮播图

    viewpager实现自动循环轮播图

    这篇文章主要为大家详细介绍了viewpager实现自动循环轮播图,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-01-01
  • Android Studio通过Artifactory搭建本地仓库优化编译速度的方法

    Android Studio通过Artifactory搭建本地仓库优化编译速度的方法

    这篇文章主要介绍了Android Studio通过Artifactory搭建本地仓库优化编译速度的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-03-03
  • Android Gradle多渠道打包的实现方法

    Android Gradle多渠道打包的实现方法

    这篇文章主要介绍了Android Gradle多渠道打包的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • Android RecyclerView多类型布局卡片解决方案

    Android RecyclerView多类型布局卡片解决方案

    这篇文章主要介绍了Android RecyclerView多类型布局卡片解决方案,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-03-03
  • Android中layout属性大全

    Android中layout属性大全

    这篇文章主要介绍了Android中layout属性含义及用法,较为详细的总结分析了layout属性相关用法,需要的朋友可以参考下
    2015-05-05
  • Android判断当前App是在前台还是在后台

    Android判断当前App是在前台还是在后台

    这篇文章主要为大家详细介绍了Android判断当前App是在前台还是在后台的方法,感兴趣的小伙伴们可以参考一下
    2016-08-08
  • 使用Flutter 构建Web应用逻辑解析

    使用Flutter 构建Web应用逻辑解析

    这篇文章主要为大家介绍了使用Flutter 构建Web应用逻辑解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • Android实现3秒钟自动关闭界面

    Android实现3秒钟自动关闭界面

    这篇文章主要为大家详细介绍了Android实现3秒钟自动关闭界面,以支付成功为例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-02-02
  • Android自定义view实现动态柱状图

    Android自定义view实现动态柱状图

    这篇文章主要为大家详细介绍了Android自定义view实现动态柱状图的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-08-08
  • Android自定义圆点指示器

    Android自定义圆点指示器

    这篇文章主要为大家详细介绍了Android自定义圆点指示器,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-06-06

最新评论