之前實現時間軸的方式,總體來說就是通過ListView的方式。看到網友評論說到RecycleView,就嘗試了一下,結果發現用RecycleView實現時間更加高效,尤其是在實現橫向時間軸的時候。
RecycleView 是什麼?
RecyclerView 是Android L版本中新添加的一個用來取代ListView的SDK,它的靈活性與可替代性比listview更好。
在百度上一搜RecycleView,很多介紹都是以這樣的開頭。RecycleView的確比ListView靈活了許多,通過設置它提供的不同LayoutManager,ItemDecoration , ItemAnimator可以實現很拉風的視圖效果和用戶操作體驗。(下面你馬上就可以體驗到)
縱向時間軸
縱向時間軸的實現,類似於使用ListView實現,只是起Adapter和ListView的Adapter有所不同,但整體思路是一樣的。
- Adapter 實現
public class MyRecyclerAdapter extends
RecyclerView.Adapter<MyRecyclerAdapter.MyViewHolder> {
List<ItemBean> lists;
Context mContext;
public MyRecyclerAdapter(List<ItemBean> lists, Context mContext) {
super();
this.lists = lists;
this.mContext = mContext;
}
/*
* 覆蓋方法
*/
@Override
public int getItemCount() {
// TODO 自動生成的方法存根
return lists.size();
}
/*
* 覆蓋方法
*/
@Override
public MyViewHolder onCreateViewHolder(ViewGroup arg0, int arg1) {
// TODO 自動生成的方法存根
LayoutInflater inflater = LayoutInflater.from(mContext);
View view = inflater.inflate(R.layout.item_view, arg0, false);
MyViewHolder holder = new MyViewHolder(view);
return holder;
}
class MyViewHolder extends ViewHolder {
TextView title,time;
View line;
/**
* @param itemView
*/
public MyViewHolder(View itemView) {
super(itemView);
// TODO 自動生成的構造函數存根
title = (TextView) itemView.findViewById(R.id.show_title);
time= (TextView) itemView.findViewById(R.id.show_time);
line = itemView.findViewById(R.id.line_normal);
}
}
/*
* 覆蓋方法
*/
@Override
public void onBindViewHolder(MyViewHolder arg0, int arg1) {
// TODO 自動生成的方法存根
arg0.title.setText(lists.get(arg1).getTitle());
arg0.time.setText(lists.get(arg1).getTime());
//最後一項時,豎線不再顯示
if (arg1 == lists.size() - 1) {
arg0.line.setVisibility(View.GONE);
}
}
}
這裏需要注意的是,佈局文件view_item.xml 最外層的View必須是高度必須是wrap_content.
效果如圖
橫向時間軸
在實現橫向的時間軸時,就體現出了RecycleView的優勢來。
在之前的文章中提到,此時需要自定義實現橫向的ListView。但是對RecycleView來說,變成橫向佈局,簡直太容易了。代碼如下:
- 設置RecycleView爲橫向
recycview=(RecyclerView) findViewById(R.id.recyclerview);
adapter=new MyRecyclerAdapter2(datas,mContext);
//設置佈局管理器
LinearLayoutManager linearLayoutManager = new LinearLayoutManager(this);
linearLayoutManager.setOrientation(LinearLayoutManager.HORIZONTAL);
recycview.setLayoutManager(linearLayoutManager);
recycview.setAdapter(adapter);
RecycleView就是這麼任性,只需要在設置佈局管理器時制定方向爲HORIZONTAL,那麼整個View就會在水平方向做延伸,很容易的就實現了一個橫向的列表。
- Adapter
public class MyRecyclerAdapter2 extends
RecyclerView.Adapter<MyRecyclerAdapter2.MyViewHolder> {
List<ItemBean> lists;
Context mContext;
public MyRecyclerAdapter2(List<ItemBean> lists, Context mContext) {
super();
this.lists = lists;
this.mContext = mContext;
}
/*
* 覆蓋方法
*/
@Override
public int getItemCount() {
// TODO 自動生成的方法存根
return lists.size();
}
/*
* 覆蓋方法
*/
@Override
public MyViewHolder onCreateViewHolder(ViewGroup arg0, int arg1) {
// TODO 自動生成的方法存根
LayoutInflater inflater = LayoutInflater.from(mContext);
View view = inflater.inflate(R.layout.item_view2, arg0, false);
MyViewHolder holder = new MyViewHolder(view);
return holder;
}
class MyViewHolder extends ViewHolder {
TextView title,time;
View lineNorma, lineHiLight;
ImageView image;
/**
* @param itemView
*/
public MyViewHolder(View itemView) {
super(itemView);
// TODO 自動生成的構造函數存根
title = (TextView) itemView.findViewById(R.id.show_title);
time= (TextView) itemView.findViewById(R.id.show_time);
lineNorma = itemView.findViewById(R.id.line_normal);
lineHiLight = itemView.findViewById(R.id.line_highlight);
image = (ImageView) itemView.findViewById(R.id.image);
}
}
/*
* 覆蓋方法
*/
@Override
public void onBindViewHolder(MyViewHolder item, int position) {
// TODO 自動生成的方法存根
item.title.setText(lists.get(position).getTitle());
item.time.setText(lists.get(position).getTime());
//最後一項時,豎線不再顯示
if (position == 0) {
item.lineNorma.setVisibility(View.INVISIBLE);
item.lineHiLight.setVisibility(View.INVISIBLE);
item.time.setVisibility(View.VISIBLE);
}else {
if (lists.get(position).getStatu() == 1) {
item.lineHiLight.setVisibility(View.VISIBLE);
item.image.setImageResource(R.drawable.point1);
item.time.setVisibility(View.VISIBLE);
}
}
}
}
這裏同樣需要注意,item_view2佈局文件最外層的View的寬度需設置爲wrap_content。
效果圖
好了,這就是用RecycleView實現橫豎時間軸的兩種方式。
可以看到RecycleView的確很靈活。當然了,這裏提到的只是冰山一角,Google官方提出用其替代ListView及GridView,在性能方面必然也有它的優勢,所以以後開發需羅列大量數據時可以考慮使用RecycleView。