当前位置: 移动技术网 > IT编程>移动开发>Android > RecyclerView+CardView实现横向卡片式滑动效果

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

2019年07月30日  | 移动技术网IT编程  | 我要评论

感应开关十大品牌,欧诗漫化妆品怎么样,3u8966

现在来介绍两种控件recyclerview和cardview,并通过实例将它们结合在一起实现一种横向卡片式滑动效果.

1.recyclerview

recyvlerview是android sdk 新增加的一种控件,也被官方推荐代替listview来使用,因为其具有更好的灵活性和代替性。

2.cardview

cardview是安卓5.0推出的一种卡片式控件,内部封装了许多有用的方法来实现美观效果。

3.如何使用recylerview和cardview在android studio中

在build.gradle中添加依赖再编辑即可

compile 'com.android.support:recyclerview-v7:25.+'
compile 'com.android.support:cardview-v7:25

4.通过实例,使用两种控件实现横向卡片式滑动效果

建立main.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"
       xmlns:app="http://schemas.android.com/apk/res-auto">

  <android.support.v7.widget.recyclerview
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:id="@+id/recycler_view"
    >

  </android.support.v7.widget.recyclerview>

</linearlayout>

使用过listview的同学应该知道还需要一个子布局来填充recyclerview
以下为recyclerview_item.xml的代码:

<?xml version="1.0" encoding="utf-8"?>
<linearlayout xmlns:android="http://schemas.android.com/apk/res/android"
                  xmlns:app="http://schemas.android.com/apk/res-auto"
       android:orientation="vertical"
       android:layout_width="match_parent"
       android:layout_height="match_parent"
       android:id="@+id/recyclerview_item"
       android:padding="30dp"

  >

  <android.support.v7.widget.cardview
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    app:contentpadding="50dp"
    app:cardcornerradius="20dp"
    android:clickable="true"

    android:foreground="?android:attr/selectableitembackground"
    app:cardelevation="@dimen/cardview_compat_inset_shadow"
    app:cardbackgroundcolor="@color/cardview_light_background">

    <linearlayout
      android:layout_width="match_parent"
      android:layout_height="wrap_content">

      <textview
        android:id="@+id/tv1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:text="作者"
        android:textsize="22dp"/>
    </linearlayout>

    <linearlayout
      android:layout_width="match_parent"
      android:layout_height="114dp"
      >
      <textview
        android:id="@+id/tv2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:text="
        锄禾日当午,汗滴禾下土"

        android:textsize="22dp"/>
    </linearlayout>
  </android.support.v7.widget.cardview>
</linearlayout>

从代码中,我们会发现使用了cardview控件以及在控件中添加简易的两个textview

现在来介绍cardview的一些常用属性,这也是现在卡片效果的关键所在

card_view:contentpadding 这个可以给你的内容加上padding属性
card_view:cardbackgroundcolor这个可以改变cardview的背景
card_view:cardcornerradius这个可以改变cardview圆角的大小
card_view:cardelevation这个比较难解释,cardview的z轴阴影,被用来决定阴影的大小以及柔和度,以至于可以逼真的模拟出对于深度效果的描述。说白点可以理解为阴影的大小
andorid:foreground=”?android:attr/selectableitembackground” 这个可以使cardview被点击后出现波纹效

通过以上常用属性可以使cardview出现各种不同的效果

现在回到activity中来实现recyclerview

跟listview的一样,我们需要写一个适配器,代码如下:

public class recyclerviewadapter extends recyclerview.adapter {
  private list<databean> lists;
  private context context;

  public recyclerviewadapter(list<databean> lists, context context) {
    this.lists = lists;
    this.context = context;
  }

  class myholder extends recyclerview.viewholder{

    private textview tv1,tv2;
    public myholder(view itemview) {
      super(itemview);
      tv1= (textview) itemview.findviewbyid(r.id.tv1);
      tv2= (textview) itemview.findviewbyid(r.id.tv2);


    }
  }

  @override
  public recyclerview.viewholder oncreateviewholder(viewgroup parent, int viewtype) {
    myholder holder =new myholder(layoutinflater.from(parent.getcontext()).inflate(r.layout.recyclerview_item,parent,false));
    return holder;
  }

  @override
  public void onbindviewholder(recyclerview.viewholder holder, int position) {
    log.d("tag", "onbindviewholder: "+lists.get(position).getautor());
    ((myholder)holder).tv1.settext(lists.get(position).getautor());
    ((myholder)holder).tv2.settext(lists.get(position).getcontent());

  }

  @override
  public int getitemcount() {
    return lists.size();
  }
}

写一个类继承recyclerview.adapter,重写recyclerview.adapter的三个重要方法 onbindviewholder() getitemcount() 和 oncreateviewholder()

oncreateviewholder(): 创建新的view,被layoutmanager所调用
onbindviewholder():将数据与界面进行绑定
getitemcount() :返回数据的数量

在activity中,代码如下:

public class frament1 extends android.support.v4.app.fragment{

  private toolbar toolbar1;
  private recyclerview recycler_view;
  private textview tv1,tv2;
  private view view;
  private list<databean> lists;


  @override
  public void onattach(context context) {

    super.onattach(context);
  }

  @nullable
  @override
  public view oncreateview(layoutinflater inflater, @nullable viewgroup container, @nullable bundle savedinstancestate) {
    sethasoptionsmenu(true);
     view = inflater.inflate(r.layout.fragment1, container, false);

    initview();
    initdata();
    linearlayoutmanager m=new linearlayoutmanager(getcontext());
    m.setorientation(linearlayoutmanager.horizontal);
    recycler_view.setlayoutmanager(m);
    recyclerviewadapter adapter=new recyclerviewadapter(lists,getcontext());
    recycler_view.setadapter(adapter);


    return view;
  }

  @override
  public void onresume() {
    super.onresume();

  }

  private void initdata() {
    lists=new arraylist<>();
    lists.add(new databean("smart","青青原上草,一岁一枯荣"));
    lists.add(new databean("smart","青青原上草,一岁一枯荣"));
    lists.add(new databean("smart","青青原上草,一岁一枯荣"));
    lists.add(new databean("smart","青青原上草,一岁一枯荣"));
    lists.add(new databean("smart","青青原上草,一岁一枯荣"));
    lists.add(new databean("smart","青青原上草,一岁一枯荣"));

  }

  private void initview() {
    recycler_view= (recyclerview) view.findviewbyid(r.id.recycler_view);
    tv1= (textview) view.findviewbyid(r.id.tv1);
    tv2= (textview) view.findviewbyid(r.id.tv2);


  }
}

在代码中,我们获取layoutmanager对象,设置其方向为水平方向,并设置recyclerview的layoutmanager

然后实例化adapter对象,传入上下文和假数据lists,并设置recyclerview.adapater

 linearlayoutmanager m=new linearlayoutmanager(getcontext());
    m.setorientation(linearlayoutmanager.horizontal);
    recycler_view.setlayoutmanager(m);
    recyclerviewadapter adapter=new recyclerviewadapter(lists,getcontext());
    recycler_view.setadapter(adapter);

到此基本步骤已经完成,运行程序。

以下为运行截图

这里写图片描述

**这里写图片描述**

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网