android 缓存本地图片路径,android异步加载图片并缓存到本地实现方法

图片过多形成内存溢出,这个是最不容易解决的,要想一些好的缓存策略,好比大图片使用LRU缓存策略或懒加载缓存策略。今天首先介绍一下本地缓存图片。java

在android项目中访问网络图片是很是广泛性的事情,若是咱们每次请求都要访问网络来获取图片,会很是耗费流量,并且图片占用内存空间也比较大,图片过多且不释放的话很容易形成内存溢出。针对上面遇到的两个问题,首先耗费流量咱们能够将图片第一次加载上面缓存到本地,之后若是本地有就直接从本地加载。图片过多形成内存溢出,这个是最不容易解决的,要想一些好的缓存策略,好比大图片使用LRU缓存策略或懒加载缓存策略。今天首先介绍一下本地缓存图片。 首先看一下异步加载缓存本地代码:android

publicclassAsyncBitmapLoader

{

/**

*内存图片软引用缓冲

*/

privateHashMap>imageCache=null;

publicAsyncBitmapLoader()

{

imageCache=newHashMap>();

}

publicBitmaploadBitmap(finalImageViewimageView,finalStringimageURL,finalImageCallBackimageCallBack)

{

//在内存缓存中,则返回Bitmap对象

if(imageCache.containsKey(imageURL))

{

SoftReferencereference=imageCache.get(imageURL);

Bitmapbitmap=reference.get();

if(bitmap!=null)

{

returnbitmap;

}

}

else

{

/**

*加上一个对本地缓存的查找

*/

StringbitmapName=imageURL.substring(imageURL.lastIndexOf("/")+1);

FilecacheDir=newFile("/mnt/sdcard/test/");

File[]cacheFiles=cacheDir.listFiles();

inti=0;

if(null!=cacheFiles){

for(;i

{

if(bitmapName.equals(cacheFiles[i].getName()))

{

break;

}

}

if(i

{

returnBitmapFactory.decodeFile("/mnt/sdcard/test/"+bitmapName);

}

}

}

finalHandlerhandler=newHandler()

{

/*(non-Javadoc)

*@seeandroid.os.Handler#handleMessage(android.os.Message)

*/

@Override

publicvoidhandleMessage(Messagemsg)

{

//TODOAuto-generatedmethodstub

imageCallBack.imageLoad(imageView,(Bitmap)msg.obj);

}

};

//若是不在内存缓存中,也不在本地(被jvm回收掉),则开启线程下载图片

newThread()

{

/*(non-Javadoc)

*@seejava.lang.Thread#run()

*/

@Override

publicvoidrun()

{

//TODOAuto-generatedmethodstub

InputStreambitmapIs=HttpUtils.getStreamFromURL(imageURL);

Bitmapbitmap=BitmapFactory.decodeStream(bitmapIs);

imageCache.put(imageURL,newSoftReference(bitmap));

Messagemsg=handler.obtainMessage(0,bitmap);

handler.sendMessage(msg);

Filedir=newFile("/mnt/sdcard/test/");

if(!dir.exists())

{

dir.mkdirs();

}

FilebitmapFile=newFile("/mnt/sdcard/test/"+

imageURL.substring(imageURL.lastIndexOf("/")+1));

if(!bitmapFile.exists())

{

try

{

bitmapFile.createNewFile();

}

catch(IOExceptione)

{

//TODOAuto-generatedcatchblock

e.printStackTrace();

}

}

FileOutputStreamfos;

try

{

fos=newFileOutputStream(bitmapFile);

bitmap.compress(Bitmap.CompressFormat.PNG,

100,fos);

fos.close();

}

catch(FileNotFoundExceptione)

{

//TODOAuto-generatedcatchblock

e.printStackTrace();

}

catch(IOExceptione)

{

//TODOAuto-generatedcatchblock

e.printStackTrace();

}

}

}.start();

returnnull;

}

publicinterfaceImageCallBack

{

publicvoidimageLoad(ImageViewimageView,Bitmapbitmap);

}

}

这是一个封装好的异步加载图片类,缓存了两份,一份是使用软引用缓存到内存中,一份是缓存到本地sd卡,若是内存中没有,则从本地查找,若是本地没有则从网络获取图片。

publicclassHttpUtils{

publicstaticInputStreamgetStreamFromURL(StringimageURL){

InputStreamin=null;

try{

URLurl=newURL(imageURL);

HttpURLConnectionconnection=(HttpURLConnection)url.openConnection();

in=connection.getInputStream();

}catch(Exceptione){

//TODOAuto-generatedcatchblock

e.printStackTrace();

}

returnin;

}

}

这是一个访问网络获取类。不细说了。

下面看一下如何使用封装好的异步加载图片的类:

publicclassImageCacheActivityextendsActivity{

/**Calledwhentheactivityisfirstcreated.*/

privateListViewlistview;

@Override

publicvoidonCreate(BundlesavedInstanceState){

super.onCreate(savedInstanceState);

setContentView(R.layout.main);

listview=(ListView)findViewById(R.id.listView_list);

MyAdapteradapter=newMyAdapter();

listview.setAdapter(adapter);

}

privateclassMyAdapterextendsBaseAdapter{

privateAsyncBitmapLoaderasyncBitmapLoader;

publicMyAdapter(){

asyncBitmapLoader=newAsyncBitmapLoader();

}

@Override

publicintgetCount(){

//TODOAuto-generatedmethodstub

return10;

}

@Override

publicObjectgetItem(intposition){

//TODOAuto-generatedmethodstub

returnnull;

}

@Override

publiclonggetItemId(intposition){

//TODOAuto-generatedmethodstub

return0;

}

@Override

publicViewgetView(intposition,ViewconvertView,ViewGroupparent){

//TODOAuto-generatedmethodstub

if(convertView==null){

convertView=LayoutInflater.from(getApplicationContext()).inflate(R.layout.list_item,null);

}

ImageViewimage=(ImageView)convertView.findViewById(R.id.addexam_list_icon);

StringimageURL="http://s.ata.net.cn/4f98db46908987a21a000003/logo/2012/04/114_80aaf295c083d07a496743699aac3193.png";

Bitmapbitmap=asyncBitmapLoader.loadBitmap(image,imageURL,newImageCallBack(){

@Override

publicvoidimageLoad(ImageViewimageView,Bitmapbitmap){

//TODOAuto-generatedmethodstub

imageView.setImageBitmap(bitmap);

}

});

if(bitmap==null)

{

image.setImageResource(R.drawable.ic_launcher);

}

else

{

image.setImageBitmap(bitmap);

}

returnconvertView;

}

}

}

这样就完成了,网络获取不到bitmap则显示默认图片。

abacd6ee23734b4694b742a1.html 这是一种很实用的方法,你们本身试试吧!缓存

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值