Android基于CountDownView的时间控件扩展

首先,新年的一年里祝大家,心想事成,鸡年大吉。去年的时候,我们做时间控件的时候一直遗留一个问题那就是正计时控件一直没有好的解决方案,我们很想把CountDownView既支持正计时又能支持倒计时。基于这个想法,便有了今天这篇文章,原理不在介绍,其实很简单,主要是我们知道怎么用,此控件的优点有:

* 实现了正计时倒计时的统一
* 优化了Adapter,不再绑定控件Id
* 一个属性实现正倒计时
* 不在为具体的时间属性设置别名

具体用法

1、xml文件

属性 app:isCountUp=”false”代表倒计时 true为正计时

<com.delta.library.CountTimeView
    android:id="@+id/cv_countView"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignParentRight="true"
    android:layout_gravity="center_horizontal"
    android:layout_marginTop="20dp"
    app:isCountUp="false"
    app:isShowDay="true"
    app:isShowHour="true"
    app:isShowMillisecond="false"
    app:isShowMinute="true"
    app:isShowSecond="true"
    app:suffixDay="天"
    app:suffixDayRightMargin="10dp"
    app:suffixGravity="center"
    app:suffixHour=":"
    app:suffixMinute=":"
    app:suffixTextColor="#e61010"
    app:suffixTextSize="17sp"
    app:timeTextColor="#e60b0b"
    app:timeTextSize="20sp" />

2、实体类

要继承TimeEntity
eg:

package com.delta.counttimeview;

/**
 * @description :正计时的
 * @autHor : V.Wenju.Tian
 * @date : 2017/2/6 15:31
 */

public class ItemEntity extends TimeEntity {

  private String title;

  private Long time;

  public ItemEntity() {
  }

  public ItemEntity(int id, long endTime, long createTime, String title, Long upTime) {
    super(id, endTime, createTime);
    this.title = title;
    this.time = upTime;
  }

  public Long getTime() {
    return time;
  }

  public void setTime(Long time) {
    this.time = time;
  }

  public void setTitle(String title) {
    this.title = title;
  }

  public String getTitle() {
    return title;
  }
}

3、Adapter如下

倒计时 主要是==要注意在数据源的时候初始化endTime属性,也就是截止时间还有相应的EntityId==

public class CountDownActivity extends AppCompatActivity {

  private RecyclerView rv;
  private List<ItemEntity> datas = new ArrayList<>();
  private ItemCountViewAdapter<ItemEntity> mMyAdapter;

  @Override
  public void onCreate(Bundle savedInstanceState) {

    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_count_down);
    rv = ((RecyclerView) findViewById(R.id.rv));
    long time =System.currentTimeMillis();
    for (int i = 0; i < 100; i++) {
      ItemEntity entity = new ItemEntity();
      entity.setEntityId(i);
      entity.setTitle("第" + i);
      entity.setTime(i *60 *1000l);
      entity.setEndTime(time + entity.getTime());
      datas.add(entity);
    }
    mMyAdapter = new ItemCountViewAdapter<ItemEntity>(this, datas) {
      @Override
      protected int getCountViewId() {
        return R.id.cv_countView;
      }

      @Override
      protected int getLayoutId() {
        return R.layout.item_count_down;
      }

      @Override
      protected void convert(ItemTimeViewHolder holder, ItemEntity itemEntity, int position) {

        holder.setText(R.id.tv_title, itemEntity.getTitle());
      }
    };
    rv.setLayoutManager(new LinearLayoutManager(this));
    rv.setAdapter(mMyAdapter);

  }

  @Override
  protected void onResume() {
    super.onResume();
    if (null != mMyAdapter) {
      mMyAdapter.startRefreshTime();
    }
  }

  @Override
  protected void onPause() {
    super.onPause();
    if (null != mMyAdapter) {
      mMyAdapter.cancelRefreshTime();
    }
  }

  @Override
  public void onDestroy() {
    super.onDestroy();
    if (null != mMyAdapter) {
      mMyAdapter.cancelRefreshTime();
    }
  }
}

正计时 ==主要是在获得数据源的时候初始化createTime,也就是起始时间和EntityId==

public class CountUpActivity extends AppCompatActivity {

  private RecyclerView rv;
  private List<ItemEntity> datas = new ArrayList<>();
  private ItemCountViewAdapter<ItemEntity> mMyAdapter;

  @Override
  public void onCreate(Bundle savedInstanceState) {

    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_count_up);
    rv = ((RecyclerView) findViewById(R.id.rv));

    for (int i = 0; i < 100; i++) {
      ItemEntity entity = new ItemEntity();
      entity.setEntityId(i);
      entity.setTitle("第" + i);
      entity.setTime(i * 60 * 60 * 1000l);
      entity.setCreateTime(System.currentTimeMillis() - entity.getTime());
      datas.add(entity);
    }
    mMyAdapter = new ItemCountViewAdapter<ItemEntity>(this, datas) {
      @Override
      protected int getCountViewId() {
        return R.id.cv_countView;
      }

      @Override
      protected int getLayoutId() {
        return R.layout.list_item;
      }

      @Override
      protected void convert(ItemTimeViewHolder holder, ItemEntity itemEntity, int position) {

        holder.setText(R.id.tv_title, itemEntity.getTitle());
      }
    };
    rv.setLayoutManager(new LinearLayoutManager(this));
    rv.setAdapter(mMyAdapter);

  }
  @Override
  protected void onResume() {
    super.onResume();
    if (null != mMyAdapter) {
      mMyAdapter.startRefreshTime();
    }
  }

  @Override
  protected void onPause() {
    super.onPause();
    if (null != mMyAdapter) {
      mMyAdapter.cancelRefreshTime();
    }
  }

  @Override
  public void onDestroy() {
    super.onDestroy();
    if (null != mMyAdapter) {
      mMyAdapter.cancelRefreshTime();
    }
  }
}

