(转载请注明出处:http://www.kennethyo.me/post/android/recyclerviewchu-ji-shi-yong)
RecyclerView
是Android在v7包中包括了一个新的widget。RecyclerView
是一个ListView
进阶版,但不继承与AdapterView
。相比ListView
,RecyclerView
更加灵活和先进。
1。导入RecyclerView
首先要保证SDK Tools
和Android
为最新版。
Support Repository
例如以下图:
其次,在你的demoproject里选中Project Structurebutton,而且选择app —— Dependencies —— “+” —— Library dependency,去加入支持包,例如以下图:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQva2VubmV0aHlv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" >
最后。在新的对话框里选中com.android.support:recyclerview-v7:21.0.0
,点击OK。
例如以下图:
这里就顺利的导入了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点击不同位置。有不同的响应。
版权声明:本文博客原创文章。博客,未经同意,不得转载。