RecyclerView是个很强大的item集合展示框,我们有很大的DIY空间对其进行自定义,以期待符合不同的应用场景。但是相对的,强大的适配能力必然面临着更多的自定义实现、更复杂的代码结构,而不只是如ListView和GridView那样利用现成的Adapter进行structor,然后setAdapter就完事儿。通常RecyclerVIew有如下DIY空间(即类):
<code>
1.RecyclerView.Adapter,必须自定义实现
2.RecyclerView.ViewHolder,必须自定义实现,Google强制开发者使用ViewHolder的一个里程碑
3.RecyclerView.LayoutManager,必须使用,但是默认实现可用(可以偷懒)
4.RecyclerView.ItemDecoration,代码中可以省略,有默认项,也可以自定义实现
5.RecyclerView.ItemAnimator,代码中可以省略,有默认项,也可以自定义实现
</code>
下面我们就1、2点进行重点分析它们各自的作用,其他三项在此基础上可以进行后续进一步学习
<code>
ViewHolder主要用于保存RecyclerView中每个Item的View引用(如:TextVIew文本)
Adapter中有三个实现的接口,并且使用一个单参构造器:
构造器:
//获取数据源
public CustomAdapter(List<String> dataSet)
三个实现接口:
//返回数据源大小
public int getItemCount();
//返回的ViewHolder以item为构造器参数(LayoutInflater中转)
public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType);
//为item中的每个view赋值,注册监听时间
public void onBindViewHolder(MyViewHolder holder, int position);
</code>
下面是使用RecyclerView实现ListView的具体功能:
item_layout.xml:
<pre>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="?android:attr/listPreferredItemHeight"
android:padding="6dp">
<TextView
android:id="@+id/firstLine"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:gravity="center_vertical"
android:text="@string/example"
android:textSize="16sp"
/>
</RelativeLayout>
</pre>
activity_main.xml:
<pre>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/activity_main"
android:layout_width="match_parent"
android:layout_height="match_parent"
>
<android.support.v7.widget.RecyclerView
android:id="@+id/recyclerview"
android:layout_width="match_parent"
android:layout_height="match_parent"
/>
</RelativeLayout>
</pre>
SimpleAdapter代码:
<pre>
public class SimpleAdapter extends RecyclerView.Adapter<SimpleAdapter.MyViewHolder> {
private List<String> mDataSet;
class MyViewHolder extends RecyclerView.ViewHolder{
private TextView mTextView;
public MyViewHolder(View itemView) {
super(itemView);
mTextView = (TextView) itemView.findViewById(R.id.firstLine);
}
public TextView getTextView(){
return mTextView;
}
}
public SimpleAdapter(List<String> dataSet) {
mDataSet = dataSet;
}
@Override
public int getItemCount() {
return mDataSet.size();
}
@Override
public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_layout, parent, false);
return new MyViewHolder(view);
}
@Override
public void onBindViewHolder(MyViewHolder holder, int position) {
holder.getTextView().setText(mDataSet.get(position));
}
}
</pre>
MainActivity代码:
<pre>
public class MainActivity extends AppCompatActivity {
private RecyclerView mRecyclerView;
private List<String> arrays;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initData();
mRecyclerView = (RecyclerView) findViewById(R.id.recyclerview);
LinearLayoutManager llm = new LinearLayoutManager(this,LinearLayoutManager.VERTICAL,false);
mRecyclerView.setLayoutManager(llm);
SimpleAdapter adapter = new SimpleAdapter(arrays);
mRecyclerView.setAdapter(adapter);
}
private void initData() {
arrays = new ArrayList<String>();
for(int i=0;i<50;i++){
arrays.add("this is element # "+i);
}
}
}
</pre>
AndroidManifest文件:
<pre>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.recyclerviewdemo">
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<activity android:name=".MainActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN"/>
<category android:name="android.intent.category.LAUNCHER"/>
</intent-filter>
</activity>
</application>
</manifest>
</pre>
以上就是RecyclerView的简单入门内容,其他的自定义内容可以参考官网API内容进行逐步加深