Android中大图片加载

2024-05-27 06:48
文章标签 android 加载 图片 中大

本文主要是介绍Android中大图片加载,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.1.1 加载大图片原理

Android虚拟机默认为每个应用分配的堆内存是16M,当在界面显示图片时,需要的内存空间不是按图片的实际大小来计算的,而是按像素点的多少乘以每个像素点占用的空间大小来计算的。图片加载到内存中需要把每一个像素都加载到内存中. 所以对内存的要求非常高,一不小心就会造成OOM(OutOfMemoryError)错误。下面通过一组计算来演示OOM为什么会发生,以及解决方案。
假设:当前有一张图片,大小仅为1M,但是其规格(图片的像素)为3648*2736,那么完全加载此图片的像素数=3648*2736=9980928。在Android中像素的表现形式有三种模式:
三种像素如下:
l ARGB_4444 : 2bytes 每个像素占据2个字节
l ARGB_8888 : 4bytes 每个像素占据4个字节
l RGB_565 : 4bytes 每个像素占据4个字节
假设采用ARGB_4444模式作为像素的表现形式,则该1M大小的图片在Android中占用的总空间为:
图片占用空间=总像素数 *像素的单位
=9980928* 2bytes
=19961856bytes
=19M>16M
通过计算大家发现就算采用每个像素占用2个字节的形式该1M的图片也需要分配19M的空间才能100%地将所有像素表现出来,这肯定会导致OOM的发生。
解决方案:
通过代码可以对图片进行按比例(之所以按照比例缩放是为了避免图片的畸变,比如一张图片长度缩小一半,那么高度也缩小一半就保证了图片不会畸变)缩放,这也是必须要进行的工作。
假设:
图片的宽和高: 3648 * 2736
屏幕的宽和高: 320 * 480
计算缩放比:
宽度缩放比例: 3648 / 320 = 11
高度缩放比例: 2736 / 480 = 5
比较宽和高的缩放比例,哪一个大用哪一个进行缩放,因此我们采用11作为该图片长和高的缩放比例。
计算缩放后的图片的宽和高:
宽=3648 / 11 = 331
高=2736 / 11 = 248
缩放后图片的宽和高: 331* 248
计算缩放后的图片在Android中占有的空间:
总空间=331* 248*像素点大小=882088 * 2bytes=160K
最终计算结果是160K,远远小于堆内存的16M上限,从而解决了OOM的发生。

 /*** 点击界面Button后调用该方法,实现加载大图片的业务逻辑** @param view*/public void load(View view) {/*** 最普通的方式(不对图片进行等比例缩放时)加载图片的两行核心代码*/Bitmap bitmap = BitmapFactory.decodeFile("/mnt/sdcard/dog.jpg");iv.setImageBitmap(bitmap);//创建一个可选项对象,该对象用于配置图片的处理参数Options opts = new Options();// 将该参数设置为true则加载器不加载图片, 而是把图片的out(宽和高)的字段信息取出来opts.inJustDecodeBounds = true;/*** 加载图片,该方法只是从图片文件中读取图片的宽和高信息,而没有真正的加载到内存中* 参数1:是图片的地址* 参数2:是加载图片时的配置信息*/BitmapFactory.decodeFile("/mnt/sdcard/dog.jpg", opts);//获取到图片的宽和高信息int imageWidth = opts.outWidth;int imageHeight = opts.outHeight;// 获取到屏幕对象Display display = getWindowManager().getDefaultDisplay();// 获取到屏幕的真是宽和高int screenWidth = display.getWidth();int screenHeight = display.getHeight();// 计算缩放比例int widthScale = imageWidth / screenWidth;int heightScale = imageHeight / screenHeight;//计算出最大的比例int scale = widthScale > heightScale ? widthScale : heightScale;// 使用缩放比例进行缩放加载图片opts.inJustDecodeBounds = false; // 加载器就会返回图片了// 配置该参数加载图片时BitmapFactory就会自动缩放图片opts.inSampleSize = scale;//重新加载图片,这次才是 真正的压缩加载图片Bitmap bm = BitmapFactory.decodeFile("/mnt/sdcard/me.jpg", opts);// 显示在屏幕上iv.setImageBitmap(bm);}

这篇关于Android中大图片加载的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1006744

相关文章

使用Python获取JS加载的数据的多种实现方法

《使用Python获取JS加载的数据的多种实现方法》在当今的互联网时代,网页数据的动态加载已经成为一种常见的技术手段,许多现代网站通过JavaScript(JS)动态加载内容,这使得传统的静态网页爬取... 目录引言一、动态 网页与js加载数据的原理二、python爬取JS加载数据的方法(一)分析网络请求1

IDEA下"File is read-only"可能原因分析及"找不到或无法加载主类"的问题

《IDEA下Fileisread-only可能原因分析及找不到或无法加载主类的问题》:本文主要介绍IDEA下Fileisread-only可能原因分析及找不到或无法加载主类的问题,具有很好的参... 目录1.File is read-only”可能原因2.“找不到或无法加载主类”问题的解决总结1.File

使用Python实现调用API获取图片存储到本地的方法

《使用Python实现调用API获取图片存储到本地的方法》开发一个自动化工具,用于从JSON数据源中提取图像ID,通过调用指定API获取未经压缩的原始图像文件,并确保下载结果与Postman等工具直接... 目录使用python实现调用API获取图片存储到本地1、项目概述2、核心功能3、环境准备4、代码实现

Java实现图片淡入淡出效果

《Java实现图片淡入淡出效果》在现代图形用户界面和游戏开发中,**图片淡入淡出(FadeIn/Out)**是一种常见且实用的视觉过渡效果,它可以用于启动画面、场景切换、轮播图、提示框弹出等场景,通过... 目录1. 项目背景详细介绍2. 项目需求详细介绍2.1 功能需求2.2 非功能需求3. 相关技术详细

重新对Java的类加载器的学习方式

《重新对Java的类加载器的学习方式》:本文主要介绍重新对Java的类加载器的学习方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、介绍1.1、简介1.2、符号引用和直接引用1、符号引用2、直接引用3、符号转直接的过程2、加载流程3、类加载的分类3.1、显示

Java如何根据文件名前缀自动分组图片文件

《Java如何根据文件名前缀自动分组图片文件》一大堆文件(比如图片)堆在一个目录下,它们的命名规则遵循一定的格式,混在一起很难管理,所以本文小编就和大家介绍一下如何使用Java根据文件名前缀自动分组图... 目录需求背景分析思路实现代码输出结果知识扩展需求一大堆文件(比如图片)堆在一个目录下,它们的命名规

在 PyQt 加载 UI 三种常见方法

《在PyQt加载UI三种常见方法》在PyQt中,加载UI文件通常指的是使用QtDesigner设计的.ui文件,并将其转换为Python代码,以便在PyQt应用程序中使用,这篇文章给大家介绍在... 目录方法一:使用 uic 模块动态加载 (不推荐用于大型项目)方法二:将 UI 文件编译为 python 模

将图片导入Python的turtle库的详细过程

《将图片导入Python的turtle库的详细过程》在Python编程的世界里,turtle库以其简单易用、图形化交互的特点,深受初学者喜爱,随着项目的复杂度增加,仅仅依靠线条和颜色来绘制图形可能已经... 目录开篇引言正文剖析1. 理解基础:Turtle库的工作原理2. 图片格式与支持3. 实现步骤详解第

Android NDK版本迭代与FFmpeg交叉编译完全指南

《AndroidNDK版本迭代与FFmpeg交叉编译完全指南》在Android开发中,使用NDK进行原生代码开发是一项常见需求,特别是当我们需要集成FFmpeg这样的多媒体处理库时,本文将深入分析A... 目录一、android NDK版本迭代分界线二、FFmpeg交叉编译关键注意事项三、完整编译脚本示例四

在React聊天应用中实现图片上传功能

《在React聊天应用中实现图片上传功能》在现代聊天应用中,除了文字和表情,图片分享也是一个重要的功能,本文将详细介绍如何在基于React的聊天应用中实现图片上传和预览功能,感兴趣的小伙伴跟着小编一起... 目录技术栈实现步骤1. 消息组件改造2. 图片预览组件3. 聊天输入组件改造功能特点使用说明注意事项