【Android 内存优化】图片文件压缩 ( Android 原生 API 提供的图片压缩功能能 | 图片质量压缩 | 图片尺寸压缩 )

简介: 【Android 内存优化】图片文件压缩 ( Android 原生 API 提供的图片压缩功能能 | 图片质量压缩 | 图片尺寸压缩 )

文章目录

一、 图片压缩

二、 图片文件压缩类型

三、 Android 原生 API 提供的质量压缩

四、 Android 原生 API 提供的尺寸压缩





一、 图片压缩


图片压缩 :



① 文件压缩 : 图片的文件压缩 , 一张图片可以经过压缩 , 占用更少的磁盘或网络空间 ;


② 文件压缩应用场景 :


网络传输图片 : 上传图片至服务器 , 为了 节省占用的带宽资源 , 将图片文件进行压缩 ;

保存图片 : 保存图片到设备的 SD 卡 , 为了 节省磁盘资源 , 将图片文件进行压缩 ;

③ 内存压缩 : 与文件压缩相对应的是内存压缩 , 在 内存中如何使用更少的内存显示出想要显示的图片 ; 在之后的博客中会详细介绍 ;






二、 图片文件压缩类型


图片文件压缩类型 :



① 质量压缩 :


压缩清晰度 : 将图片的清晰度降低 , 一些画面的细节被模糊掉了 , 这些细节尽量不要让肉眼观察出来 ;

有损压缩 : 压缩后有信息损失 , 无法复原 ;

② 尺寸压缩 : 减小图片的尺寸大小 , 明显这个也是有损的 , 无法复原 ;


③ 不同压缩格式的压缩率 : webp > jpeg > png ;


如果图片不需要透明度 ( alpha ) 通道的信息 , 推荐使用 JPEG ;

webp 目前使用还不是很广泛 ;





三、 Android 原生 API 提供的质量压缩


图片质量压缩函数原型 : 下面的函数原型中给出了详细注释 ;



① 函数作用 : 传入压缩参数 , 将压缩的内容输出到文件或网络中 ;


② 参数解析 :


CompressFormat format 参数 : 被压缩的目标格式, 要将该图片压缩成什么格式 JPEG, PNG, WEBP , 压缩格式从下面的枚举类型中获取 ;
    /**
     * Bitmap 位图只能被压缩成以下三种格式
     */
    public enum CompressFormat {
        JPEG    (0),
        PNG     (1),
        WEBP    (2);
        CompressFormat(int nativeInt) {
            this.nativeInt = nativeInt;
        }
        final int nativeInt;
    }


int quality 参数 : 给压缩器的质量, 0-100 ; 0 压缩到极限最小 , 100 压缩时最高质量 , PNG 图片是无损图片格式 , 其质量不能被降低 , 会忽略该参数 ;

OutputStream stream 参数 : 写出被压缩图片的输出流, 可以是文件输出流 , 也可以是网络流 ;

③ 返回值 : 如果压缩成功, 并写出到指令的输出流, 返回 true ;


 

