在Android的项目中,需要大量的列表组件来显示数据,在之前的项目中一直使用的是ListView 组件,但是在最新的V7包中出现了能后替代ListView的组件RecycleView。
所以在新的项目中使用了大量的RecycleView来替代ListView。
在使用RecycleView的时候,发现做了大量的重复操作,所以对RecycleView进行了简单的封装,方便在项目中视使用。
封装的操作主要是针对RecycleViewAdapter的封装,具体的功能如下:
- 可以添加多个头视图、尾视图
- 可以设置默认的分割线
- 可以隐藏第一个、第二个头视图的分割线
- 简化适配器中的方法
- 为ItemView设置点击事件
GitHub的地址:https://github.com/Wan7451/Wan_RecycleViewAdapter
具体的使用方式如下:
ArrayList<String> data = new ArrayList<>();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
for (int i = 0; i < 100; i++) {
data.add("Item" + i);
}
RecyclerView mainView = (RecyclerView) findViewById(R.id.mianView);
WGAdapter adapter = new WGAdapter(this, data, android.R.layout.simple_list_item_1);
mainView.setAdapter(adapter);
ImageView headerView = new ImageView(this);
headerView.setImageResource(R.mipmap.ic_launcher);
adapter.addHeaderView(headerView); //添加头视图
Button footerView = new Button(this);
footerView.setText("load");
adapter.addFooterView(footerView); //添加尾视图
WanItemDecoration item = new WanItemDecoration(this, WanItemDecoration.VERTICAL_LIST);
//item.setIsShowSecondItemDecoration(false); //不显示第一行 分割线
item.setIsShowFirstItemDecoration(false); //不显示第二行 分割线
item.setMarginLeftDP(10); //分割线左边距
item.setMarginRightDP(10); //分割线右边距
mainView.addItemDecoration(item); //添加分割线
mainView.setLayoutManager(new LinearLayoutManager(this));
adapter.setOnItemClickListener(this); //设置点击事件
}
@Override
public void onItemClickListener(int posotion) {
Toast.makeText(this, data.get(posotion), Toast.LENGTH_LONG).show();
}
class WGAdapter extends WanAdapter<String> {
protected WGAdapter(Context context, List<String> mDatas, int itemLayoutId) {
super(context, mDatas, itemLayoutId);
}
/**
* @param holder itemHolder
* @param item 每一Item显示的数据
*/
@Override
public void convert(WanViewHolder holder, String item) {
//holder.setText(android.R.id.text1, item);
//或者
TextView text = holder.getView(android.R.id.text1);
text.setText(item);
}
}
注意:如果要定义分割线的样式,需要添加属性:
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
<!-- ################################################ -->
<!-- 分割线的样式有这里定义。 一般都是Drawable -->
<item name="android:listDivider">@drawable/divider</item>
</style>