ListView异步加载图片是非常实用的方法,凡是是要通过网络获取图片资源一般使用这种方法比较好,用户体验好,下面就说实现方法,先贴上主方法的代码:
- packagecn.wangmeng.test;
- importjava.io.IOException;
- importjava.io.InputStream;
- importjava.lang.ref.SoftReference;
- importjava.net.MalformedURLException;
- importjava.net.URL;
- importjava.util.HashMap;
- importandroid.graphics.drawable.Drawable;
- importandroid.os.Handler;
- importandroid.os.Message;
- publicclassAsyncImageLoader{
- privateHashMap<String,SoftReference<Drawable>>imageCache;
- publicAsyncImageLoader(){
- imageCache=newHashMap<String,SoftReference<Drawable>>();
- }
- publicDrawableloadDrawable(finalStringimageUrl,finalImageCallbackimageCallback){
- if(imageCache.containsKey(imageUrl)){
- SoftReference<Drawable>softReference=imageCache.get(imageUrl);
- Drawabledrawable=softReference.get();
- if(drawable!=null){
- returndrawable;
- }
- }
- finalHandlerhandler=newHandler(){
- publicvoidhandleMessage(Messagemessage){
- imageCallback.imageLoaded((Drawable)message.obj,imageUrl);
- }
- };
- newThread(){
- @Override
- publicvoidrun(){
- Drawabledrawable=loadImageFromUrl(imageUrl);
- imageCache.put(imageUrl,newSoftReference<Drawable>(drawable));
- Messagemessage=handler.obtainMessage(0,drawable);
- handler.sendMessage(message);
- }
- }.start();
- returnnull;
- }
- publicstaticDrawableloadImageFromUrl(Stringurl){
- URLm;
- InputStreami=null;
- try{
- m=newURL(url);
- i=(InputStream)m.getContent();
- }catch(MalformedURLExceptione1){
- e1.printStackTrace();
- }catch(IOExceptione){
- e.printStackTrace();
- }
- Drawabled=Drawable.createFromStream(i,"src");
- returnd;
- }
- publicinterfaceImageCallback{
- publicvoidimageLoaded(DrawableimageDrawable,StringimageUrl);
- }
- }
以上代码是实现异步获取图片的主方法,SoftReference是软引用,是为了更好的为了系统回收变量,重复的URL直接返回已有的资源,实现回调函数,让数据成功后,更新到UI线程。
几个辅助类文件:
- packagecn.wangmeng.test;
- publicclassImageAndText{
- privateStringimageUrl;
- privateStringtext;
- publicImageAndText(StringimageUrl,Stringtext){
- this.imageUrl=imageUrl;
- this.text=text;
- }
- publicStringgetImageUrl(){
- returnimageUrl;
- }
- publicStringgetText(){
- returntext;
- }
- }
- packagecn.wangmeng.test;
- importandroid.view.View;
- importandroid.widget.ImageView;
- importandroid.widget.TextView;
- publicclassViewCache{
- privateViewbaseView;
- privateTextViewtextView;
- privateImageViewimageView;
- publicViewCache(ViewbaseView){
- this.baseView=baseView;
- }
- publicTextViewgetTextView(){
- if(textView==null){
- textView=(TextView)baseView.findViewById(R.id.text);
- }
- returntextView;
- }
- publicImageViewgetImageView(){
- if(imageView==null){
- imageView=(ImageView)baseView.findViewById(R.id.image);
- }
- returnimageView;
- }
- }
ViewCache是辅助获取adapter的子元素布局
- packagecn.wangmeng.test;
- importjava.util.List;
- importcn.wangmeng.test.AsyncImageLoader.ImageCallback;
- importandroid.app.Activity;
- importandroid.graphics.drawable.Drawable;
- importandroid.view.LayoutInflater;
- importandroid.view.View;
- importandroid.view.ViewGroup;
- importandroid.widget.ArrayAdapter;
- importandroid.widget.ImageView;
- importandroid.widget.ListView;
- importandroid.widget.TextView;
- publicclassImageAndTextListAdapterextendsArrayAdapter<ImageAndText>{
- privateListViewlistView;
- privateAsyncImageLoaderasyncImageLoader;
- publicImageAndTextListAdapter(Activityactivity,List<ImageAndText>imageAndTexts,ListViewlistView){
- super(activity,0,imageAndTexts);
- this.listView=listView;
- asyncImageLoader=newAsyncImageLoader();
- }
- publicViewgetView(intposition,ViewconvertView,ViewGroupparent){
- Activityactivity=(Activity)getContext();
- ViewrowView=convertView;
- ViewCacheviewCache;
- if(rowView==null){
- LayoutInflaterinflater=activity.getLayoutInflater();
- rowView=inflater.inflate(R.layout.image_and_text_row,null);
- viewCache=newViewCache(rowView);
- rowView.setTag(viewCache);
- }else{
- viewCache=(ViewCache)rowView.getTag();
- }
- ImageAndTextimageAndText=getItem(position);
- StringimageUrl=imageAndText.getImageUrl();
- ImageViewimageView=viewCache.getImageView();
- imageView.setTag(imageUrl);
- DrawablecachedImage=asyncImageLoader.loadDrawable(imageUrl,newImageCallback(){
- publicvoidimageLoaded(DrawableimageDrawable,StringimageUrl){
- ImageViewimageViewByTag=(ImageView)listView.findViewWithTag(imageUrl);
- if(imageViewByTag!=null){
- imageViewByTag.setImageDrawable(imageDrawable);
- }
- }
- });
- if(cachedImage==null){
- imageView.setImageResource(R.drawable.default_image);
- }else{
- imageView.setImageDrawable(cachedImage);
- }
- TextViewtextView=viewCache.getTextView();
- textView.setText(imageAndText.getText());
- returnrowView;
- }
- }
ImageAndTextListAdapter是实现ListView的Adapter,里面有个技巧就是imageView.setTag(imageUrl),setTag是存储数据的,这样是为了保证在回调函数时,listview去更新自己对应item,大家仔细阅读就知道了。
最后贴出布局文件:
- <?xmlversion="1.0"encoding="utf-8"?>
- <LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"
- android:orientation="horizontal"
- android:layout_width="fill_parent"
- android:layout_height="wrap_content">
- <ImageViewandroid:id="@+id/image"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- />
- <TextViewandroid:id="@+id/text"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"/>
- </LinearLayout>
分享到:
相关推荐
这里的“android listView 异步加载图片”指的是在不阻塞UI线程的情况下,从网络、本地存储或其他来源加载图片到ListView中的技术。 这篇名为“ImageLoader”的Java文件很可能就是一个实现图片异步加载的工具类。在...
本文实例讲述了Android实现Listview异步加载网络图片并动态更新的方法。分享给大家供大家参考,具体如下: 应用实例:解析后台返回的数据,把每条都显示在ListView中,包括活动图片、店名、活动详情、地址、电话和...
本文将深入探讨Android ListView中异步加载图片的策略、常见问题以及解决方案。 首先,我们要理解异步加载的基本原理。异步加载是指在后台线程中执行耗时操作,如加载图片,而主线程则继续处理用户交互,保证界面...
Android 异步加载图片,对ListView的异步加载图片的功能演示,主要根据url读取图片返回流的方法。为了方便演示,将请求图片的链接先固定,每读取好一个图片就更新,界面比较简单,当然你可以做成比较好的,像很多好...
为了解决这个问题,我们需要实现ListView的异步加载图片功能。本篇文章将详细介绍如何通过软引用缓存图片,实现高效、流畅的异步加载机制。 一、异步加载原理 异步加载的基本思想是将耗时的操作(如网络请求和图片...
本实例将详细讲解如何实现“Android ListView异步加载图片”,结合线程池、数据库和本地保存来优化性能。 首先,我们需要理解异步加载的概念。在Android中,由于主线程负责用户界面的更新,因此不应在主线程中执行...
因此,我们需要采用异步加载图片的方式,同时为了优化性能,通常会采用双缓存策略。本文将详细介绍如何在ListView中实现图片的异步加载,并且在用户拖动时不加载,以提高滚动流畅性。 一、异步加载原理 异步加载是...
因此,Android实现ListView异步加载图片是非常重要的优化手段。以下是对这个主题的详细解释。 1. **异步加载原理**: - 异步加载是指在后台线程中执行耗时操作,不阻塞主线程,从而提高应用的响应速度和流畅性。 ...
为了解决“android中ListView异步加载图片错位”这一问题,开发者可以采取以下几种策略: 1. 使用 ViewHolder 设计模式:ViewHolder模式能提高ListView的滚动性能,通过缓存convertView中的视图对象,避免了频繁的...
综上所述,实现ListView中的异步加载图片进度条,需要综合运用多线程、图片缓存、UI更新等技术,并遵循良好的代码组织和错误处理原则。通过合理的封装和接口设计,可以使得代码更加规范,同时也提升了用户体验。
10. **总结**:在Android的ListView中实现异步加载网络图片,需要结合异步处理框架、选择合适的图片库、优化缓存策略、合理管理内存,并对ListView进行优化。通过这些手段,可以显著提升应用的性能和用户体验。
通过以上方法,我们可以有效地解决Android ListView中异步加载图片时出现的图片错位问题,提供流畅且高效的用户体验。在实际开发中,应根据项目的具体需求,灵活运用各种策略,实现最佳的图片加载效果。
在本压缩包文件"listview异步加载.rar"中,我们很可能会找到关于如何实现ListView异步加载的相关资料。 在Android中,ListView的异步加载通常涉及以下几个关键知识点: 1. **Adapter**:Adapter是连接ListView与...
综上所述,实现Android中ListView全面完美的网络图片异步加载需要结合异步加载库(如Picasso或Glide)、LruCache缓存策略以及动态加载技术。这些方法的运用可以显著提升应用性能,为用户提供流畅的滚动体验,同时...
这个“android ListView异步加载图片示例”就是为了解决这个问题。 首先,我们要理解ListView的机制。ListView通过复用视图(convertView)来提高性能,即只有当前屏幕可见的几项会创建View,其余的View会在滚动时...