/**
     * 写出该位图压缩后的版本到输出流中
     * 如果该方法返回 true, 该位图可以向 BitmapFactory.decodeStream() 传入对应输入流进行恢复. 
     * 传入的压缩配置并不是所有的格式都接收所有的配置,
     * 从 BitmapFactory 返回的位图极有可能与原图位深度不同,
     * 如果是 JPEG 格式, 其没有透明度通道, 只支持
     *
     * @param format   被压缩的目标格式, 要将该图片压缩成什么格式 JPEG, PNG, WEBP 
     * @param quality  给压缩器的质量, 0-100. 0 压缩到极限最小, 100 压缩时最高质量
     *        PNG 图片是无损图片格式, 其质量不能被降低, 会忽略该参数; 
     * @param stream   写出被压缩图片的输出流, 可以是文件输出流 , 也可以是网络流
     * @return 如果压缩成功, 并写出到指令的输出流, 返回 true
     */
    @WorkerThread
    public boolean compress(CompressFormat format, int quality, OutputStream stream) {
      // 首先检查该图片是否被回收, 如果已经被回收, 直接丢出异常退出
        checkRecycled("Can't compress a recycled bitmap");
        // 调用输出流时会调用 Native 方法, 显示检查该流是否合法
        if (stream == null) {
            throw new NullPointerException();
        }
        // 输入的质量是否合法
        if (quality < 0 || quality > 100) {
            throw new IllegalArgumentException("quality must be 0..100");
        }
        // 严格模式 
        StrictMode.noteSlowCall("Compression of a bitmap is slow");
        // 输出压缩过程中的执行细节
        Trace.traceBegin(Trace.TRACE_TAG_RESOURCES, "Bitmap.compress");
        // 执行 Native 方法, 压缩图片
        boolean result = nativeCompress(mNativePtr, format.nativeInt,
                quality, stream, new byte[WORKING_COMPRESS_STORAGE]);
        Trace.traceEnd(Trace.TRACE_TAG_RESOURCES);
        return result;
    }






四、 Android 原生 API 提供的尺寸压缩


图片尺寸压缩函数原型 : 下面的函数原型中给出了详细注释 ;



① 函数作用 : 创建一个新的 Bitmap 对象 , 缩放一张已存在的位图 ; 如果指定的宽高与当前源位图的宽高一致 , 那么直接将源位图返回 ;


② 参数解析 :


Bitmap src 参数 : 位图原图 ;

int dstWidth 参数 : 图片转换后的目标宽度 ;

int dstHeight 参数 : 图片转换后的目标高度 ;

boolean filter 参数 : 设置缩放图像时是否使用双线性滤波 ; 如果设置成 true , 则使用双线性滤波 , 当缩放时图片质量更好 , 但是会降低性能 ; 如果设置成 false , 使用最近邻法进行尺寸缩放 , 图片质量差 , 但是速度很快 ; 推荐默认设置成 true , 双线性滤波开销很小 , 对于图像质量的改善效果显著 ;

③ 返回值 : 返回新的被缩放好的 Bitmap 位图 , 如果缩放失败 , 返回源图 ;


   /

**
     * 创建一个新的 Bitmap 对象 , 缩放一张已存在的位图 ;
     * 如果指定的宽高与当前源位图的宽高一致 , 那么直接将源位图返回
     *
     * @param src       位图原图
     * @param dstWidth  图片转换后的目标宽度
     * @param dstHeight 图片转换后的目标高度
     * @param filter    设置缩放图像时是否使用双线性滤波. 
     *      如果设置成 true , 则使用双线性滤波 , 
     *      当缩放时图片质量更好 , 但是会降低性能 ; 
     *      如果设置成 false , 使用最近邻法进行尺寸缩放 ,
     *      图片质量差 , 但是速度很快 ;
     *      推荐默认设置成 true , 双线性滤波开销很小 , 对于图像质量的改善效果显著 ;
     * @return 返回新的被缩放好的 Bitmap 位图 , 如果缩放失败 , 返回源图 ;
     * @throws IllegalArgumentException 如果传入的宽高值参数小于等于 0, 抛出异常 ;
     */
    public static Bitmap createScaledBitmap(@NonNull Bitmap src, int dstWidth, int dstHeight,
            boolean filter) {
        Matrix m = new Matrix();
        final int width = src.getWidth();
        final int height = src.getHeight();
        if (width != dstWidth || height != dstHeight) {
            final float sx = dstWidth / (float) width;
            final float sy = dstHeight / (float) height;
            m.setScale(sx, sy);
        }
        /*
          最终调用的是 public static Bitmap createBitmap(
          @NonNull Bitmap source, int x, int y, int width, int height,
            @Nullable Matrix m, boolean filter) 方法 , 后续博客有详细解析
         */
        return Bitmap.createBitmap(src, 0, 0, width, height, m, filter);
    }


