真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

ListView中怎么使用泛型適配器

這篇文章給大家介紹ListView中怎么使用泛型適配器,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。

成都創(chuàng)新互聯(lián)公司的客戶來自各行各業(yè),為了共同目標(biāo),我們?cè)诠ぷ魃厦芮信浜希瑥膭?chuàng)業(yè)型小企業(yè)到企事業(yè)單位,感謝他們對(duì)我們的要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來驚喜。專業(yè)領(lǐng)域包括網(wǎng)站設(shè)計(jì)、成都做網(wǎng)站、電商網(wǎng)站開發(fā)、微信營銷、系統(tǒng)平臺(tái)開發(fā)。

1.先創(chuàng)建好我們今天需要的控件、源數(shù)據(jù)以及Bean類。

控件只有一個(gè)ListView



  

beans方法模擬了一個(gè)假數(shù)據(jù)

private void beans() {
  list = new ArrayList<>();
  for (int i = 0; i < 16; i += 4) {
    list.add(new Student("同學(xué)" + i, "男", 15 + i, R.drawable.a, true));
    list.add(new Student("同學(xué)" + (i + 1), "男", 15 + i, R.drawable.b, false));
    list.add(new Student("同學(xué)" + (i + 2), "男", 15 + i, R.drawable.c, false));
    list.add(new Student("同學(xué)" + (i + 3), "男", 15 + i, R.drawable.d, true));
  }
}

這是bean類

package zy.pers.homework_20.bean;
public class Student {
  private String name;
  private String sex;
  private int age;
  private int imgId;
  private boolean isOver;
  public Student(String name, String sex, int age, int imgId,boolean isOver) {
    this.name = name;
    this.sex = sex;
    this.age = age;
    this.imgId = imgId;
    this.isOver = isOver;
  }
  public String getName() {
    return name;
  }
  public void setName(String name) {
    this.name = name;
  }
  public String getSex() {
    return sex;
  }
  public void setSex(String sex) {
    this.sex = sex;
  }
  public int getAge() {
    return age;
  }
  public void setAge(int age) {
    this.age = age;
  }
  public int getImgId() {
    return imgId;
  }
  public void setImgId(int imgId) {
    this.imgId = imgId;
  }
  @Override
  public String toString() {
    return "Student{" +
        "name='" + name + '\'' +
        ", sex='" + sex + '\'' +
        ", age=" + age +
        ", imgId=" + imgId +
        '}';
  }
  public boolean isOver() {
    return isOver;
  }
  public void setOver(boolean over) {
    isOver = over;
  }
}

2.創(chuàng)建MyBaseAdapter繼承BaseAdapter

public class MyBaseAdapter extends BaseAdapter {
  @Override
  public int getCount() {
    return 0;
  }
  @Override
  public Object getItem(int position) {
    return null;
  }
  @Override
  public long getItemId(int position) {
    return 0;
  }
  @Override
  public View getView(int position, View convertView, ViewGroup parent) {
    return null;
  }
}

3.我們說通用適配器傳入布局id和源數(shù)據(jù),所以我們定義這兩個(gè)量接收傳入的數(shù)據(jù)。

private List list;
private int mLayRes;
public MyBaseAdapter(List list, int mLayRes) {
  this.list= list;
  this.mLayRes = mLayRes;
}

4.重寫我們的前三個(gè)方法

前三個(gè)方法應(yīng)該算是比較簡(jiǎn)單的了,

@Override
public int getCount() {
  return list != null ? list.size() : 0;
}
@Override
public T getItem(int position) {
  return list.get(position);
}
@Override
public long getItemId(int position) {
  return position;
}

第一個(gè)一個(gè)簡(jiǎn)單的判斷,返回list的大小。第二個(gè)跟第三個(gè)和以前適配器一樣,只是getItem的返回值寫成了泛型。

5.寫Viewholder類,這個(gè)是很麻煩的,我們先創(chuàng)建出來Viewholder,之后的方法我們一步一步添加。

public static class ViewHolder {
  private SparseArray mViews = new SparseArray<>();
  private Context mContext;
  private int position;
  private int layRes;
  private View itemView;
 private ViewHolder(Context context, ViewGroup parent, int layRes) {
  this.mContext = context;
  this.layRes= layRes;
  this.itemView = LayoutInflater.from(context).inflate(layRes, parent, false);
  this.itemView.setTag(this);
 }
 public static ViewHolder bind(int position, View convertView, ViewGroup parent, int layRes, Context context) {
  ViewHolder holder;
  if (convertView == null) {
    holder = new ViewHolder(context, parent, layRes);
  } else {
    holder = (ViewHolder) convertView.getTag();
    holder.itemView = convertView;
  }
  holder.position = position;
  return holder;
}

東西有點(diǎn)多,我們順著邏輯慢慢看:

1)首先是通過單例來實(shí)現(xiàn),所以我們需要一個(gè)私有化構(gòu)造方法,里面有三個(gè)參數(shù),分別是上下文,ViewGroup和布局id,這三個(gè)屬性是我們必須要用到的,我們傳入上下文獲取inflater,把布局id傳進(jìn)去,然后把holder傳入我們的itemView中。

