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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...