RecyclerView

来源:http://www.cnblogs.com/ganchuanpu/archive/2016/11/05/6033384.html
-Advertisement-
Play Games

1.簡介 RecyclerView是一種新的視圖組,目標是為任何基於適配器的視圖提供相似的渲染方式。它被作為ListView和GridView控制項的繼承者,在最新的support-V7版本中提供支持。RecyclerView架構,提供了一種插拔式的體驗,高度的解耦,異常的靈活,通過設置它提供的不同L ...


1.簡介

  RecyclerView是一種新的視圖組,目標是為任何基於適配器的視圖提供相似的渲染方式。它被作為ListView和GridView控制項的繼承者,在最新的support-V7版本中提供支持。RecyclerView架構,提供了一種插拔式的體驗,高度的解耦,異常的靈活,通過設置它提供的不同LayoutManager,ItemDecoration , ItemAnimator實現令人瞠目的效果。

總之ListView和GridView能做的RecyclerView都能做,並且能實現瀑布流效果

2.使用

在build.gradle配置RecyclerView的庫
compile 'com.android.support:recyclerview-v7:23.3.0'

 

//設置RecyclerView的適配器
adapter = new MyRecyclerViewAdapter(RecyclerViewActivity.this,datas);
recyclerview.setAdapter(adapter);

//LayoutManager
recyclerview.setLayoutManager(new LinearLayoutManager(RecyclerViewActivity.this, LinearLayoutManager.VERTICAL, false));
//        recyclerview.scrollToPosition(datas.size()-1);

//添加RecyclerView的分割線
recyclerview.addItemDecoration(new DividerListItemDecoration(RecyclerViewActivity.this,DividerListItemDecoration.VERTICAL_LIST));

//設置動畫
recyclerview.setItemAnimator(new DefaultItemAnimator());

  

public class MyAdapter extends  RecyclerView.Adapter<MyAdapter.MyViewHolder> {

    private final Context context;
    private final ArrayList<String> datas;
   
    public MyAdapter(Context context,ArrayList<String> datas){
        this.context = context;
        this.datas = datas;
    }
    /**
     * 相當於ListView適配器中的getView的創建holder佈局
     *
     * @param parent
     * @param viewType
     * @return
     */
    @Override
    public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        View view = View.inflate(context, R.layout.item_hello, null);
        return new MyViewHolder(view);
    }

    @Override
    public void onBindViewHolder(MyViewHolder holder, int position) {
        holder.tv_text.setText(datas.get(position));
        holder.iv_icon.setBackgroundResource(R.mipmap.ic_launcher);

    }

    @Override
    public int getItemCount() {
        return datas.size();
    }

    class MyViewHolder extends RecyclerView.ViewHolder {

        private TextView tv_text;
        private ImageView iv_icon;

        public MyViewHolder(View itemView) {
            super(itemView);
            tv_text = (TextView) itemView.findViewById(R.id.tv_text);
            iv_icon = (ImageView) itemView.findViewById(R.id.iv_icon);

        }
    }
}

  

3.設置ListView&GridView&瀑布流類型效果

//設置List類型效果
recyclerview.setLayoutManager(new LinearLayoutManager(RecyclerViewActivity.this,LinearLayoutManager.VERTICAL,false));

//設置Grid類型效果
recyclerview.setLayoutManager(new GridLayoutManager(RecyclerViewActivity.this, 2, GridLayoutManager.VERTICAL, false));
//recyclerview.scrollToPosition(99);

//設置瀑布流類型效果
recyclerview.setLayoutManager(new StaggeredGridLayoutManager(3,StaggeredGridLayoutManager.VERTICAL));

  

4.分割線

參照網址:http://blog.csdn.net/lmj623565791/article/details/45059587

