本文实例为大家分享了Android列表时间轴展示的具体代码,供大家参考,具体内容如下

实现的效果图如下:

实现的方式是利用recycleview的ItemDecoration这个抽象类,就是我们经常用来画分割线的的这个类,
具体如下

public class DividerItemDecoration extends RecyclerView.ItemDecoration{ // 写右边字的画笔(具体信息) private Paint mPaint; // 写左边日期字的画笔( 时间 + 日期) private Paint mPaint1; private Paint mPaint2; private Paint mPaint3; // 左 上偏移长度 private int itemView_leftinterval; private int itemView_topinterval; // 轴点半径 private int circle_radius; // 图标 private Bitmap mIcon; //月份合集(使用时需要设置) private List monthList= new ArrayList<>(); //年份合集(使用时需要设置) private List yearList= new ArrayList<>(); public void setMonthList(List monthList) {  this.monthList = monthList; } public void setYearList(List yearList) {  this.yearList = yearList; } // 在构造函数里进行绘制的初始化,如画笔属性设置等 public DividerItemDecoration(Context context) {  // 轴点画笔(红色)  mPaint = new Paint();  mPaint.setColor(Color.rgb(58, 154, 239));  mPaint.setStyle(Paint.Style.STROKE);  mPaint.setStrokeWidth(3);  // 左边时间文本画笔(蓝色)  // 此处设置了两只分别设置 时分 & 年月  mPaint1 = new Paint();  mPaint1.setColor(Color.BLACK);  mPaint1.setTextSize(30);  mPaint2 = new Paint();  mPaint2.setColor(context.getResources().getColor(R.color.divider));  mPaint2.setTextSize(26);  mPaint3 = new Paint();  mPaint3.setColor(Color.rgb(58, 154, 239));  mPaint3.setTextSize(20);  // 赋值ItemView的左偏移长  itemView_leftinterval = 150;  // 赋值ItemView的上偏移长度  itemView_topinterval = 30;  // 赋值轴点圆的半径为10  circle_radius = 8; } // 重写getItemOffsets()方法 // 作用:设置ItemView 左 & 上偏移长度 @Override public void getItemOffsets(Rect outRect, View view, RecyclerView parent, RecyclerView.State state) {  super.getItemOffsets(outRect, view, parent, state);  // 设置ItemView的左 & 上偏移长度分别为150 px & 30px,即此为onDraw()可绘制的区域  outRect.set(itemView_leftinterval, itemView_topinterval, 0, 0); } // 重写onDraw() // 作用:在间隔区域里绘制时光轴线 & 时间文本 @Override public void onDraw(Canvas c, RecyclerView parent, RecyclerView.State state) {  super.onDraw(c, parent, state);  // 获取RecyclerView的Child view的个数  int childCount = parent.getChildCount();  // 遍历每个Item,分别获取它们的位置信息,然后再绘制对应的分割线  for (int i = 0; i < childCount; i++) {   // 获取每个Item对象   View child = parent.getChildAt(i);   View lastChild = null;   if (i > 0) {    lastChild = parent.getChildAt(i - 1);   }   /**    * 绘制轴点    */   // 轴点 = 圆 = 圆心(x,y) 位置可以根据需求来调节   float centerx = child.getLeft() - itemView_leftinterval / 4;   float centery = child.getTop() + itemView_topinterval +10;   // 绘制轴点圆   c.drawCircle(centerx, centery, circle_radius, mPaint);   /**    * 绘制上半轴线(x轴是保持不变的)    */   // 上端点坐标(x,y)   float upLine_up_x = centerx;   float upLine_up_y = 0;   if (i>0){     upLine_up_y = lastChild.getBottom();   }else {     upLine_up_y = centery - itemView_topinterval;   }   // 下端点坐标(x,y)   float upLine_bottom_x = centerx;   float upLine_bottom_y = centery - circle_radius;   //绘制上半部轴线   c.drawLine(upLine_up_x, upLine_up_y, upLine_bottom_x, upLine_bottom_y, mPaint);   /**    * 绘制下半轴线,最后一个不画下半轴    */   if (i     

使用比较简单:

DividerItemDecoration dividerItemDecoration = new DividerItemDecoration(this);  dividerItemDecoration.setMonthList(monthList);  dividerItemDecoration.setYearList(yearList);  mRecyclerView.addItemDecoration(dividerItemDecoration);

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

更多相关文章

  1. 动态设置布局属性
  2. android关于控件中setTag(key,Object)的设置的相关问题
  3. 使用xml让你的Activity无标题方法
  4. Android(安卓)自定义View探索——图片
  5. android设置ImageView边框
  6. Android中通过typeface设置字体textAppearance设置文字外观
  7. android新特性,CoordinatorLayout,TabLayout+viewpager+fragment,
  8. Android(安卓)L 沉浸式状态栏和圆形动画实现炫酷效果
  9. Android(安卓)画图Path的使用

随机推荐

  1. android 意见反馈
  2. Android开发基础—通过匿名内部类实现按
  3. Android(安卓)录像添加时间戳水印
  4. 【Android四大组件之Service】(二)Android
  5. Android技术提升
  6. Android的view重绘
  7. cocos2dx android mk 2.0.2编译文件目录
  8. Android(安卓)开发技术选型(博客,新闻,阅读
  9. Android总结之链式调用(方法链)
  10. Android模拟器学framework和driver之batt