ListView Adapter优化 实例

代码如下:

//方案一 - adapter优化public class listviewAdapterDemo1 extends BaseAdapter {

private String[] mArrData;
    private ListView listView;
    private AsyncImageLoader asyncImageLoader;
    private final LayoutInflater inflater;

public listviewAdapterDemo1(String[] mArrData, Context mContext, ListView listView) {
        this.mArrData = mArrData;
        this.listView = listView;
        asyncImageLoader = new AsyncImageLoader();
        inflater = (LayoutInflater) mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    }

@Override
    public int getCount() {
        return this.mArrData.length;
    }

@Override
    public Object getItem(int arg0) {
        return mArrData[arg0];
    }

@Override
    public long getItemId(int position) {
        return position;
    }

/***
     * 1.控件对象内存为一个
     * 2.view对象只会创建可视对象次数(有的是8次)根据屏幕可视listview的数量而定,在加载超过可视postion数据时不会重新创建
     *   但是需要每次重新加载数据
     *  
     *   从节省内存的角度出发,这种更合理,毕竟加载数据不需要占用内存
     */
    @Override
    public View getView(int position, View convertView, ViewGroup parent) {

ViewHolder viewholder;
        Log.d("dd", "Position:" + position+"------");
        if (convertView == null) {
            Log.d("dd", "Position:" + position);
            convertView = inflater.inflate(R.layout.list_item_icon_text, null);
            viewholder = new ViewHolder();
            viewholder.icon = (ImageView) convertView.findViewById(R.id.icon);
            viewholder.text = (TextView) convertView.findViewById(R.id.text);

convertView.setTag(viewholder);
        } else {
            viewholder = (ViewHolder) convertView.getTag();
        }

viewholder.text.setText(mArrData[position]);
        // Load the image and set it on the ImageView
        String imageUrl = "";
        viewholder.icon.setTag(imageUrl);
        Drawable cachedImage = asyncImageLoader.loadDrawable(imageUrl, new ImageCallback() {

public void imageLoaded(Drawable imageDrawable, String imageUrl) {
                ImageView imageViewByTag = (ImageView) listView.findViewWithTag(imageUrl);
                if (imageViewByTag != null) {
                    imageViewByTag.setImageDrawable(imageDrawable);
                }
            }
        });
        if (cachedImage != null)//说明是从缓存池中得到
            viewholder.icon.setImageDrawable(cachedImage);

return convertView;
    }

static class ViewHolder {
        ImageView icon;
        TextView text;
    }
}

在listview中的getview方法中也可以这样用这个方法:


代码如下:

public Drawable getDrawable(AsyncImageLoader asyncImageLoader, String imageUrl, final ImageView imageView) {
Drawable drawable = asyncImageLoader.loadDrawable(imageUrl,new ImageCallback() {
@Override public void imageLoaded(Drawable imageDrawable,String imageUrl) {
if (imageDrawable != null)
imageView.setImageDrawable(imageDrawable);
else
imageView.setImageResource(R.drawable.u6_normal);
}
});
return drawable;
}

代码如下:

//方案二---adapter的优化public class listviewAdapterDemo2 extends BaseAdapter {

private String[] mArrData;
    private ListView listView;
    private AsyncImageLoader asyncImageLoader;
    private final LayoutInflater inflater;
    private Map<Integer, View> viewMap = new HashMap<Integer, View>();

public listviewAdapterDemo2(String[] mArrData, Context mContext, ListView listView) {
        this.mArrData = mArrData;
        this.listView = listView;
        asyncImageLoader = new AsyncImageLoader();
        inflater = (LayoutInflater) mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    }

@Override
    public int getCount() {
        return this.mArrData.length;
    }

@Override
    public Object getItem(int arg0) {
        return mArrData[arg0];
    }

@Override
    public long getItemId(int position) {
        return position;
    }

