RecyclerView入门原理

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内容进行逐步加深

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容