BaseAdapter的使用

最近重新学了下BaseAdapter,发现之前学过之后还是不能熟练使用,应该是没有完全掌握的原因,并没有很好的理解BaseAdapter需要重新的四个方法,特别是getView()。

完整的类:

    public class MyAdapter extends BaseAdapter {

    private List<String> title;
    private LayoutInflater mInflater;

    public MyAdapter( Context context, List<String> title) {
        mInflater = LayoutInflater.from(context);
        this.title = title;
    }

    @Override
    public int getCount() {
        return title.size();
    }

    @Override
    public Object getItem(int position) {
        return title.get(position);
    }

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

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {

        ViewHolder viewHolder = new ViewHolder();
        if (convertView == null) {
            convertView = mInflater.inflate(R.layout.item, null);
            viewHolder.textView = (TextView) convertView.findViewById(R.id.title);
            convertView.setTag(viewHolder);
        } else {
            viewHolder = (ViewHolder) convertView.getTag();
        }
        viewHolder.textView.setText(title.get(position));
        return convertView;
    }

    class ViewHolder {
        public TextView textView;
    }
}

有四个方法需要重写:1,getCount()

    /**
     * 决定了listview一共有多少个item
     */
    @Override
    public int getCount() {
        title.size();
    }

2,getItem()

    /**
     * setOnItemClickListener、setOnItemLongClickListener、
     * setOnItemSelectedListener的点击选择处理事件中通过AdapterView的
     * getItemAtPosition(position)调用此方法
     */
      @Override
    public Object getItem(int position) {
        return title.get(position);
    }

3,getItemId()

 /**
     * 某些方法(如onclicklistener的onclick方法)有id这个参数,而这个id
     * 参数就是取决于getItemId()这个返回值的
     */
 @Override
    public long getItemId(int position) {
        return position;
    }

4,getView() (最重要的方法)

    /**
     * 当界面每显示出来一个item时,就会调用该方法,getView()有三个参数,第一个参数表示该item在Adapter中的位置;
     * 第二个参数是item的View对象,是滑动list时将要显示在界面上的item,如果有item在显示界面消失,这时
     * android会将消失的item返回,称为旧view,也就是说此时的view不为null;第三个参数用在加载xml视图。
     */
      @Override
    public View getView(int position, View convertView, ViewGroup parent) {

        ViewHolder viewHolder = null;
        if (convertView == null) {//(convertView 为缓存的item view)当滑动list时,如果没有item消失(应该是没有任何操作,保存当前的实例),
            viewHolder = new ViewHolder();
            // 这时参数对象view是没有任何指向的,为null
            convertView = mInflater.inflate(R.layout.item, null);
            viewHolder.textView = (TextView) convertView.findViewById(R.id.title);
            convertView.setTag(viewHolder);
        } else { //如果有旧的view对象返回(该情况是滑动list时有item消失),从该 view中提取已经创建的
            // textview对象,达到对象循环使用
            viewHolder = (ViewHolder) convertView.getTag();
        }
        viewHolder.textView.setText(title.get(position));
        return convertView;
    }
ViewHolder类,为了性能优化
    /**
     * //该类用来暂存textView和ImageView的实例化对象,达到循环使用
     */
     class ViewHolder {
        public TextView textView;
    }

一个带参数的构造方法,这里是为了拿到数据和context(LayoutInflater需要context)

public MyAdapter( Context context, List<String> title) {
        mInflater = LayoutInflater.from(context);
        this.title = title;
    }

再看看Activity的代码,比较简单,结合注释一目了然

public class MainActivity extends AppCompatActivity {

    private ListView mListview;
    private List<String> title;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        mListview = (ListView) findViewById(R.id.list_view);
        title = new ArrayList<>();
        Bean bean = new Bean(title);

        for (int i = 0; i <20; i++) {
            bean.title.add("标题" + i); //bean类将数据封装起来
        }
        //通过构造方法将context(LayoutInflater需要context),和数据传递到adapter
        MyAdapter myAdapter = new MyAdapter(this, bean.title);
        mListview.setAdapter(myAdapter);

    }
}

完整的项目还需要两个XML文件(item和带有listview的XML),自行补脑就可以写出来了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值