RecyclerView0基于使用

RecyclerView0基于使用

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

(转载请注明出处:http://www.kennethyo.me/post/android/recyclerviewchu-ji-shi-yong)

RecyclerView是Android在v7包中包括了一个新的widget。RecyclerView是一个ListView进阶版,但不继承与AdapterView。相比ListViewRecyclerView更加灵活和先进。

1。导入RecyclerView

首先要保证SDK ToolsAndroid Support Repository为最新版。

例如以下图:

RecyclerView0基于使用

RecyclerView0基于使用
其次,在你的demoproject里选中Project Structurebutton,而且选择app —— Dependencies —— “+” —— Library dependency,去加入支持包,例如以下图:

RecyclerView0基于使用

最后。在新的对话框里选中com.android.support:recyclerview-v7:21.0.0,点击OK。

例如以下图:

RecyclerView0基于使用
这里就顺利的导入了RecyclerView

2,使用RecyclerView

在布局文件里使用RecyclerView。跟其它自己定义控件一样,例如以下:

<RelativeLayout 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=".MainActivity">

    <android.support.v7.widget.RecyclerView
        android:id="@+id/recyclerView"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />
</RelativeLayout>

由于日常开发中,我们大多数都是依照UI去布局每一个item,所以这里我没与图省事用Android自带的布局。例如以下:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">


        <TextView
            android:id="@+id/textView"
            android:layout_width="match_parent"
            android:layout_height="48dp"
            android:textStyle="bold"
            android:background="@android:color/holo_blue_light"
            android:textColor="@android:color/holo_red_light"
            android:gravity="center_vertical"
            android:paddingLeft="@dimen/activity_horizontal_margin"
            android:text="New Text" />

</LinearLayout>

以下就是代码了:

@Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        recyclerView = (RecyclerView) findViewById(R.id.recyclerView);

        //LinearLayoutManager能够自己定义实现不同的动画效果和布局效果
        //这里设置为LinearLayoutManager.HORIZONTAL变成为了一个能够横向滑动的ListView,赞不赞?
        LinearLayoutManager layoutManager = new LinearLayoutManager(this,LinearLayoutManager.VERTICAL,false);
        recyclerView.setLayoutManager(layoutManager);
        recyclerView.setHasFixedSize(false);//adapter的改变不会改变RecyclerView的大小

        String[] strings = new String[50];
        for (int i = 0;i<50;i++){
            strings[i] = String.valueOf(i);
        }

        StringRecyclerAdapter adapter = new StringRecyclerAdapter(strings);

        recyclerView.setAdapter(adapter);

    }

能够明白看到的是,RecyclerView通过(RecyclerView) findViewById(R.id.recyclerView)初始化之后,不仅要像ListView一样要放入Adapter进行数据和布局的适配,并且还要额外加入一个LinearLayoutManager

这个Manager就是我们的布局管理工具类,这里不仅能够用常规的竖直方向布局。还有横向的滑动的布局,以后再也不会由于没有横向滑动的ListView去头疼自己定义了。

通过自己定义LinearLayoutManager也能够实现不同的动画效果,和移动效果。
RecyclerView的Adapter和ListView的Adapter也是不同的。RecyclerView的Adapter要继承RecyclerView.Adapter<VH extends ViewHolder>,而且ViewHolder要继承与ViewHolder.RecyclerView。详细代码例如以下:

public class StringRecyclerAdapter extends RecyclerView.Adapter<StringRecyclerAdapter.ViewHolder> {
    private String[] strings;

    public StringRecyclerAdapter(String[] strings) {
        this.strings = strings;
    }

