国产chinesehdxxxx野外,国产av无码专区亚洲av琪琪,播放男人添女人下边视频,成人国产精品一区二区免费看,chinese丰满人妻videos

Android 構(gòu)建一個(gè)可復(fù)用的自定義BaseAdapter

2023-03-31 13:42 更新

本節(jié)引言:

如題,本節(jié)給大家?guī)淼氖菢?gòu)建一個(gè)可復(fù)用的自定義BaseAdapter,我們每每涉及到ListView GridView等其他的Adapter控件,都需要自己另外寫一個(gè)BaseAdapter類,這樣顯得非常麻煩, 又比如,我們想在一個(gè)界面顯示兩個(gè)ListView的話,我們也是需要些兩個(gè)BaseAdapter... 這,程序員都是喜歡偷懶的哈,這節(jié)我們就來寫一個(gè)可復(fù)用的自定義BaseAdapter類~


1.我們一點(diǎn)點(diǎn)開始改:

首先我們把上節(jié)寫的自定義BaseAdapter貼下,等下我們就要對(duì)他進(jìn)行升級(jí)改造

/**
 * Created by Jay on 2015/9/21 0021.
 */
public class MyAdapter extends BaseAdapter {

    private Context mContext;
    private LinkedList<Data> mData;

    public MyAdapter() {
    }

    public MyAdapter(LinkedList<Data> mData, Context mContext) {
        this.mData = mData;
        this.mContext = mContext;
    }

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

    @Override
    public Object getItem(int position) {
        return null;
    }

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

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        ViewHolder holder = null;
        if (convertView == null) {
            convertView = LayoutInflater.from(mContext).inflate(R.layout.item_list, parent, false);
            holder = new ViewHolder();
            holder.img_icon = (ImageView) convertView.findViewById(R.id.img_icon);
            holder.txt_content = (TextView) convertView.findViewById(R.id.txt_content);
            convertView.setTag(holder);
        } else {
            holder = (ViewHolder) convertView.getTag();
        }
        holder.img_icon.setImageResource(mData.get(position).getImgId());
        holder.txt_content.setText(mData.get(position).getContent());
        return convertView;
    }

    //添加一個(gè)元素
    public void add(Data data) {
        if (mData == null) {
            mData = new LinkedList<>();
        }
        mData.add(data);
        notifyDataSetChanged();
    }

    //往特定位置,添加一個(gè)元素
    public void add(int position,Data data){
        if (mData == null) {
            mData = new LinkedList<>();
        }
        mData.add(position, data);
        notifyDataSetChanged();
    }

    public void remove(Data data) {
        if(mData != null) {
            mData.remove(data);
        }
        notifyDataSetChanged();
    }

    public void remove(int position) {
        if(mData != null) {
            mData.remove(position);
        }
        notifyDataSetChanged();
    }

    public void clear() {
        if(mData != null) {
            mData.clear();
        }
        notifyDataSetChanged();
    }

    private class ViewHolder {
        ImageView img_icon;
        TextView txt_content;
    }

}

升級(jí)1:將Entity設(shè)置成泛型

好的,畢竟我們傳遞過來的Entitiy實(shí)體類可能千奇百怪,比如有Person,Book,Wether等,所以我們 將Entity設(shè)置成泛型,修改后的代碼如下:

<pre>
public class MyAdapter<T> extends BaseAdapter {

    private Context mContext;
    private LinkedList<T> mData;

    public MyAdapter() {
    }

    public MyAdapter(LinkedList<T> mData, Context mContext) {
        this.mData = mData;
        this.mContext = mContext;
    }

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

