Android RecyclerView 和 CardView簡單使用

来源:http://www.cnblogs.com/Linccy/archive/2016/07/07/5648582.html
-Advertisement-
Play Games

Android 5.0之後Android新增加的兩個UI控制項RecyclerView,CardView。 RecyclerView可以看出是ListView的加強版,能夠更加靈活的使用、支持動畫等 CardView則是Google提供的一個卡片式視圖組件,可以定義如邊角的弧度、陰影等屬性。從本質上看 ...


Android 5.0之後Android新增加的兩個UI控制項RecyclerView,CardView。

RecyclerView可以看出是ListView的加強版,能夠更加靈活的使用、支持動畫等

CardView則是Google提供的一個卡片式視圖組件,可以定義如邊角的弧度、陰影等屬性。從本質上看,可以將CardView看做是FrameLayout在自身之上添加了圓角和陰影效果。

要使用這兩個UI控制項我們需要先在Android Studio 中添加相應的庫:

 

之後要有兩個佈局文件:

 

main_activity.xml:

 1 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 2     xmlns:tools="http://schemas.android.com/tools"
 3     android:layout_width="match_parent"
 4     android:layout_height="match_parent"
 5     android:orientation="vertical"
 6     android:paddingLeft="@dimen/activity_horizontal_margin"
 7     android:paddingRight="@dimen/activity_horizontal_margin"
 8     android:paddingTop="@dimen/activity_vertical_margin"
 9     android:paddingBottom="@dimen/activity_vertical_margin"
10     tools:context=".MainActivity">
11 
12     <TextView
13         android:id="@+id/tvTitle"
14         android:layout_width="wrap_content"
15         android:layout_height="wrap_content"
16         android:layout_gravity="center_horizontal"
17         android:textSize="20sp"
18         android:text="@string/tvTitle" />
19 
20     <android.support.v7.widget.RecyclerView
21         android:id="@+id/recyclerView"
22         android:layout_width="match_parent"
23         android:layout_height="wrap_content" />
24 
25 </LinearLayout>

recyclerview_cardview_item.xml:

 1 <android.support.v7.widget.CardView
 2     xmlns:android="http://schemas.android.com/apk/res/android"
 3     xmlns:card_view="http://schemas.android.com/apk/res-auto"
 4     android:id="@+id/cardview"
 5     android:layout_width="match_parent"
 6     android:layout_height="match_parent"
 7     android:layout_margin="6dp"
 8     android:padding="6dp"
 9     card_view:cardBackgroundColor="#ffdddddd"
10     card_view:cardCornerRadius="28dp"
11     card_view:cardElevation="6dp">
12 
13     <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
14         android:layout_width="match_parent"
15         android:layout_height="match_parent"
16         android:orientation="vertical">
17 
18         <ImageView
19             android:id="@+id/ivImage"
20             android:layout_width="120dp"
21             android:layout_height="160dp"
22             android:layout_marginLeft="16dp" />
23 
24         <LinearLayout
25             android:layout_width="wrap_content"
26             android:layout_height="wrap_content"
27             android:orientation="horizontal">
28 
29             <TextView
30                 android:id="@+id/tvId"
31                 android:layout_width="wrap_content"
32                 android:layout_height="wrap_content"
33                 android:layout_marginBottom="12dp"
34                 android:layout_marginLeft="20dp" />
35 
36             <TextView
37                 android:id="@+id/tvName"
38                 android:layout_width="wrap_content"
39                 android:layout_height="wrap_content"
40                 android:layout_marginBottom="12dp"
41                 android:layout_marginLeft="24dp" />
42         </LinearLayout>
43 
44     </LinearLayout>
45 </android.support.v7.widget.CardView>

