android之BitmapFactory.Options的使用

本文详细介绍了如何使用BitmapFactory.Options类中的inJustDecodeBounds和inSampleSize成员变量来优化内存使用,特别是在加载大图片时避免出现OutOfMemory错误。通过设置inJustDecodeBounds为true,可以仅获取图片的宽高信息而不需要创建完整的Bitmap对象,从而节省内存。同时,通过计算inSampleSize值,可以在保持图片质量的同时减小图片尺寸,进一步减少内存消耗。

,BitmapFactory.Options的使用是在加载图片时,就从图片的加载和使用说起

 

怎样获取图片的大小?
首先我们把这个图片转成Bitmap,然后再利用Bitmap的getWidth()和getHeight()方法就可以取到图片的宽高了。
新问题又来了,在通过BitmapFactory.decodeFile(String path)方法将突破转成Bitmap时,遇到大一些的图片,我们经常会遇到OOM(Out Of Memory)的问题。怎么避免它呢?
这就用到了我们上面提到的BitmapFactory.Options这个类。

BitmapFactory.Options这个类,有一个字段叫做 inJustDecodeBounds 。SDK中对这个成员的说明是这样的:
If set to true, the decoder will return null (no bitmap), but the out…
也就是说,如果我们把它设为true,那么BitmapFactory.decodeFile(String path, Options opt)并不会真的返回一个Bitmap给你,它仅仅会把它的宽,高取回来给你,这样就不会占用太多的内存,也就不会那么频繁的发生OOM了。
示例代码如下:

[java]  view plain copy print ?
  1. BitmapFactory.Options options = new BitmapFactory.Options();  
  2.   
  3. options.inJustDecodeBounds = true;  
  4.   
  5. Bitmap bmp = BitmapFactory.decodeFile(path, options);/* 这里返回的bmp是null */  

这段代码之后,options.outWidth 和 options.outHeight就是我们想要的宽和高了。

有了宽,高的信息,我们怎样在图片不变形的情况下获取到图片指定大小的缩略图呢?
比如我们需要在图片不变形的前提下得到宽度为200的缩略图。
那么我们需要先计算一下缩放之后,图片的高度是多少 ,代码如下

[java]  view plain copy print ?
  1. int height = options.outHeight * 200 / options.outWidth;  
  2.   
  3. options.outWidth = 200;  
  4.   
  5. options.outHeight = height;   
  6.   
  7. options.inJustDecodeBounds = false;  
  8.   
  9. Bitmap bmp = BitmapFactory.decodeFile(path, options);  
  10.   
  11. image.setImageBitmap(bmp);  

这样虽然我们可以得到我们期望大小的ImageView
但是在执行BitmapFactory.decodeFile(path, options);时,并没有节约内存。要想节约内存,还需要用到BitmapFactory.Options这个类里的 inSampleSize 这个成员变量。
我们可以根据图片实际的宽高和我们期望的宽高来计算得到这个值。

[java]  view plain copy print ?
  1. options.inSampleSize = options.outWidth / 200/*图片长宽方向缩小倍数*/  
另外,为了节约内存我们还可以使用下面的几个字段:
[java]  view plain copy print ?
  1. options.inDither=false;    /*不进行图片抖动处理*/  
  2. options.inPreferredConfig=null;  /*设置让解码器以最佳方式解码*/  
  3.   
  4. /* 下面两个字段需要组合使用 */  
  5.   
  6. options.inPurgeable = true;  
  7.   
  8. options.inInputShareable = true;  

版权声明:本文为博主原创文章,未经博主允许不得转载。

### 关于电阻和贴片电容的规格、封装和尺寸的记忆方法 #### 一、电阻的记忆技巧 ##### 1. 封装与尺寸 常见的贴片电阻(如厚膜式固定电阻器)有多种标准封装形式,这些封装通常由两个数字组成,表示长度和宽度。例如0402, 0603, 0805等,单位为英寸的一百分之一[^2]。 为了方便记忆不同型号的具体大小,可以采用谐音联想法。“零四零二”,听起来像“灵山寺佛”,想象一座小小的寺庙坐落在一片宁静之地;同样,“零六零三”可记作“溜达路上”,仿佛走在一条宽广的路上;至于“零八零五”,则能联想成“老爷爷舞剑”。 ##### 2. 阻值编码规则 对于色环电阻而言,存在特定的颜色对应不同的数值以及倍率关系。记住基本颜色顺序:棕(1), 红(2), 橙(3), 黄(4), 绿(5), 蓝(6), 紫(7), 灰(8), 白(9),这可以通过一句顺口溜来帮助记忆:“棕色红橙黄绿蓝紫灰白金”。而对于第四条或多出来的第五条色带,则分别代表误差范围或是额外的有效数字位置[^5]。 #### 二、贴片电容的记忆技巧 ##### 1. 类型区分 贴片电容主要包括陶瓷电容器和铝电解电容器两种主要类别。前者体积小巧且具备优秀的高频响应能力,适合用于信号处理等领域;后者虽然体型较大但拥有更高的容量等级,特别适用于电源管理等方面的应用场景[^3]。 ##### 2. 参数理解 - **容量**:陶瓷电容多见于pF至μF级别间变动,而铝电解电容可以从几个μF一直到数千μF以上; - **耐压值**:两者差异明显,其中陶瓷产品支持更高工作电压环境下的稳定运行,相比之下铝质品项则更适合低电压条件下的应用场合; - **频率特性**:由于内部结构上的区别使得二者在面对快速变化电信号时表现各异——陶瓷材质表现出更低ESR/ESL特征从而更适配高速度要求严格的线路设计之中; - **温度敏感性**:随着外界温差波动幅度增加,某些类型的铝电解件可能出现显著性能衰退现象,相反地,大多数情况下陶瓷类别的参数会保持较为恒定的状态不变。 通过上述描述可以看出,针对不同类型元器件特性的理解和掌握有助于加深对其外形尺寸及功能特点的印象,进而形成有效的记忆策略。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值