`
qwzs112
  • 浏览: 120596 次
文章分类
社区版块
存档分类
最新评论

Android L——RecyclerView,CardView的导入和使用

阅读更多

本文主要介绍Android L新增加的两个UI控件RecyclerView,CardView的导入和使用。

RecyclerView:ListView的升级版,它提供了更好的性能而且更容易使用。该控件是一个可以装载大量的视图集合,并且可以非常效率的进行回收和滚动。当你list中的元素经常动态改变时可以使用RecyclerView控件。它提供了如下两个功能:

1、为每个条目位置提供了layout管理器(RecyclerView.setLayoutManager

2、为每个条目设置了操作动画(RecyclerView.setItemAnimator

CardView:Google提供的一个卡片式视图组件。CardView继承自FrameLayout,允许你在Card视图中显示信息, CardView也可以设置阴影和圆角。(其实现在很多应用都自定义了Card视图,Google这回将Card视图作为基本控件,可以拿来直接使用了。)

本例就是一个使用RecyclerView来展示多个CardView的一个小例子,先看下效果图:

效果图

导入RecyclerView,CardView

由于RecyclerView,CardView是放在support library v7包中,所以我们想要使用就必须要导包。

下面就介绍下在Eclipse和Android Studio中是如何导入这两个包的。

Eclipse:

第一步:通过SDK manager下载/更新Android Support Libraries(5.0版本最新为21) 

下载/更新Android Support Libraries

第二步:导入CardView和RecyclerView项目(都在support v7中)

1、在Eclipse中点击Import,导入Android项目

2、导入CardView和RecycleView,路径为your sdk path\extras\android\support\v7\cardview(RecycleView则为相同目录下的recyclerview)

3、导入时记得将工程copy到本地并建议重命名,这样方便以后管理例如:

重命名

第三步:设置Library

1、将两个工程设置为Library

2、在主工程中引入这两个Library例如:

在主工程中引入Library

通过这三步就可以将这两个包导入进来了。

Android Studio

Android Stuido相对于Eclipse简单的多。

第一步:首先要确保已经将Android Support Libraries升级到最新。

第二步:打开项目中的build.gradle文件,在dependencies中添加如下代码。

1
2
3
4
dependencies {
    compile 'com.android.support:recyclerview-v7:21.+'
    compile 'com.android.support:cardview-v7:21.+'
}

第三步:重新Build一下工程,Build完成后就会发现这两个包就已经导入进来了。

重新Build工程

代码介绍:

主题:

首先这个黑色基调的主题是使用了Material.Dark.ActionBar样式。

设置方法:修改values-v21文件夹下styles.xml文件:

1
2
3
4
<resources>  
    <style name="AppTheme" parent="android:ThemeOverlay.Material.Dark.ActionBar">  
    </style>  
</resources>

布局文件:

recycler_view.xml(RecyclerView布局文件):

1
2
3
4
5
6
7
8
9
10
11
12
13
<?xml version="1.0" encoding="utf-8"?>  
<FrameLayout 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=".MyActivity">  
   
    <android.support.v7.widget.RecyclerView  
        android:id="@+id/list"  
        android:layout_width="match_parent"  
        android:layout_height="match_parent"  
        tools:context=".MyActivity" />  
</FrameLayout>

FrameLayout里包含了RecyclerView控件。

card_view.xml(CardView布局文件):

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
<android.support.v7.widget.CardView xmlns:android="http://schemas.android.com/apk/res/android"  
    xmlns:card_view="http://schemas.android.com/apk/res-auto"  
    android:layout_width="match_parent"  
    android:layout_height="match_parent"  
    android:layout_margin="5dp"  
    android:orientation="horizontal"  
    card_view:cardBackgroundColor="@color/cardview_dark_background"  
    card_view:cardCornerRadius="5dp" >  
   
    <RelativeLayout  
        android:layout_width="match_parent"  
        android:layout_height="100dp"  
        android:padding="5dp" >  
   
        <ImageView  
            android:id="@+id/pic"  
            android:layout_width="match_parent"  
            android:layout_height="match_parent"  
            android:layout_centerInParent="true"  
            android:scaleType="centerCrop" />  
   
        <TextView  
            android:clickable="true"  
            android:id="@+id/name"  
            android:layout_width="match_parent"  
            android:layout_height="match_parent"  
            android:layout_marginBottom="10dp"  
            android:layout_marginRight="10dp"  
            android:gravity="right|bottom"  
            android:textColor="@android:color/white"  
            android:textSize="24sp" />  
    </RelativeLayout>  
   
</android.support.v7.widget.CardView>

CardView视图中包含了一个ImageView和一个TextView分别显示图片和文字信息。

唯一需要介绍的就是在布局文件中使用了,如下两个属性:

1
2
card_view:cardBackgroundColor="@color/cardview_dark_background"  
   card_view:cardCornerRadius="5dp"

他俩的作用分别是设置CardView的背景颜色和外围的圆角大小(注意要使用card_view命名空间)

代码:

Actor类(封装数据的Model类):

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
public class Actor
{
    String name;
 
    String picName;
 
    public Actor(String name, String picName)
    {
        this.name = name;
        this.picName = picName;
    }
 
    public int getImageResourceId( Context context )
    {
        try
        {
            return context.getResources().getIdentifier(this.picName, "drawable", context.getPackageName());
 
        }
        catch (Exception e)
        {
            e.printStackTrace();
            return -1;
        }
    }
}

封装了演员的名字和图片名,getImageResourceId()方法的作用就是根据图片命找到系统资源。

MyActivity(程序主控制Activity)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
public class MyActivity
    extends Activity
{
 
    private RecyclerView mRecyclerView;
 
    private MyAdapter myAdapter;
 
    private Listactors = new ArrayList();
 
    private String[] names = { "朱茵""张柏芝""张敏""巩俐""黄圣依""赵薇""莫文蔚""如花" };
 
    private String[] pics = { "p1""p2""p3""p4""p5""p6""p7""p8" };
 
    @Override
    protected void onCreate( Bundle savedInstanceState )
    {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.recycler_view);
 
        actors.add(new Actor("朱茵""p1"));
        getActionBar().setTitle("那些年我们追的星女郎");
 
        // 拿到RecyclerView
        mRecyclerView = (RecyclerView) findViewById(R.id.list);
        // 设置LinearLayoutManager
        mRecyclerView.setLayoutManager(new LinearLayoutManager(this));
        // 设置ItemAnimator
        mRecyclerView.setItemAnimator(new DefaultItemAnimator());
        // 设置固定大小
        mRecyclerView.setHasFixedSize(true);
        // 初始化自定义的适配器
        myAdapter = new MyAdapter(this, actors);
        // 为mRecyclerView设置适配器
        mRecyclerView.setAdapter(myAdapter);
 
    }
 
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.menu, menu);
        return true;
    }
 
    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        switch(item.getItemId()) {
            // 当点击actionbar上的添加按钮时,向adapter中添加一个新数据并通知刷新
            case R.id.action_add:
                if (myAdapter.getItemCount() != names.length) {
                    actors.add(new Actor(names[myAdapter.getItemCount()], pics[myAdapter.getItemCount()]));
                    mRecyclerView.scrollToPosition(myAdapter.getItemCount() - 1);
                    myAdapter.notifyDataSetChanged();
                }
                return true;
            // 当点击actionbar上的删除按钮时,向adapter中移除最后一个数据并通知刷新
            case R.id.action_remove:
                if (myAdapter.getItemCount() != 0) {
                    actors.remove(myAdapter.getItemCount()-1);
                    mRecyclerView.scrollToPosition(myAdapter.getItemCount() - 1);
                    myAdapter.notifyDataSetChanged();
                }
                return true;
        }
        return super.onOptionsItemSelected(item);
    }
 
}

MyAdapter(自定义适配器类)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
public class MyAdapter
    extends RecyclerView.Adapter{
 
    private Listactors;
 
    private Context mContext;
 
    public MyAdapter( Context context , Listactors)
    {
        this.mContext = context;
        this.actors = actors;
    }
 
    @Override
    public ViewHolder onCreateViewHolder( ViewGroup viewGroup, int i )
    {
        // 给ViewHolder设置布局文件
        View v = LayoutInflater.from(viewGroup.getContext()).inflate(R.layout.card_view, viewGroup, false);
        return new ViewHolder(v);
    }
 
    @Override
    public void onBindViewHolder( ViewHolder viewHolder, int i )
    {
        // 给ViewHolder设置元素
        Actor p = actors.get(i);
        viewHolder.mTextView.setText(p.name);
        viewHolder.mImageView.setImageDrawable(mContext.getDrawable(p.getImageResourceId(mContext)));
    }
 
    @Override
    public int getItemCount()
    {
        // 返回数据总数
        return actors == null 0 : actors.size();
    }
 
    // 重写的自定义ViewHolder
    public static class ViewHolder
        extends RecyclerView.ViewHolder
    {
        public TextView mTextView;
 
        public ImageView mImageView;
 
        public ViewHolder( View v )
        {
            super(v);
            mTextView = (TextView) v.findViewById(R.id.name);
            mImageView = (ImageView) v.findViewById(R.id.pic);
        }
    }
}

以上所有代码就介绍完了,可以总结为以下两点:

RecyclerView:

理解为之前的ListView,不过需要设置LinearLayoutManager和ItemAnimator两个新属性。

RecyclerView.Adapter:

理解为默认自带和基于ViewHolder的新的适配器,只不过回调方法稍有不同,但本质都是一样的。

推荐阅读:

19个实用的Android开发工具

Android四大组件详解

1
1
分享到:
评论
1 楼 qwzs112 2015-08-14  
  来一篇偏技术点的,希望能对大家有些许帮助

相关推荐

    Android Training学习笔记——RecyclerView和CardView

    总的来说,掌握RecyclerView和CardView的使用对于Android开发者至关重要,它们能够帮助开发者构建出高效的列表视图和具有Material Design风格的界面。而Navigation组件则能帮助优化应用的导航逻辑,提高用户体验。...

    android RecyclerView CardView实践

    本文将深入探讨如何在Android 5.0及以上版本中使用RecyclerView和CardView进行实践。 RecyclerView是一个高效的视图回收复用组件,主要用于处理大量数据的列表展示。与之前的ListView相比,RecyclerView具有更好的...

    RecyclerView+CardView实现横向卡片式滑动效果

    本文主要介绍了使用RecyclerView和CardView实现横向卡片式滑动效果的方法,旨在提高Android应用程序的用户体验。下面是相关知识点的详细解释: 1. RecyclerView简介 RecyclerView是Android SDK中的一种控件,官方...

    android 新组件RecyclerView及CardView 使用详解

    在Android开发中,RecyclerView和...总之,理解并熟练掌握RecyclerView和CardView的使用,对于提高Android应用的界面设计和用户体验至关重要。通过不断实践和探索,开发者可以创造出更多富有创意和功能丰富的界面。

    RecyclerView结合CardView的照片瀑布流

    在Android开发中,RecyclerView是一个非常重要的组件,它用于展示可滚动的数据集,具有高效和灵活的布局管理器。而CardView则是一个轻量级的UI组件,它为内容提供了一个带有阴影和圆角的卡片视图,使得界面更加美观...

    ndroid之 RecyclerView,CardView 详解和相对应的上拉刷新下拉加载

    Android之 RecyclerView,CardView 详解和相对应的上拉刷新下拉加载,博客地址:http://blog.csdn.net/dickyqie/article/details/54913289

    AndroidRecyclerViewCardView:Android RecyclerView CardView

    Android RecyclerView CardView 具有动画和差异模式的Android RecyclerView CardView: 1.)线性视图水平 2.)线性视图垂直 3.)网格视图 4.)交错视图水平 5.)交错视图垂直

    类似淘宝订单列表(多于两条的时候收起可展开)RecyclerView+CardView实现

    本教程将详细讲解如何使用`RecyclerView`和`CardView`来实现这样一个功能丰富的订单列表,特别是当单个订单包含多个商品时,如何实现收起和展开的效果。 首先,`RecyclerView`是Android SDK提供的一种高效的数据...

    recyclerView cardView简单例子,zxing二维码生成,cardView阴影效果,圆角效果使用

    在Android开发中,`RecyclerView`和`CardView`是两个非常重要的组件,广泛应用于构建高效且可滚动的数据列表。`ZXing`库则用于生成和扫描二维码,是移动设备上处理条码和二维码的主要工具。这里我们将深入探讨这三个...

    recyclerview和cardview的结合使用

    总结来说,RecyclerView和CardView是Android开发中的强大工具,它们的结合使用可以创建出高度可定制且性能优秀的列表视图。通过学习和实践,开发者可以更好地利用这两个组件来提升应用的用户体验。

    RecyclerView+CardView+Glide加载图片实现瀑布流

    在Android应用开发中,RecyclerView、CardView和Glide是三个非常重要的组件,它们共同作用可以构建出高效且美观的图片加载瀑布流界面。本篇文章将详细介绍这三个组件的使用方法及其结合实现瀑布流的过程。 首先,...

    RecyclerView和CardView演示Demo

    在Android开发中,RecyclerView和CardView是两个非常重要的组件,它们极大地丰富了用户界面的展示方式,提高了用户体验。本文将详细解析这两个组件及其在实际应用中的结合使用。 RecyclerView是Android SDK 21引入...

    RecyclerView中嵌套CardView

    在Android开发中,`RecyclerView`和`CardView`是两个非常重要的组件,它们结合使用能够构建出高效且美观的用户界面。本篇文章将详细讲解如何在`RecyclerView`中嵌套`CardView`,以及实现这一功能所涉及的关键知识点...

    recyclerview-cardview-example:示例如何在Android中实现RecyclerView和CardView

    在Android开发中,RecyclerView和CardView是两个非常重要的组件,它们极大地提升了应用界面的用户体验和性能。本项目,"recyclerview-cardview-example",旨在演示如何有效地结合这两个组件来创建一个美观且高效的...

    RecyclerView CardView

    在Android开发中,`RecyclerView`和`CardView`是两个非常重要的组件,它们共同用于创建高效、可滚动的视图列表。本篇文章将详细介绍`RecyclerView`和`CardView`的基本使用,以及如何结合它们实现一个名为`...

    Android-使用RecyclerView实现的自定义课程表View

    在Android应用开发中,RecyclerView是一个强大的视图组件,它用于高效地展示大量数据集,并支持滚动、动画和自定义布局管理器。本教程将深入探讨如何利用RecyclerView来创建一个自定义的课程表视图。 首先,理解...

    Android-Android自定义ShadowView可替代CardView使用

    在Android开发中,CardView是一种常用的UI组件,它提供了一个带有阴影效果的矩形框,常用于展示卡片式的信息。然而,有时我们可能需要更自定义化的阴影效果,这时可以考虑使用自定义的ShadowView来替代CardView。...

    RecyclerView:recyclerview + cardview

    Android5.0 RecyclerView的使用方法 预览 用来做什么 这是Android5.0 新特性,主要用来替代ListView的使用,在RecyclerView标准化了ViewHolder类似于ListView中convertView用来做视图缓存. 可以通过设置LayoutManager...

    RecyclerView_CardView_Demo

    在Android开发中,`RecyclerView`和`CardView`是两个非常重要的组件,它们极大地提高了应用的性能和用户体验。本文将详细讲解如何使用这两个组件来创建一个`RecyclerView_CardView_Demo`。 首先,我们来了解`...

    Android MD控件之CardView

    总结,CardView是Android MD设计的重要组成部分,通过其丰富的自定义选项和与RecyclerView的完美结合,开发者可以创建出美观且高效的用户界面。理解和掌握CardView的使用,能够提升应用的视觉效果和用户体验。

Global site tag (gtag.js) - Google Analytics