    @Override
    public Object getItem(int position) {
        return null;
    }

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

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        ViewHolder holder = null;
        if (convertView == null) {
            convertView = LayoutInflater.from(mContext).inflate(R.layout.item_list, parent, false);
            holder = new ViewHolder();
            holder.img_icon = (ImageView) convertView.findViewById(R.id.img_icon);
            holder.txt_content = (TextView) convertView.findViewById(R.id.txt_content);
            convertView.setTag(holder);
        } else {
            holder = (ViewHolder) convertView.getTag();
        }
        holder.img_icon.setImageResource(mData.get(position).getImgId());
        holder.txt_content.setText(mData.get(position).getContent());
        return convertView;
    }

    //添加一個(gè)元素
    public void add(T data) {
        if (mData == null) {
            mData = new LinkedList<>();
        }
        mData.add(data);
        notifyDataSetChanged();
    }

    //往特定位置,添加一個(gè)元素
    public void add(int position,T data){
        if (mData == null) {
            mData = new LinkedList<>();
        }
        mData.add(position, data);
        notifyDataSetChanged();
    }

    public void remove(T data) {
        if(mData != null) {
            mData.remove(data);
        }
        notifyDataSetChanged();
    }

    public void remove(int position) {
        if(mData != null) {
            mData.remove(position);
        }
        notifyDataSetChanged();
    }

    public void clear() {
        if(mData != null) {
            mData.clear();
        }
        notifyDataSetChanged();
    }

    private class ViewHolder {
        ImageView img_icon;
        TextView txt_content;
    }

}

好的,上面我們做的事僅僅是將Data類型換成了泛型T!


升級(jí)2:ViewHolder類的升級(jí)改造:

我們先來看看前面我們的ViewHolder干了什么? 答:findViewById,設(shè)置控件狀態(tài); 下面我們想在完成這個(gè)基礎(chǔ)上,將getView()方法大部分的邏輯寫到ViewHolder類里, 這個(gè)ViewHolder要做的事:

  • 定義一個(gè)查找控件的方法,我們的思路是通過暴露公共的方法,調(diào)用方法時(shí)傳遞過來 控件id,以及設(shè)置的內(nèi)容,比如TextView設(shè)置文本: public ViewHolder setText(int id, CharSequence text){文本設(shè)置}
  • 將convertView復(fù)用部分搬到這里,那就需要傳遞一個(gè)context對(duì)象了,我們把需要獲取 的部分都寫到構(gòu)造方法中!
  • 寫一堆設(shè)置方法(public),比如設(shè)置文字大小顏色,圖片背景等!

好的,接下來我們就來一步步改造我們的ViewHolder類


1)相關(guān)參數(shù)與構(gòu)造方法:

public static class ViewHolder {

    private SparseArray<View> mViews;   //存儲(chǔ)ListView 的 item中的View
    private View item;                  //存放convertView
    private int position;               //游標(biāo)
    private Context context;            //Context上下文

    //構(gòu)造方法,完成相關(guān)初始化
    private ViewHolder(Context context, ViewGroup parent, int layoutRes) {
        mViews = new SparseArray<>();
        this.context = context;
        View convertView = LayoutInflater.from(context).inflate(layoutRes, parent,false);
        convertView.setTag(this);
        item = convertView;
    }

    ImageView img_icon;
    TextView txt_content;
}

2)綁定ViewHolder與Item

在上面的基礎(chǔ)上我們?cè)偬砑右粋€(gè)綁定的方法

//綁定ViewHolder與item
public static ViewHolder bind(Context context, View convertView, ViewGroup parent,
                              int layoutRes, int position) {
    ViewHolder holder;
    if(convertView == null) {
        holder = new ViewHolder(context, parent, layoutRes);
    } else {
        holder = (ViewHolder) convertView.getTag();
        holder.item = convertView;
    }
    holder.position = position;
    return holder;
}

3)根據(jù)id獲取集合中保存的控件

public <T extends View> T getView(int id) {
    T t = (T) mViews.get(id);
    if(t == null) {
        t = (T) item.findViewById(id);
        mViews.put(id, t);
    }
    return t;
}

4) 接著我們?cè)俣x一堆暴露出來的方法

/**
 * 獲取當(dāng)前條目
 */
public View getItemView() {
    return item;
}

/**
 * 獲取條目位置
 */
public int getItemPosition() {
    return position;
}

/**
 * 設(shè)置文字
 */
public ViewHolder setText(int id, CharSequence text) {
    View view = getView(id);
    if(view instanceof TextView) {
        ((TextView) view).setText(text);
    }
    return this;
}

/**
 * 設(shè)置圖片
 */
