热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

Android基于CountDownView的时间控件扩展

这篇文章主要为大家详细介绍了Android基于CountDownView的时间控件扩展,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

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

具体用法

1、xml文件

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


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 datas = new ArrayList<>();
  private ItemCountViewAdapter 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(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 datas = new ArrayList<>();
  private ItemCountViewAdapter 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(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();
    }
  }
}

下载源码

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


推荐阅读
  • Android 九宫格布局详解及实现:人人网应用示例
    本文深入探讨了人人网Android应用中独特的九宫格布局设计,解析其背后的GridView实现原理,并提供详细的代码示例。这种布局方式不仅美观大方,而且在现代Android应用中较为少见,值得开发者借鉴。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • Android LED 数字字体的应用与实现
    本文介绍了一种适用于 Android 应用的 LED 数字字体(digital font),并详细描述了其在 UI 设计中的应用场景及其实现方法。这种字体常用于视频、广告倒计时等场景,能够增强视觉效果。 ... [详细]
  • RecyclerView初步学习(一)
    RecyclerView初步学习(一)ReCyclerView提供了一种插件式的编程模式,除了提供ViewHolder缓存模式,还可以自定义动画,分割符,布局样式,相比于传统的ListVi ... [详细]
  • 解决JAX-WS动态客户端工厂弃用问题并迁移到XFire
    在处理Java项目中的JAR包冲突时,我们遇到了JaxWsDynamicClientFactory被弃用的问题,并成功将其迁移到org.codehaus.xfire.client。本文详细介绍了这一过程及解决方案。 ... [详细]
  • 本文介绍如何通过SSH协议使用Xshell远程连接到Ubuntu系统。为了实现这一目标,需要确保Ubuntu系统已安装并配置好SSH服务器,并保证网络连通性。 ... [详细]
  • 优化局域网SSH连接延迟问题的解决方案
    本文介绍了解决局域网内SSH连接到服务器时出现长时间等待问题的方法。通过调整配置和优化网络设置,可以显著缩短SSH连接的时间。 ... [详细]
  • 本文介绍如何使用布局文件在Android应用中排列多行TextView和Button,使其占据屏幕的特定比例,并提供示例代码以帮助理解和实现。 ... [详细]
  • 几何画板展示电场线与等势面的交互关系
    几何画板是一款功能强大的物理教学软件,具备丰富的绘图和度量工具。它不仅能够模拟物理实验过程,还能通过定量分析揭示物理现象背后的规律,尤其适用于难以在实际实验中展示的内容。本文将介绍如何使用几何画板演示电场线与等势面之间的关系。 ... [详细]
  • 本文介绍如何通过Windows批处理脚本定期检查并重启Java应用程序,确保其持续稳定运行。脚本每30分钟检查一次,并在需要时重启Java程序。同时,它会将任务结果发送到Redis。 ... [详细]
  • MySQL中枚举类型的所有可能值获取方法
    本文介绍了一种在MySQL数据库中查询枚举(ENUM)类型字段所有可能取值的方法,帮助开发者更好地理解和利用这一数据类型。 ... [详细]
  • 从零开始构建完整手机站:Vue CLI 3 实战指南(第一部分)
    本系列教程将引导您使用 Vue CLI 3 构建一个功能齐全的移动应用。我们将深入探讨项目中涉及的每一个知识点,并确保这些内容与实际工作中的需求紧密结合。 ... [详细]
  • moment 国际化设置中文语言 (全局) 及使用示例 ... [详细]
  • 深入解析 Spring Security 用户认证机制
    本文将详细介绍 Spring Security 中用户登录认证的核心流程,重点分析 AbstractAuthenticationProcessingFilter 和 AuthenticationManager 的工作原理。通过理解这些组件的实现,读者可以更好地掌握 Spring Security 的认证机制。 ... [详细]
  • 本文介绍如何在现有网络中部署基于Linux系统的透明防火墙(网桥模式),以实现灵活的时间段控制、流量限制等功能。通过详细的步骤和配置说明,确保内部网络的安全性和稳定性。 ... [详细]
author-avatar
10651s
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有