//設置分割線-分割線需要自定義&還可以自定義分割線的樣式
//沒有提供預設的分割線
recyclerview.addItemDecoration(new DividerListItemDecoration(this, DividerListItemDecoration.VERTICAL_LIST));

  

 1 public class DividerListItemDecoration extends RecyclerView.ItemDecoration {
 2     private static final int[] ATTRS = new int[]{
 3             android.R.attr.listDivider
 4     };
 5 
 6     public static final int HORIZONTAL_LIST = LinearLayoutManager.HORIZONTAL;
 7 
 8     public static final int VERTICAL_LIST = LinearLayoutManager.VERTICAL;
 9 
10     private Drawable mDivider;
11 
12     private int mOrientation;
13 
14     public DividerListItemDecoration(Context context, int orientation) {
15         final TypedArray a = context.obtainStyledAttributes(ATTRS);
16         mDivider = a.getDrawable(0);
17         a.recycle();
18         setOrientation(orientation);
19     }
20 
21     public void setOrientation(int orientation) {
22         if (orientation != HORIZONTAL_LIST && orientation != VERTICAL_LIST) {
23             throw new IllegalArgumentException("invalid orientation");
24         }
25         mOrientation = orientation;
26     }
27 
28     @Override
29     public void onDraw(Canvas c, RecyclerView parent) {
30 //        Log.e("recyclerview - itemdecoration", "onDraw()");
31 
32         if (mOrientation == VERTICAL_LIST) {
33             drawVertical(c, parent);
34         } else {
35             drawHorizontal(c, parent);
36         }
37 
38     }
39 
40 
41     public void drawVertical(Canvas c, RecyclerView parent) {
42         final int left = parent.getPaddingLeft();
43         final int right = parent.getWidth() - parent.getPaddingRight();
44 
45         final int childCount = parent.getChildCount();
46         for (int i = 0; i < childCount; i++) {
47             final View child = parent.getChildAt(i);
48             android.support.v7.widget.RecyclerView v = new android.support.v7.widget.RecyclerView(parent.getContext());
49             final RecyclerView.LayoutParams params = (RecyclerView.LayoutParams) child
50                     .getLayoutParams();
51             final int top = child.getBottom() + params.bottomMargin;
52             final int bottom = top + mDivider.getIntrinsicHeight();
53             mDivider.setBounds(left, top, right, bottom);
54             mDivider.draw(c);
55         }
56     }
57 
58     public void drawHorizontal(Canvas c, RecyclerView parent) {
59         final int top = parent.getPaddingTop();
60         final int bottom = parent.getHeight() - parent.getPaddingBottom();
61 
62         final int childCount = parent.getChildCount();
63         for (int i = 0; i < childCount; i++) {
64             final View child = parent.getChildAt(i);
65             final RecyclerView.LayoutParams params = (RecyclerView.LayoutParams) child
66                     .getLayoutParams();
67             final int left = child.getRight() + params.rightMargin;
68             final int right = left + mDivider.getIntrinsicHeight();
69             mDivider.setBounds(left, top, right, bottom);
70             mDivider.draw(c);
71         }
72     }
73 
74     @Override
75     public void getItemOffsets(Rect outRect, int itemPosition, RecyclerView parent) {
76         if (mOrientation == VERTICAL_LIST) {
77             outRect.set(0, 0, 0, mDivider.getIntrinsicHeight());
78         } else {
79             outRect.set(0, 0, mDivider.getIntrinsicWidth(), 0);
80         }
81     }
82 }
DividerListItemDecoration

 

設置分割線樣式:

①application設置

<!-- Base application theme. -->
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
    <!-- Customize your theme here. -->
    <item name="colorPrimary">@color/colorPrimary</item>
    <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
    <item name="colorAccent">@color/colorAccent</item>
    <item name="android:listDivider">@drawable/divider_bg</item>
</style>

②在activity中

<activity android:name=".recyclerview.RecyclerViewActivity"
    android:theme="@style/listDividerTheme"/>
<style name="listDividerTheme"  parent="Theme.AppCompat.Light.DarkActionBar">
    <!-- Customize your theme here. -->
    <item name="colorPrimary">@color/colorPrimary</item>
    <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
    <item name="colorAccent">@color/colorAccent</item>
    <item name="android:listDivider">@drawable/divider_bg</item>
</style>

  

5.自定義設置item的點擊事件

RecyclerView預設是沒有點擊事件的,需要自定義點擊事件
用到知識點:介面,getLayoutPosition()

public class MyAdapter extends RecyclerView.Adapter<MyAdapter.MyViewHolder>{

    private final Context context;
    private final ArrayList<String> datas;

    //設置點擊某個item的監聽
    public interface OnItemClickListener{
         void onItemClick(View view,int position,String content);
    }

    private OnItemClickListener onItemClickListener;
    public void setOnItemClickListener(OnItemClickListener onItemClickListener)   {
        this.onItemClickListener = onItemClickListener;
    }

    //設置點擊圖片
    public interface OnImageViewClickListener{
        void onImageViewClick(View view,int position);
    }

    private OnImageViewClickListener onImageViewClickListener;
    public void setOnImageViewClickListener(OnImageViewClickListener onImageViewClickListener) {
        this.onImageViewClickListener = onImageViewClickListener;
    }

  ...................................

    class MyViewHolder extends RecyclerView.ViewHolder {

        private TextView tv_text;
        private ImageView iv_icon;