這一步我們應(yīng)該比較熟悉吧,我們以前是在getView中實(shí)現(xiàn)這一步的。

2)然后我們看下面的bind方法,他的參數(shù)有五個(gè)。其實(shí)有三個(gè)參數(shù)我們很熟悉,就是我們getView中的三個(gè)參數(shù)。在這基礎(chǔ)上我們又添加了兩個(gè)參數(shù),布局id和上下文。

然后為了優(yōu)化我們先判斷當(dāng)前的convertView是否為空,如果為空就新建一個(gè)Viewholder,讓convertView在私有構(gòu)造器中加載;如果不為空,直接通過getTag拿到。

注意我們要對(duì)holder中的兩個(gè)參數(shù)進(jìn)行修改,一個(gè)是itemView,一個(gè)是position。因?yàn)槲覀儍?yōu)化過后,如果convertView不為空,他里面是有之前的數(shù)據(jù)的,其他的幾個(gè)屬性我們不用管,但是這兩個(gè)還是儲(chǔ)存著上一個(gè)的內(nèi)容。我們需要讓他重新指向當(dāng)前的convertView和position,給大家畫一張圖就很明白了:

ListView中怎么使用泛型適配器

索引什么的畫的可能不準(zhǔn)確,但是主要就是這么個(gè)意思,大家領(lǐng)會(huì)精神哈。

最后返回holder。

3)我們還需要返回我們加載完成的convertView,

public View getItemView() {
  return itemView;
}

現(xiàn)在我們Viewholder基本框架寫完了,我們暫時(shí)不管他了,去寫getView。

6.重寫方法getView:

我們剛才說了,在adapter中寫一個(gè)抽象方法,然后通過回調(diào)方法,實(shí)現(xiàn)多類型適配,也就是說這個(gè)抽象方法是寫我們給具體控件添加數(shù)據(jù)的,我們?cè)谶@里面?zhèn)鬟f兩個(gè)參數(shù),一個(gè)是我們的Viewholder,另一個(gè)是對(duì)應(yīng)位置的數(shù)據(jù),類型為泛型。

public abstract void bindView(ViewHolder holder,T obj);

因?yàn)槲覀兂霈F(xiàn)了抽象方法,所以我們的MyBaseAdapter需要變成抽象類,

public abstract class MyBaseAdapter extends BaseAdapter {

這是我們的getView

@Override
public View getView(int position, View convertView, ViewGroup parent) {
  ViewHolder holder = ViewHolder.bind(position,convertView,parent,mLayRes,parent.getContext());
  bindView(holder,list.get(position));
  return holder.getItemView();
}

現(xiàn)在我們的適配器已經(jīng)完成百分之九十了,還差一點(diǎn),我們需要寫幾個(gè)輔助方法,為了方便我們等會(huì)進(jìn)行適配。

1.獲取指定控件

public  T getView(int id){
  T t = (T) mViews.get(id);
  if(t == null){
    t = itemView.findViewById(id);
    mViews.put(id,t);
  }
  return t;
}

在Viewholder中寫一個(gè)getView方法,通過控件id來獲取指定控件。

2.TextView控件輸入數(shù)據(jù)

public ViewHolder setText(int id,CharSequence text){
  View view = getView(id);
  if(view instanceof View){
    ((TextView)view).setText(text);
  }
  return this;
}

3.ImageView輸入圖片

public ViewHolder setImg(int id,int resId){
  View view = getView(id);
  if(view instanceof View){
    ((ImageView)view).setImageResource(resId);
  }else
    view.setBackgroundResource(resId);
  return this;
}

4.復(fù)選框輸入選定狀態(tài)

public ViewHolder setCheckable(int id,boolean checkable){
  View view = getView(id);
  if(view instanceof View){
    ((CheckBox)view).setChecked(checkable);
  }
  return this;
}

好啦,先在我們的適配器完全寫完了,我們來看一下效果吧。

private void initTools() {
  ListView mLv = (ListView) findViewById(R.id.mlv);
  adapter = new MyBaseAdapter(list,R.layout.item_one) {
    @Override
    public void bindView(ViewHolder holder, Student obj) {
      holder.setText(R.id.name,obj.getName())
          .setText(R.id.age,obj.getAge() + "")
          .setText(R.id.sex,obj.getSex())
          .setImg(R.id.head,obj.getImgId())
          .setCheckable(R.id.mc,obj.isOver());
    }
  };
  mLv.setAdapter(adapter);
}

關(guān)于ListView中怎么使用泛型適配器就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。


網(wǎng)頁題目:ListView中怎么使用泛型適配器
文章地址:http://weahome.cn/article/jedpdd.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部