然後再在MainActivity中

  1 package idv.ron.recyclercardviewdemo;
  2 
  3 import android.content.Context;
  4 import android.os.Bundle;
  5 import android.support.v7.app.AppCompatActivity;
  6 import android.support.v7.widget.RecyclerView;
  7 import android.support.v7.widget.StaggeredGridLayoutManager;
  8 import android.view.LayoutInflater;
  9 import android.view.View;
 10 import android.view.ViewGroup;
 11 import android.widget.ImageView;
 12 import android.widget.TextView;
 13 import android.widget.Toast;
 14 
 15 import java.util.ArrayList;
 16 import java.util.List;
 17 
 18 public class MainActivity extends AppCompatActivity {
 19     @Override
 20     protected void onCreate(Bundle savedInstanceState) {
 21         super.onCreate(savedInstanceState);
 22         setContentView(R.layout.main_activity);
 23         RecyclerView recyclerView = (RecyclerView) findViewById(R.id.recyclerView);
 24         recyclerView.setLayoutManager(
 25                 new StaggeredGridLayoutManager(
 26                         2, StaggeredGridLayoutManager.HORIZONTAL));
 27         List<Member> memberList = new ArrayList<>();
 28         memberList.add(new Member(92, R.drawable.p05, "James"));
 29         memberList.add(new Member(103, R.drawable.p06, "David"));
 30         memberList.add(new Member(234, R.drawable.p09, "Jerry"));
 31         memberList.add(new Member(35, R.drawable.p10, "Maggie"));
 32         memberList.add(new Member(23, R.drawable.p01, "John"));
 33         memberList.add(new Member(75, R.drawable.p02, "Jack"));
 34         memberList.add(new Member(65, R.drawable.p03, "Mark"));
 35         memberList.add(new Member(12, R.drawable.p04, "Ben"));
 36         memberList.add(new Member(45, R.drawable.p07, "Ken"));
 37         memberList.add(new Member(78, R.drawable.p08, "Ron"));
 38         memberList.add(new Member(57, R.drawable.p11, "Sue"));
 39         memberList.add(new Member(61, R.drawable.p12, "Cathy"));
 40         recyclerView.setAdapter(new MemberAdapter(this, memberList));
 41     }
 42 
 43     private class MemberAdapter extends
 44             RecyclerView.Adapter<MemberAdapter.ViewHolder> {
 45         private Context context;
 46         private LayoutInflater layoutInflater;
 47         private List<Member> memberList;
 48 
 49         public MemberAdapter(Context context, List<Member> memberList) {
 50             this.context = context;
 51             layoutInflater = LayoutInflater.from(context);
 52             this.memberList = memberList;
 53         }
 54 
 55         public class ViewHolder extends RecyclerView.ViewHolder {
 56             ImageView ivImage;
 57             TextView tvId, tvName;
 58             View itemView;
 59 
 60             public ViewHolder(View itemView) {
 61                 super(itemView);
 62                 this.itemView = itemView;
 63                 ivImage = (ImageView) itemView.findViewById(R.id.ivImage);
 64                 tvId = (TextView) itemView.findViewById(R.id.tvId);
 65                 tvName = (TextView) itemView.findViewById(R.id.tvName);
 66             }
 67         }
 68 
 69         @Override
 70         public int getItemCount() {
 71             return memberList.size();
 72         }
 73 
 74         @Override
 75         public ViewHolder onCreateViewHolder(ViewGroup viewGroup, int viewType) {
 76             View itemView = layoutInflater.inflate(
 77                     R.layout.recyclerview_cardview_item, viewGroup, false);
 78             return new ViewHolder(itemView);
 79         }
 80 
 81         @Override
 82         public void onBindViewHolder(ViewHolder viewHolder, final int position) {
 83             final Member member = memberList.get(position);
 84             viewHolder.ivImage.setImageResource(member.getImage());
 85             viewHolder.tvId.setText(String.valueOf(member.getId()));
 86             viewHolder.tvName.setText(member.getName());
 87             viewHolder.itemView.setOnClickListener(new View.OnClickListener() {
 88                 @Override
 89                 public void onClick(View v) {
 90                     ImageView imageView = new ImageView(context);
 91                     imageView.setImageResource(member.getImage());
 92                     Toast toast = new Toast(context);
 93                     toast.setView(imageView);
 94                     toast.setDuration(Toast.LENGTH_SHORT);
 95                     toast.show();
 96                 }
 97             });
 98         }
 99     }
100 }

下麵是效果圖:

 


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

-Advertisement-
Play Games
更多相關文章
  • J2V8是基於Google的JavaScript引擎V8的Java開源項目,實現Java和JavaScript的相互調用。並對Android平臺提供支持,最新版本提供了aar格式的類庫包方便Android Studio集成。 ...
  • 1. 首先先下載生成二維碼的支持文件 "libqrencode" 2. 添加依賴庫 CoreGraphics.framework 、 QuartzCore.framework 、 AVFoundation.framework 、 libiconv.dylib 、 CoreMedia.framewor ...
  • 對AFNetworking+MBProgressHUD的二次封裝,使用更方便,適用性非常強: 一句話搞定網路提示; 再也不用擔心網路庫更新後,工程要修改很多地方了!網路庫更新了只需要更新這個封裝好的庫。 不足之處歡迎指正 使用方法簡介: [MBProgressHUD showAutoMessage: ...
  • *res/raw和assets的相同點: 1.兩者目錄下的文件在打包後會原封不動的保存在apk包中,不會被編譯成二進位。 *res/raw和assets的不同點:1.res/raw中的文件會被映射到R.java文件中,訪問的時候直接使用資源ID即R.id.filename;assets文件夾下的文件 ...
  • 重寫onKeyDown事件即可 @Overridepublic boolean onKeyDown(int keyCode, KeyEvent event) { if (keyCode == KeyEvent.KEYCODE_BACK) { moveTaskToBack(false); return ...
  • 之前因為工作需要要實現一個類似的 懸浮+視差的headerView的效果, 研究了好久沒研究出來怎麼做,最後用UICollectionView + CSStickyHeaderFlowLayout的方法實現了(不得不說CSStickyHeaderFlowLayout真的是一個很強大的庫,作者對UIC ...
  • //顯示動畫 dialog = new Dialog(context, R.style.loading); dialog.setContentView(R.layout.loadinglayout);//此處佈局為一個progressbar dialog.setCancelable(true); / ...
  • 一,效果圖。 二,工程圖。 三,代碼。 AppDelegate.m #import "AppDelegate.h" //加入頭文件 #import "RoundDiskViewController.h" @implementation AppDelegate - (BOOL)application: ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...