    @Override
    public ViewHolder onCreateViewHolder(ViewGroup viewGroup, int i) {
        View view = View.inflate(viewGroup.getContext(), R.layout.adapter_string_recylcer, null);

       //这里发现不给item布局加入LayoutParams,会直接默觉得WRAP_CONTENT。WRAP_CONTENT布局。

view.setPadding(20, 0,0, 0); view.setFocusable(true); RecyclerView.LayoutParams lp = new RecyclerView.LayoutParams( ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT); lp.leftMargin = 10; lp.rightMargin = 5; lp.topMargin = 20; lp.bottomMargin = 15; view.setLayoutParams(lp); ViewHolder viewHolder = new ViewHolder(view); return viewHolder; } @Override public void onBindViewHolder(ViewHolder viewHolder, int i) { viewHolder.textView.setText(StringRecyclerAdapter.class.getSimpleName() + getValueAt(i)); } public String getValueAt(int i) { return strings[i]; } @Override public int getItemCount() { return this.strings == null ? 0 : strings.length; } public static class ViewHolder extends RecyclerView.ViewHolder implements View.OnClickListener { public TextView textView; public ViewHolder(View itemView) { super(itemView); textView = (TextView) itemView.findViewById(R.id.textView); //由于RecyclerView没用setOnItemClickListener,所以在这里实现了点击事件 //况且,如今有越来越多的设计,会在每一个item点击不同位置,有不同的响应 textView.setOnClickListener(this); } @Override public void onClick(View v) { Toast.makeText(v.getContext(),((TextView)v).getText(),Toast.LENGTH_SHORT).show(); } } }

onCreateViewHolder方法中,我们须要把载入布局和ViewHolder绑定起来。这里有个问题。不知道是Android的bug。还是有益这么设计的,须要我们主动写代码给item设置LayoutParams
onBindViewHolder中负责数据绑定。


这里有一个问题,RecyclerView没有setOnItemClickListener方法,所以我在里面对TextView加入了点击事件,如今有越来越多的设计,会在每一个item点击不同位置。有不同的响应。

RecyclerView0基于使用

Demo链接

版权声明:本文博客原创文章。博客,未经同意,不得转载。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/117428.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • synchronized偏向锁和轻量级锁_线程synchronized用法

    synchronized偏向锁和轻量级锁_线程synchronized用法今天简单了解了一下java轻量级锁和重量级锁以及偏向锁。看了看这篇文章觉得写的不错原文链接java 偏向锁、轻量级锁及重量级锁synchronized原理Java对象头与Monitorjava对象头是实现synchronized的锁对象的基础,synchronized使用的锁对象是存储在Java对象头里的。对象头包含两部分:Mark Word 和 Class Metadata Address其中Mark Word在默认情况下存储着对象的HashCode、分代年龄、锁标记位等以下是32位JVM的

    2022年8月9日
    8
  • 哈佛结构和冯·诺依曼结构的区别和联系_edsac是第一台冯诺依曼机吗

    哈佛结构和冯·诺依曼结构的区别和联系_edsac是第一台冯诺依曼机吗一、哈佛结构    哈佛结构(Harvardarchitecture)是一种将程序指令储存和数据储存分开的存储器结构。中央处理器首先到程序指令储存器中读取程序指令内容,解码后得到数据地址,再到相应的数据储存器中读取数据,并进行下一步的操作(通常是执行)。程序指令储存和数据储存分开,数据和指令的储存可以同时进行,可以使指令和数据有不同的数据宽度,如Microchip公司的PIC16芯…

    2022年9月27日
    0
  • WPF 控件专题 WrapPanel 控件详解「建议收藏」

    WPF 控件专题 WrapPanel 控件详解「建议收藏」WPF控件专题WrapPanel控件详解

    2022年7月23日
    6
  • vue删除数组中的某个对象_vue修改数组的元素的值

    vue删除数组中的某个对象_vue修改数组的元素的值vue数组对象过滤

    2022年10月21日
    1
  • Freemarker判断对象是否为空的用法

    Freemarker判断对象是否为空的用法注:https://blog.csdn.net/elladu/article/details/80393814freemark判断对象的属性&lt;#if(${blog.belongid==1})&gt;red&lt;/#if&gt;以上不对,应该是&lt;#if(blog.belongid==1)&gt;red&lt;/#if&gt;参考…

    2022年5月24日
    56
  • java clone()_java throwable

    java clone()_java throwable克隆是一种基本的编程模式。事实上,Java在很多方面可能实现得很差,但这丝毫没有减少克隆的必要性。而且,很容易实现克隆,无论你希望它如何工作,浅层的,深层的,混合的,无论什么。如果愿意的话,甚至可以为函数使用clone名称,而不实现Cloneable。假设我有类A、B和C,其中B和C是从A派生的。如果我有一个A类型的对象列表,如下所示:ArrayListlist1;ArrayListlist2…

    2022年10月10日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号