        public MyViewHolder(View itemView) {
            super(itemView);
            tv_text = (TextView) itemView.findViewById(R.id.tv_text);
            iv_icon = (ImageView) itemView.findViewById(R.id.iv_icon);

            //設置點擊事件
            itemView.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    if(onItemClickListener != null){
                        onItemClickListener.onItemClick(v,getLayoutPosition(),datas.get(getLayoutPosition()));
                    }
                }
            });

            //設置監聽
            iv_icon.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    if(onImageViewClickListener != null){
                        onImageViewClickListener.onImageViewClick(v,getLayoutPosition());
                    }
                }
            });
        }
    }
}

  

在Activity中使用自定義的點擊事件

//設置點擊item的點擊事件
myAdapter.setOnItemClickListener(new MyAdapter.OnItemClickListener() {
    @Override
    public void onItemClick(View view, int position, String content) {
        Toast.makeText(RecyclerViewActivity.this, "content=="+content+",--position=="+position, Toast.LENGTH_SHORT).show();
    }
});

//設置點擊某張圖片的點擊事件
myAdapter.setOnImageViewClickListener(new MyAdapter.OnImageViewClickListener() {
    @Override
    public void onImageViewClick(View view, int position) {
        Toast.makeText(RecyclerViewActivity.this, "position=="+position+",view=="+view.toString(), Toast.LENGTH_SHORT).show();
    }
});

  

6.刪除和增加數據

1_在適配器中新增加添加和刪除兩個方法

public class MyAdapter extends RecyclerView.Adapter<MyAdapter.MyViewHolder> {
	
    ........................
	
    public void addData(int position,String content){
        datas.add(position,content);
        notifyItemInserted(position);
    }

    public void removeData(int position){
        datas.remove(position);
        notifyItemRemoved(position);
    }
}

2_Activity中

btn_add.setOnClickListener(new View.OnClickListener() {
	@Override
	public void onClick(View v) {
		myAdapter.addData(0,"Content NetData");
		//定位到第0個位置
		recyclerview.scrollToPosition(0);
	}
});

btn_remove.setOnClickListener(new View.OnClickListener() {
	@Override
	public void onClick(View v) {
		myAdapter.removeData(0);
	}
});

  

  

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • var EventHandle = { addEvent:function(ele,type,handle){ if (ele.addEventListener) { ele.addEventListener(type,handle,false); }else if(attachEvent){ el ...
  • html部分 <!DOCTYPE html> <!--下麵三個百分比都是為了實現後期項目優化的時候,實現自適應屏幕的寬度和高度--> <html style="height: 100%;"> <!--這個需要HTML標簽上也得加上style="height:100%"才行,要不然會顯示一半,經常用C ...
  • 今天項目需要用到旋轉木馬輪播功能,需要顯示個可以切換的選項,這幾個選項也許是圖片,也許是文字,也許是一個iframe頁面,也有可能是圖文混排,還可能需要支持調用介面數據,需要顯示多條信息,最少3條,最多不限,可能有10條,可能有10000條,於是就有了下麵這個實現方法,看上去已經很完美了(樣式和具體... ...
  • 簡介 技術一般水平有限,有什麼錯的地方,望大家指正。 sessionStorage、localStorage、cookie這三個是我們在瀏覽器端用來存儲數據的,cookie使用起來較為繁瑣以後進行總結,主要介紹一下sessionStorage和localStorage的用法。sessionStora ...
  • 恢復內容開始 當我們註冊或者登錄要用郵箱格式時會顯示郵箱尾碼的提示下拉框 效果如圖所示 主要介紹了JS輸入用戶名自動顯示郵箱尾碼列表的方法,可實現自動顯示郵箱尾碼名列表的功能, 原理是:一個輸入框 當我輸入任何字的時候 自動下拉相應的郵箱提示,在輸入框輸入11的時候 下拉框有所有11的郵箱 輸入其他 ...
  • 工欲善其事,必先利其器。以下介紹一些常用的Android Plugin,有助於開發。 1、adb-idea 支持在AS面板中,執行ADB命令。不過如果用慣命令行的話,可以不安裝; 2、android-parcelable-intellij-plugin parcelable 代碼補全,省時省力; 3 ...
  • 1.SwipeRefreshLayout是Google在support v4 19.1版本的library更新的一個下拉刷新組件,實現刷新效果更方便。 弊端:只有下拉 2.在xml文件中引用android.support.v4.widget.SwipeRefreshLayout控制項,在裡面可以放置任 ...
  • 1、Android Log簡介; 在程式中輸出日誌,使用 android.util.Log 類。該類提供了若幹靜態方法: Log.v(String tag, String msg); // 任何消息都會輸出 Log.d(String tag, String msg); // 僅輸出debug調試的意 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...