public ViewHolder setImageResource(int id, int drawableRes) {
    View view = getView(id);
    if(view instanceof ImageView) {
        ((ImageView) view).setImageResource(drawableRes);
    } else {
        view.setBackgroundResource(drawableRes);
    }
    return this;
}

/**
 * 設(shè)置點(diǎn)擊監(jiān)聽
 */
public ViewHolder setOnClickListener(int id, View.OnClickListener listener) {
    getView(id).setOnClickListener(listener);
    return this;
}

/**
 * 設(shè)置可見
 */
public ViewHolder setVisibility(int id, int visible) {
    getView(id).setVisibility(visible);
    return this;
}

/**
 * 設(shè)置標(biāo)簽
 */
public ViewHolder setTag(int id, Object obj) {
    getView(id).setTag(obj);
    return this;
}

//其他方法可自行擴(kuò)展

好的,ViewHolder的改造升級(jí)完成~


升級(jí)3:定義一個(gè)抽象方法,完成ViewHolder與Data數(shù)據(jù)集的綁定

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

我們創(chuàng)建新的BaseAdapter的時(shí)候,實(shí)現(xiàn)這個(gè)方法就好,另外,別忘了把我們自定義 的BaseAdapter改成abstact抽象的!


升級(jí)4:修改getView()部分的內(nèi)容

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

2.升級(jí)完畢,我們寫代碼來體驗(yàn)下:

我們要實(shí)現(xiàn)的效果圖:

就是上面有兩個(gè)列表,布局不一樣,但是我只使用一個(gè)BaseAdapter類來完成上述效果!

關(guān)鍵代碼如下:

MainActivity.java

public class MainActivity extends AppCompatActivity {

    private Context mContext;
    private ListView list_book;
    private ListView list_app;

    private MyAdapter<App> myAdapter1 = null;
    private MyAdapter<Book> myAdapter2 = null;
    private List<App> mData1 = null;
    private List<Book> mData2 = null;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mContext = MainActivity.this;
        init();

    }

    private void init() {

        list_book = (ListView) findViewById(R.id.list_book);
        list_app = (ListView) findViewById(R.id.list_app);

        //數(shù)據(jù)初始化
        mData1 = new ArrayList<App>();
        mData1.add(new App(R.mipmap.iv_icon_baidu,"百度"));
        mData1.add(new App(R.mipmap.iv_icon_douban,"豆瓣"));
        mData1.add(new App(R.mipmap.iv_icon_zhifubao,"支付寶"));

        mData2 = new ArrayList<Book>();
        mData2.add(new Book("《第一行代碼Android》","郭霖"));
        mData2.add(new Book("《Android群英傳》","徐宜生"));
        mData2.add(new Book("《Android開發(fā)藝術(shù)探索》","任玉剛"));

        //Adapter初始化
        myAdapter1 = new MyAdapter<App>((ArrayList)mData1,R.layout.item_one) {
            @Override
            public void bindView(ViewHolder holder, App obj) {
                holder.setImageResource(R.id.img_icon,obj.getaIcon());
                holder.setText(R.id.txt_aname,obj.getaName());
            }
        };
        myAdapter2 = new MyAdapter<Book>((ArrayList)mData2,R.layout.item_two) {
            @Override
            public void bindView(ViewHolder holder, Book obj) {
                holder.setText(R.id.txt_bname,obj.getbName());
                holder.setText(R.id.txt_bauthor,obj.getbAuthor());
            }
        };

        //ListView設(shè)置下Adapter:
        list_book.setAdapter(myAdapter2);
        list_app.setAdapter(myAdapter1);

    }

}

我們寫的可復(fù)用的BaseAdapter的使用就如上面所述~


3.代碼示例下載:

ListViewDemo4.zip

貼下最后寫好的MyAdapter類吧,可根據(jù)自己的需求進(jìn)行擴(kuò)展:

MyAdapter.java

/**
 * Created by Jay on 2015/9/22 0022.
 */
public abstract class MyAdapter<T> extends BaseAdapter {

    private ArrayList<T> mData;
    private int mLayoutRes;           //布局id

    public MyAdapter() {
    }

    public MyAdapter(ArrayList<T> mData, int mLayoutRes) {
        this.mData = mData;
        this.mLayoutRes = mLayoutRes;
    }

