RecyclerView出現(xiàn)已經(jīng)有一段時間了簇秒,在網(wǎng)上也有很多學習的教程皱坛,準備整理一下,總結一下RecyclerView使用時要實現(xiàn)的常用功能.
一蝌戒、使用前提
dependencies {
compile 'com.android.support:recyclerview-v7:25.0.1'
}
二瑟慈、實現(xiàn)常見的ListView效果
1桃移、布局文件
(1)、MainActivity 布局文件
沒什么好說的葛碧,直接放入RecyclerView就行了
<?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"
android:orientation="vertical">
<android.support.v7.widget.RecyclerView
android:id="@+id/recyclerview"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
</LinearLayout>
(2)借杰、RecyclerViewt條目的布局文件
和ListView一樣,你每個條目的布局應該是什么樣就設計成什么樣
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:background="#ff33b5e5"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<TextView
android:id="@+id/tv"
android:layout_width="match_parent"
android:layout_height="40dp"
android:gravity="center"
tools:text="別看了进泼,我就是一個TextView" />
</RelativeLayout>
2蔗衡、Activity中
public class MainActivity extends AppCompatActivity {
private RecyclerView mRecyclerView;
private LinearLayoutManager layoutManager;
private MainAdapter mAdapter;
private List<String> mDatas;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
/**
* 和使用ListView的步驟差不多:初始化組件、設置適配器
* 只不過這里多了一個設置布局管理器RecyclerView.LayoutManager這一步
*/
initData();
mRecyclerView = (RecyclerView) findViewById(R.id.recyclerview);
layoutManager = new LinearLayoutManager(this, LinearLayoutManager.VERTICAL, false);
mRecyclerView.setLayoutManager(layoutManager);
mAdapter = new MainAdapter(this,mDatas);
mRecyclerView.setAdapter(mAdapter);
}
private void initData() {
mDatas = new ArrayList<>();
for (int i = 'A'; i < 'Z'; i++) {
mDatas.add("" + (char) i);
}
}
}
3乳绕、數(shù)據(jù)適配器中
public class MainAdapter extends RecyclerView.Adapter<MainAdapter.MyViewHolder> {
private Context mContext;
private List<String> mDatas;
public MainAdapter(Context context, List<String> mDatas) {
this.mContext = context;
this.mDatas = mDatas;
}
/**
* 創(chuàng)建ViewHolder
* 在這里我們要做的就是把RecyclerView的item布局填充成View對象绞惦,然后返回ViewHolder對象
*/
@Override
public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View view = View.inflate(mContext, R.layout.item_layout, null);
return new MyViewHolder(view);
}
/**
* 加載數(shù)據(jù)到View中
* 在這里我們要做的就是加載每個item要顯示的數(shù)據(jù)
*/
@Override
public void onBindViewHolder(MyViewHolder holder, int position) {
holder.tv.setText(mDatas.get(position));
}
/**
* 和ListView一樣,返回item的數(shù)量
*/
@Override
public int getItemCount() {
return mDatas.size();
}
/**
* 在ListView中洋措,很多人都不懂使用ViewHolder, 這也導致了使用ListView性能比較差
* 而創(chuàng)建RecyclerView的數(shù)據(jù)適配器時強制我們使用ViewHolder
*/
class MyViewHolder extends RecyclerView.ViewHolder {
TextView tv;
// 這里的參數(shù)view就是每個item的布局轉換的View對象,在這里我們要做的就是初始化item要顯示數(shù)據(jù)的組件
public MyViewHolder(View view) {
super(view);
tv = (TextView) view.findViewById(R.id.tv);
}
}
}
4济蝉、效果圖
好了,簡單的ListView效果實現(xiàn)了菠发,下面讓我們來看一下效果圖