RecyclerView的簡單使用

自從Android 5.0之后,google推出了一個RecyclerView控件,他是support-v7包中的新組件,是一個強大的滑動組件,與經(jīng)典的ListView相比,同樣擁有item回收復(fù)用的功能,RecyclerView相當(dāng)于是ListView的升級版。

成都創(chuàng)新互聯(lián)公司專注于三水網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗。 熱誠為您提供三水營銷型網(wǎng)站建設(shè),三水網(wǎng)站制作、三水網(wǎng)頁設(shè)計、三水網(wǎng)站官網(wǎng)定制、成都微信小程序服務(wù),打造三水網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供三水網(wǎng)站排名全網(wǎng)營銷落地服務(wù)。

RecyclerView封裝了ViewHolder的回收復(fù)用,也就是說RecyclerView標(biāo)準(zhǔn)化了ViewHolder,編寫Adapter面向的是ViewHolder而不是View了,復(fù)用的邏輯被封裝了,寫起來更加簡單。

RecyclerView提供一種插拔式的體驗,高度的解耦,異常的靈活,針對一個Item的顯示RecyclerView專門抽取了相應(yīng)的類,來控制Item的顯示,使其的擴展性特別強。

引入RecyclerVIew
compile 'com.android.support:recyclerview-v7:25.1.0'
創(chuàng)建布局文件
主布局文件
/*activity_main.xml*/
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.manu.mrecyclerview.MainActivity">
    <android.support.v7.widget.RecyclerView
        android:id="@+id/rv"
        android:layout_width="match_parent"
        android:layout_height="match_parent">
    </android.support.v7.widget.RecyclerView>
</LinearLayout>
Item布局文件
/*item.xml*/
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:padding="5dp">
    <TextView
        android:id="@+id/tv_recycle"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:gravity="center_horizontal"
        android:text="data"
        android:background="#cac3c3"
        android:padding="10dp"
        android:textSize="20sp"/>
</LinearLayout>
創(chuàng)建Adapter

RecyclerView的Adapter要比ListView的Adapter設(shè)置起來稍微復(fù)雜一點,這也是RecyclerView高度解耦的體現(xiàn),雖然代碼復(fù)雜一點,但擴展性很好,下面介紹一下實現(xiàn)RecyclerView的Adapter的三個方法:

onCreateViewHolder()

該方法主要是為每個Item加載一個View,但是該方法返回的是一個ViewHolder,該方法吧View直接封裝的ViewHolder中,然后我們面向的是ViewHolder這個實例,這個ViewHolder也由自己編寫,但不用像ListView調(diào)用convertView.setTag(vh)和convertView.getTag()了。

onBindViewHolder()

該方法主要用來把數(shù)據(jù)綁定在View上,直接提供一個ViewHolder而不是convertView。

getItemCount()

該方法返回選項總數(shù)。

Adapter代碼
/**
 * Created by jzman on 2017/5/13 0013.
 */
public class RvAdapter extends RecyclerView.Adapter<RvAdapter.DataViewHolder>{
    private Context mContext;
    private ArrayList<String> mList;

    public RvAdapter() {}

    public RvAdapter(Context mContext, ArrayList<String> mList) {
        this.mContext = mContext;
        this.mList = mList;
    }

    //用于創(chuàng)建ViewHolder
    @Override
    public DataViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        View view = LayoutInflater.from(mContext).inflate(R.layout.item,null);
        //使用代碼設(shè)置寬高(xml布局設(shè)置無效時)
        view.setLayoutParams(new ViewGroup.LayoutParams(
                ViewGroup.LayoutParams.MATCH_PARENT,
                ViewGroup.LayoutParams.WRAP_CONTENT));
        DataViewHolder holder = new DataViewHolder(view);
        return holder;
    }
    //綁定數(shù)據(jù)
    @Override
    public void onBindViewHolder(DataViewHolder holder, int position) {
        holder.tv_data.setText(mList.get(position));
    }
    //數(shù)據(jù)總數(shù)
    @Override
    public int getItemCount() {
        return mList.size();
    }

    //創(chuàng)建ViewHolder
    public static class DataViewHolder extends RecyclerView.ViewHolder{
        TextView tv_data;
        public DataViewHolder(View itemView) {
            super(itemView);
            tv_data = (TextView) itemView.findViewById(R.id.tv_recycle);
        }
    }

使用StaggeredGridLayoutManager管理器時,Adapter參考如下:

/**
 * Created by jzman on 2017/5/13 0013.
 * RecycleView的Adapter
 */
public class RvAdapter extends RecyclerView.Adapter<RvAdapter.DataViewHolder>{
    private Context mContext;
    private RecyclerView recyclerView;
    private ArrayList<String> mList;
    private ArrayList<Integer> mHeight;

    public RvAdapter() {}

    public RvAdapter(Context mContext, ArrayList<String> mList) {
        this.mContext = mContext;
        this.mList = mList;
    }

    /**
     * 初始化每個Item的高度(瀑布流效果)
     * @return
     */
    public ArrayList<Integer> initHeight(){
        mHeight = new ArrayList<>();
        for (int i=0;i<mList.size();i++){
            mHeight.add((int) (Math.random()*300)+200);
        }
        return mHeight;
    }

    /**
     * 用于創(chuàng)建ViewHolder
     * @param parent
     * @param viewType
     * @return
     */
    @Override
    public DataViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        View view = LayoutInflater.from(mContext).inflate(R.layout.item,null);
        //使用代碼設(shè)置寬高(xml布局設(shè)置無效時)
        view.setLayoutParams(new ViewGroup.LayoutParams(
                ViewGroup.LayoutParams.MATCH_PARENT,
                ViewGroup.LayoutParams.WRAP_CONTENT));
        DataViewHolder holder = new DataViewHolder(view);
        return holder;
    }

    /**
     * 綁定數(shù)據(jù)
     * @param holder
     * @param position
     */
    @Override
    public void onBindViewHolder(DataViewHolder holder, int position) {
        //設(shè)置每個Item的高度
        ViewGroup.LayoutParams h = holder.tv_data.getLayoutParams();
        h.height = mHeight.get(position);
        holder.tv_data.setText(mList.get(position));
    }

    /**
     * 選項總數(shù)
     * @return
     */
    @Override
    public int getItemCount() {
        return mList.size();
    }

    /**
     * 創(chuàng)建ViewHolder
     */
    public static class DataViewHolder extends RecyclerView.ViewHolder{
        TextView tv_data;
        public DataViewHolder(View itemView) {
            super(itemView);
            tv_data = (TextView) itemView.findViewById(R.id.tv_recycle);
        }
    }
    /**
     *   將RecycleView附加到Adapter上
     */
    @Override
    public void onAttachedToRecyclerView(RecyclerView recyclerView) {
        super.onAttachedToRecyclerView(recyclerView);
        this.recyclerView= recyclerView;
        //初始化每個Item的高度
        initHeight();
    }
    /**
     *   將RecycleView從Adapter解除
     */
    @Override
    public void onDetachedFromRecyclerView(RecyclerView recyclerView) {
        super.onDetachedFromRecyclerView(recyclerView);
        this.recyclerView = null;
    }
}
MainActivity
/**
 * Created by jzman on 2017/5/13 0013.
 */
public class MainActivity extends AppCompatActivity {
    private RecyclerView rv;
    RvAdapter adapter;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        rv = (RecyclerView) findViewById(R.id.rv);
        //設(shè)置布局管理器
        rv.setLayoutManager(new LinearLayoutManager(this));//線性
//        rv.setLayoutManager(new GridLayoutManager(this,4));//線性
//        rv.setLayoutManager(new StaggeredGridLayoutManager(4,StaggeredGridLayoutManager.VERTICAL));//線性
        adapter = new RvAdapter(this,initData());
        rv.setAdapter(adapter);
    }
    public static ArrayList<String> initData(){
        ArrayList<String> arrayList = new ArrayList<>();
        for (int i=0;i<50;i++){
            arrayList.add("第"+i+"條數(shù)據(jù)");
        }
        return arrayList;
    }
}
顯示效果
LinearLayoutManagerGridLayoutManagerStaggeredGridLayoutManager
RecyclerView的簡單使用 RecyclerView的簡單使用 RecyclerView的簡單使用

如果覺得對自己有幫助,可以關(guān)注公眾號:jzman-blog,一起交流學(xué)習(xí)。
RecyclerView的簡單使用

網(wǎng)站標(biāo)題:RecyclerView的簡單使用
文章路徑:http://muchs.cn/article24/pieoce.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供做網(wǎng)站網(wǎng)站設(shè)計、營銷型網(wǎng)站建設(shè)網(wǎng)頁設(shè)計公司、關(guān)鍵詞優(yōu)化、網(wǎng)站內(nèi)鏈

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)