目录
相关文章
|
5天前
|
Java Android开发
android 下载图片的问题
android 下载图片的问题
13 3
|
5天前
|
Android开发
Android通过手势(多点)缩放和拖拽图片
Android通过手势(多点)缩放和拖拽图片
13 4
|
4天前
|
API 开发工具 Android开发
调用Android原生@SystemApi、@Hide方法
调用Android原生@SystemApi、@Hide方法
8 1
|
5天前
|
安全 Java Android开发
构建高效Android应用:采用Kotlin进行内存优化的策略
【5月更文挑战第8天】 在移动开发领域,性能优化一直是开发者关注的焦点。特别是对于Android应用而言,合理管理内存资源是确保应用流畅运行的关键因素之一。近年来,Kotlin作为官方推荐的开发语言,以其简洁、安全和互操作性的特点受到开发者青睐。本文将深入探讨利用Kotlin语言特性,通过具体策略对Android应用的内存使用进行优化,旨在帮助开发者提高应用性能,减少内存消耗,避免常见的内存泄漏问题。
12 0
|
5天前
|
Android开发
Android 设备清理内存 RAM
Android 设备清理内存 RAM
10 0
|
5天前
|
Android开发
Android中Glide加载Https图片失败的解决方案
Android中Glide加载Https图片失败的解决方案
19 1
|
5天前
|
算法 安全 Android开发
深入理解操作系统的内存管理机制构建高效Android应用:Kotlin的协程优势
【4月更文挑战第30天】 在现代计算机系统中,操作系统的内存管理是确保系统高效、稳定运行的关键。本文将探讨操作系统内存管理的核心技术,包括内存分配、虚拟内存、分页和分段等概念,以及它们是如何协同工作以提高内存利用率和系统性能的。通过对这些技术的详细分析,我们可以更好地理解操作系统背后的原理,并评估不同内存管理策略对系统行为的影响。 【4月更文挑战第30天】 在移动开发领域,尤其是针对Android平台,性能优化和流畅的用户体验始终是开发者追求的核心目标。随着Kotlin语言的普及,协程作为其在异步编程领域的杀手锏特性,已经逐渐成为提高应用性能和简化代码结构的重要工具。本文将深入探讨Kotli
|
5天前
|
缓存 监控 Android开发
构建高效Android应用:从内存优化到电池续航
【4月更文挑战第30天】 在移动开发领域,性能优化是一个永不过时的话题。对于Android应用而言,实现流畅的用户体验和延长设备电池寿命是至关重要的。本文将深入探讨Android平台特有的内存管理和电池使用策略,并提出一系列切实可行的优化措施。通过智能管理应用的生命周期、合理利用系统资源和调整后台任务执行策略,开发者可以显著提升应用性能并减少能源消耗。文章最后还将讨论如何利用Android Studio内置工具进行性能分析与监控,确保应用在发布前达到最优状态。
|
5天前
|
存储 缓存 数据库
构建高效Android应用:内存优化策略深度剖析
【4月更文挑战第29天】 在移动开发领域,性能一直是衡量应用质量的关键指标之一。特别是对于Android平台,由于设备硬件配置的多样性,内存管理成为开发者面临的一大挑战。本文将深入探讨Android应用内存优化的有效策略,旨在帮助开发者提升应用性能,减少内存消耗,避免常见的内存泄漏问题。通过对Android内存管理机制的分析与实际案例的结合,我们将提供一系列实用的优化技巧,助力应用在竞争激烈的市场中脱颖而出。
|
5天前
|
缓存 Java Android开发
构建高效的Android应用:从内存优化到电池寿命
【4月更文挑战第27天】在移动应用开发领域,尤其是对于资源有限的Android设备而言,性能优化是一个持续的挑战。本文将深入探讨如何提升Android应用的性能,重点讨论内存使用和电池寿命两大关键因素。我们将分析常见的内存泄漏问题,提供解决方案,并探究如何通过减少不必要的后台服务和优化网络请求来延长电池续航。文章的目标是为开发者提供实用的技术和策略,以构建更加高效、响应迅速且用户体验良好的Android应用。
http://www.vxiaotou.com