/**
     * 1.控件对象内存为一个
     * 2.每一个postion对应一个view,且不管前进后退,每个postion数据只加载一次   * 但是从节省内容的角度出发,方案一更节省内存
     */
    @Override
    public View getView(int position, View convertView, ViewGroup parent) {

ViewHolder viewholder;
        Log.d("dd", "Position:" + position+"------");
        convertView = this.viewMap.get(position);
        if (convertView == null) {
            Log.d("dd", "Position:" + position);
            convertView = inflater.inflate(R.layout.list_item_icon_text, null);
            viewholder = new ViewHolder();
            viewholder.icon = (ImageView) convertView.findViewById(R.id.icon);
            viewholder.text = (TextView) convertView.findViewById(R.id.text);

viewholder.text.setText(mArrData[position]);
            // Load the image and set it on the ImageView
            String imageUrl = "";
            viewholder.icon.setTag(imageUrl);
            Drawable cachedImage = asyncImageLoader.loadDrawable(imageUrl, new ImageCallback() {

public void imageLoaded(Drawable imageDrawable, String imageUrl) {
                    ImageView imageViewByTag = (ImageView) listView.findViewWithTag(imageUrl);
                    if (imageViewByTag != null) {
                        imageViewByTag.setImageDrawable(imageDrawable);
                    }
                }
            });
            if (cachedImage != null)//说明是从缓存池中得到
                viewholder.icon.setImageDrawable(cachedImage);

convertView.setTag(viewholder);
            viewMap.put(position, convertView);
        } else {
            viewholder = (ViewHolder) convertView.getTag();
        }
        return convertView;
    }

static class ViewHolder {
        ImageView icon;
        TextView text;
    }
}

代码如下:

/**图片下载-adpater优化*/
public class AsyncImageLoader {

private HashMap<String, SoftReference<Drawable>> imageCache;

public AsyncImageLoader() { 
        imageCache = new HashMap<String, SoftReference<Drawable>>(); 
    }

public Drawable loadDrawable(final String imageUrl, final ImageCallback imageCallback) { 
        //从缓存中检测是否存在
        if (imageCache.containsKey(imageUrl)) { 
            SoftReference<Drawable> softReference = imageCache.get(imageUrl); 
            Drawable drawable = softReference.get(); 
            if (drawable != null) { 
                return drawable; 
            } 
        } 
        final Handler handler = new Handler() { 
            @Override 
            public void handleMessage(Message message) { 
                imageCallback.imageLoaded((Drawable) message.obj, imageUrl); 
            } 
        }; 
        //缓存中没有则从服务器下载
        new Thread() { 
            @Override 
            public void run() { 
                Drawable drawable = loadImageFromUrl(imageUrl); 
                imageCache.put(imageUrl, new SoftReference<Drawable>(drawable)); 
                Message message = handler.obtainMessage(0, drawable); 
                handler.sendMessage(message); 
            } 
        }.start();

return null; 
    }

public static Drawable loadImageFromUrl(String url) { 
        Drawable drawable = null;
        //根据url从服务器下载图片
        return drawable;
    }

public interface ImageCallback { 
        public void imageLoaded(Drawable imageDrawable, String imageUrl); 
    } 
}

代码如下:

//activity---adapterpublic class ListviewDemoActivity extends Activity {

private listviewAdapterDemo1 mAdapter;
    private ListView listview;
    private String[] mArrData;

@Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

mArrData = new String[1000];
        for (int i = 0; i < 1000; i++) {
            mArrData[i] = "Google IO Adapter" + i;
        }

listview = (ListView)findViewById(R.id.lv);
        mAdapter = new listviewAdapterDemo1(mArrData,this,listview);
        listview.setAdapter(mAdapter);
    }
}

在main.xml中插入


代码如下:

<ListView
        android:id="@+id/lv"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:layout_weight="1" />

(0)