下载源码

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

(0)

相关推荐

  • Android滚轮选择时间控件使用详解

    滚轮选择控件 Android自带的选择时间控件有点丑,往往产品和设计都比较嫌弃,希望做成ios一样的滚轮选择,下面是我在NumberPicker的基础上自定义的选择控件,效果如下: 原理 基于NumberPicker实现 动态填充数值 联动 接口监听回调 实现滚轮效果有github上mark比较多的WheelView,但是阅读源码发现数据是一次性填入的,选择时间的话,填入10年就是10*365=3650条数据,也就是new出三千多个TextView,想想都觉得恐怖,肯定是不行的,于是便想到用Nu

  • Android基于CountDownView的时间控件扩展

    首先,新年的一年里祝大家,心想事成,鸡年大吉.去年的时候,我们做时间控件的时候一直遗留一个问题那就是正计时控件一直没有好的解决方案,我们很想把CountDownView既支持正计时又能支持倒计时.基于这个想法,便有了今天这篇文章,原理不在介绍,其实很简单,主要是我们知道怎么用,此控件的优点有: * 实现了正计时倒计时的统一 * 优化了Adapter,不再绑定控件Id * 一个属性实现正倒计时 * 不在为具体的时间属性设置别名 具体用法 1.xml文件 属性 app:isCountUp="fals

  • Android开发中DatePicker日期与时间控件实例代码

    一.简介 二.方法 最日常的使用方法了 日期控件DatePicker 时间控件TimePicker 月份从0开始 三.代码实例 效果图: 代码: fry.Activity01 package fry; import com.example.DatePicherDemo1.R; import android.app.Activity; import android.os.Bundle; import android.widget.DatePicker; import android.widget.

  • Android 自定义日期段选择控件功能(开始时间-结束时间)

    开发中碰到个需求,需要在一个空间中选择完成开始和结束时间.实现的过程走的是程序员开发的老路子,找到轮子后自己改吧改吧就成了. 当时做的时候有几个需求:1.当天为最大的结束日期,2.最大选择范围1年,3.开始时间和结束时间可以为同一天.如有其他需求实现,可以参考代码改进一下.先上效果图: 视频点击后的虚影是屏幕录制的原因.实现步骤:(如有缺失什么资源,请告知.开始时间和结束时间显示自己布局内添加就可以) 1.自定义控件属性 <declare-styleable name="MyCalenda

  • 总结Android中MD风格相关控件

    要使用MD风格控件,首先需要在Gradle中加入Support Design Library,例如: compile 'com.android.support:design:24.1.1' 一.CoordinatorLayout 1.CoordinatorLayout + AppBarLayout 布局文件代码如下: <android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.

  • Android 实现IOS 滚轮选择控件的实例(源码下载)

     Android 实现IOS 滚轮选择控件的实例 最近根据项目需要,整理了一个相对比较全面的 WheelView 使用控件,借用之前看到的一句话来说,就是站在巨人肩膀上,进行了一些小调整. 这里先贴上效果图 一般常用的时间选择格式,,单项选择,以及城市联动,这里基本都可以满足了. 这里把 单项选择,和 日期时间选择 给提出到 Util 类中,代码如下: public class Util { /** * 时间选择回调 */ public interface TimerPickerCallBack

  • Android 自定义底部上拉控件的实现方法

    前言 又到了新的一月,今天提供一个Android自定义底部上拉布局的实现,起因是自己在项目中需要实现这样一个控件,干脆自己写一个练练手. 写完了觉得能想到的需求都基本有了(可能会有其它需求,不过基本上改吧改吧就行了),又花了一点时间直接放到了Github上托管,希望能给您一些参考价值: SlideBottomLayout-Android 简单易上手的Android底部上拉控件 先看一下实现效果: 分析一下这种控件的基本需求有以下几种: 1.有一个部分是能够作为把手(就是图中的handle,)进行

  • android自定义圆形倒计时显示控件

    本文实例为大家分享了android自定义圆形倒计时显示控件的具体代码,供大家参考,具体内容如下 先上效果图 - 倒计时结束 代码块 attr.xml 控件需要用到的属性: <?xml version="1.0" encoding="utf-8"?> <resources> <declare-styleable name="CountDownView"> <!--颜色--> <attr name

  • android自定义WaveView水波纹控件

    本文实例为大家分享了android自定义WaveView水波纹控件的使用方法,供大家参考,具体内容如下 Github Repository and libaray WaveView水波纹控件 首先看下演示demo demo中可以看到不同高度,不同速度,不同幅度的水波纹:你可以通过view的参数直接控制view的表现形式. 引入你的工程 在项目的根目录下的build.gradle文件中添加如下代码: allprojects { repositories { ... maven { url 'htt

  • 基于ant design日期控件使用_仅月份的操作

    总体效果: 展开后: 选值后: 代码部分: 1.引入: import { DatePicker } from 'antd'; 2.主体部分: export default class PersonInfo extends Component{ constructor() { super(); //设置状态,存储日期 this.state = { workMode: ['month', 'month'], workValue: [], }; } render(){ //主体引用 const {Ra

  • Android自定义view实现倒计时控件

    本文实例为大家分享了Android自定义view实现倒计时控件的具体代码,供大家参考,具体内容如下 直接上代码 自定义TextView 文字展示 public class StrokeTextView extends TextView { private TextView borderText = null;///用于描边的TextView private Context mContext; public StrokeTextView(Context context) { super(conte

随机推荐