    @Override
    public int getCount() {
        return mData != null ? mData.size() : 0;
    }

    @Override
    public T getItem(int position) {
        return mData.get(position);
    }

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

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

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

    //添加一個(gè)元素
    public void add(T data) {
        if (mData == null) {
            mData = new ArrayList<>();
        }
        mData.add(data);
        notifyDataSetChanged();
    }

    //往特定位置,添加一個(gè)元素
    public void add(int position, T data) {
        if (mData == null) {
            mData = new ArrayList<>();
        }
        mData.add(position, data);
        notifyDataSetChanged();
    }

    public void remove(T data) {
        if (mData != null) {
            mData.remove(data);
        }
        notifyDataSetChanged();
    }

    public void remove(int position) {
        if (mData != null) {
            mData.remove(position);
        }
        notifyDataSetChanged();
    }

    public void clear() {
        if (mData != null) {
            mData.clear();
        }
        notifyDataSetChanged();
    }

    public static class ViewHolder {

        private SparseArray<View> mViews;   //存儲(chǔ)ListView 的 item中的View
        private View item;                  //存放convertView
        private int position;               //游標(biāo)
        private Context context;            //Context上下文

        //構(gòu)造方法,完成相關(guān)初始化
        private ViewHolder(Context context, ViewGroup parent, int layoutRes) {
            mViews = new SparseArray<>();
            this.context = context;
            View convertView = LayoutInflater.from(context).inflate(layoutRes, parent, false);
            convertView.setTag(this);
            item = convertView;
        }

        //綁定ViewHolder與item
        public static ViewHolder bind(Context context, View convertView, ViewGroup parent,
                                      int layoutRes, int position) {
            ViewHolder holder;
            if (convertView == null) {
                holder = new ViewHolder(context, parent, layoutRes);
            } else {
                holder = (ViewHolder) convertView.getTag();
                holder.item = convertView;
            }
            holder.position = position;
            return holder;
        }

        @SuppressWarnings("unchecked")
        public <T extends View> T getView(int id) {
            T t = (T) mViews.get(id);
            if (t == null) {
                t = (T) item.findViewById(id);
                mViews.put(id, t);
            }
            return t;
        }

        /**
         * 獲取當(dāng)前條目
         */
        public View getItemView() {
            return item;
        }

        /**
         * 獲取條目位置
         */
        public int getItemPosition() {
            return position;
        }

        /**
         * 設(shè)置文字
         */
        public ViewHolder setText(int id, CharSequence text) {
            View view = getView(id);
            if (view instanceof TextView) {
                ((TextView) view).setText(text);
            }
            return this;
        }

        /**
         * 設(shè)置圖片
         */
        public ViewHolder setImageResource(int id, int drawableRes) {
            View view = getView(id);
            if (view instanceof ImageView) {
                ((ImageView) view).setImageResource(drawableRes);
            } else {
                view.setBackgroundResource(drawableRes);
            }
            return this;
        }

        /**
         * 設(shè)置點(diǎn)擊監(jiān)聽
         */
        public ViewHolder setOnClickListener(int id, View.OnClickListener listener) {
            getView(id).setOnClickListener(listener);
            return this;
        }

        /**
         * 設(shè)置可見
         */
        public ViewHolder setVisibility(int id, int visible) {
            getView(id).setVisibility(visible);
            return this;
        }

        /**
         * 設(shè)置標(biāo)簽
         */
        public ViewHolder setTag(int id, Object obj) {
            getView(id).setTag(obj);
            return this;
        }

        //其他方法可自行擴(kuò)展

    }

}

本節(jié)小結(jié):

本節(jié)給大家介紹了如何來實(shí)現(xiàn)一個(gè)可供復(fù)用的BaseAdapter,當(dāng)然大家可以在這個(gè)的基礎(chǔ)上根據(jù) 自己的需求進(jìn)行修改,比如通過異步設(shè)置網(wǎng)絡(luò)圖片等~改代碼是參考鴻洋大神的視頻寫的: 視頻鏈接:Android-打造萬能適配器 另外,實(shí)際編寫中遇到一些問題,非常感謝Berial(B神)的耐心點(diǎn)撥~ ありがとうございます~


以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)