相关推荐

  • android开发中ListView与Adapter使用要点介绍

    1. Adapter.getView() public View getView(int position, View convertView , ViewGroup parent){...} 这个方法就是用来获得指定位置要显示的View.官网解释如下: Get a View that displays the data at the specified position in the data set. You can either create a View manually or infl

  • Android ListView适配器(Adapter)优化方法详解

    Android ListView的优化,在做Android项目的时候,在用到ListView 界面及数据显示,这个时候如果资源过大,对项目来说,用户体验肯定是不好的,这里就对如何优化做了详细介绍: Adapter的作用就是ListView界面与数据之间的桥梁,当列表里的每一项显示到页面时,都会调用Adapter的getView方法返回一个View.想过没有? 在我们的列表有1000000项时会是什么样的?是不是会占用极大的系统资源? ListView的Adapter的作用如下图所示: 先看看下面

  • ListView的Adapter使用 之 初学ArrayAdapter String

    ListView是Android中经常会使用的东西,绑定数据对于初学者来说,尤其是刚接触编程的人来说,往往会觉得很难理解,我上大二的时候学的java,但是基本上相当于没有学,什么都没写过,真正接触编程就是开始上手学android,把这些记录下来,自己可以回头看下,也可以让新手更好的理解.高手绕过.... Android中Adapter我是这么理解的,是数据和视图之间的桥梁,数据在adapter中做处理,然后显示到视图上面. Adapter有很多种,有ArrayAdapter<T>, BaseA

  • ListView的Adapter使用(绑定数据) 之 自定义每一项的布局去绑定数据

    大家先看第一个例子显示: 这个界面相信大家都看到过的,这次比上一个例子多的是ListView 的每一项绑定的是不再是单纯的一个字符串了,ListView 的每一个条目我们需要显示两个信息,编号和姓名.可以看到,我们绑定了十条数据,用了一个for 循环,每一条绑定的时候创建一个HashMap,然后往里面放数据,放的数据有相对应的key, 即id,name,到时候我们取数据的时候就根据这个key 找到我们放进去的数据,有点类似与键值对的意思,不知道这样解释大家明白不明白. 贴上源代码,然后接下来讲解

  • Android开发中ListView自定义adapter的封装

    [引入] 我们一般编写listView的时候顺序是这样的:  •需要展示的数据集List<T>  •为这个数据集编写一个ListView  •为这个ListView编写一个Adapter,一般继承自BaseAdapter  •在BaseAdapter内部编写一个ViewHolder类,对应ListView里面的item控件,提高控件的查询效率 分析: List<T>:ListView --> Adapter extends BaseAdapter --> ViewHol

  • Android ListView自定义Adapter实现仿QQ界面

    PS:listview中有一些简单使用的适配器,如:SimpleAdapter:构造方法SimpleAdapter(Context context,List<Map<String,?>> data,reString [] from,int [] to),但这种适配器过于单调,往往不能达到用户想要的效果,想要随心所欲,就用到了BaseAdapter,自定义适配器. 如图: 1.首先写布局文件 activity_layout.xml <?xml version="1.0

  • 揭秘在ListView等AdapterView上动态添加删除项的陷阱

    如何避开在ListView等AdapterView上动态添加删除项的陷阱,下面就为大家分享,具体内容如下 首先,定义如下array资源,作为列表的加载内容: <resources> <string name="app_name">MyListView</string> <string-array name="language"> <item>Java</item> <item>C&l

  • Android自定义Adapter的ListView的思路及代码

    在开发中,我们经常使用到ListView这个控件.Android的API也提供了许多创建ListView适配器的快捷方式.例如ArrayAdapter.SimpleAdapter和SimpleCursorAdapter等.但你是否发现,如果采用这些系统自带的适配器,对于事件的响应只能局限在一个行单位.假设一行里面有一个按钮和一个图片控件,它们之间的响应操作是不一样的.若采用系统自带的适配器,就不能精确到每个控件的响应事件.这时,我们一般采取自定义适配器来实现这个比较精确地请求. ListView

  • Android listview与adapter详解及实例代码

    一个ListView通常有两个职责. (1)将数据填充到布局. (2)处理用户的选择点击等操作. 第一点很好理解,ListView就是实现这个功能的.第二点也不难做到,在后面的学习中读者会发现,这非常简单. 一个ListView的创建需要3个元素. (1)ListView中的每一列的View. (2)填入View的数据或者图片等. (3)连接数据与ListView的适配器. 也就是说,要使用ListView,首先要了解什么是适配器.适配器是一个连接数据和AdapterView(ListView就

  • Adapter实现ListView带多选框等状态的自定义控件的注意事项

    Android本身为ListView提供了几个方便的Adapter,比如ArrayAdapter.SimpleCurrentAdapter等等.但是为了实现更复杂的列表视图和控制,一般都要继承BaseAdapter来实现自己的Adapter. 我需要的ListView是如图一样的实现SD卡资源文件浏览列表,每个列表项由一个ImageView.TextView.CheckBox组成,并且要求当整个列表中有一个或一个以上的Checkbox被选中时,右上角的搜索按钮就显示出来,否则就隐藏,因此需要对每

随机推荐