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

Android自定义DigitalClock控件实现商品倒计时

这篇文章主要为大家详细介绍了AndroidDigitalClock实现商品倒计时,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了DigitalClock实现商品倒计时的具体代码,供大家参考,具体内容如下

自定义DigitalClock控件:

package com.veally.timesale;

import java.util.Calendar;

import android.content.Context;
import android.database.ContentObserver;
import android.os.Handler;
import android.os.SystemClock;
import android.provider.Settings;
import android.util.AttributeSet;
import android.widget.DigitalClock;

/**
 * Custom digital clock
 * @author veally@foxmail.com
 */
public class CustomDigitalClock extends DigitalClock {

 Calendar mCalendar;
 private final static String m12 = "h:mm aa";
 private final static String m24 = "k:mm";
 private FormatChangeObserver mFormatChangeObserver;

 private Runnable mTicker;
 private Handler mHandler;
 private long endTime;
 private ClockListener mClockListener;

 private boolean mTickerStopped = false;

 @SuppressWarnings("unused")
 private String mFormat;

 public CustomDigitalClock(Context context) {
 super(context);
 initClock(context);
 }

 public CustomDigitalClock(Context context, AttributeSet attrs) {
 super(context, attrs);
 initClock(context);
 }

 private void initClock(Context context) {

 if (mCalendar == null) {
 mCalendar = Calendar.getInstance();
 }

 mFormatChangeObserver = new FormatChangeObserver();
 getContext().getContentResolver().registerContentObserver(Settings.System.CONTENT_URI, true, mFormatChangeObserver);

 setFormat();
 }

 @Override
 protected void onAttachedToWindow() {
 mTickerStopped = false;
 super.onAttachedToWindow();
 mHandler = new Handler();

 /**
 * requests a tick on the next hard-second boundary
 */
 mTicker = new Runnable() {
 public void run() {
 if (mTickerStopped)
  return;
 long currentTime = System.currentTimeMillis();
 if (currentTime / 1000 == endTime / 1000 - 5 * 60) {
  mClockListener.remainFiveMinutes();
 }
 long distanceTime = endTime - currentTime;
 distanceTime /= 1000;
 if (distanceTime == 0) {
  setText("00:00:00");
  onDetachedFromWindow();
  mClockListener.timeEnd();
 } else if (distanceTime <0) {
  setText("00:00:00");
 } else {
  setText(dealTime(distanceTime));
 }
 invalidate();
 long now = SystemClock.uptimeMillis();
 long next = now + (1000 - now % 1000);
 mHandler.postAtTime(mTicker, next);
 }
 };
 mTicker.run();
 }

 /**
 * deal time string
 * 
 * @param time
 * @return
 */
 public static String dealTime(long time) {
 StringBuffer returnString = new StringBuffer();
 long day = time / (24 * 60 * 60);
 long hours = (time % (24 * 60 * 60)) / (60 * 60);
 long minutes = ((time % (24 * 60 * 60)) % (60 * 60)) / 60;
 long secOnd= ((time % (24 * 60 * 60)) % (60 * 60)) % 60;
 String dayStr = String.valueOf(day);
 String hoursStr = timeStrFormat(String.valueOf(hours));
 String minutesStr = timeStrFormat(String.valueOf(minutes));
 String secOndStr= timeStrFormat(String.valueOf(second));

 returnString.append(hoursStr).append(":").append(minutesStr).append(":").append(secondStr);
 return returnString.toString();
 }

 /**
 * format time
 * 
 * @param timeStr
 * @return
 */
 private static String timeStrFormat(String timeStr) {
 switch (timeStr.length()) {
 case 1:
 timeStr = "0" + timeStr;
 break;
 }
 return timeStr;
 }

 @Override
 protected void onDetachedFromWindow() {
 super.onDetachedFromWindow();
 mTickerStopped = true;
 }

 /**
 * Clock end time from now on.
 * 
 * @param endTime
 */
 public void setEndTime(long endTime) {
 this.endTime = endTime;
 }

 /**
 * Pulls 12/24 mode from system settings
 */
 private boolean get24HourMode() {
 return android.text.format.DateFormat.is24HourFormat(getContext());
 }

 private void setFormat() {
 if (get24HourMode()) {
 mFormat = m24;
 } else {
 mFormat = m12;
 }
 }

 private class FormatChangeObserver extends ContentObserver {
 public FormatChangeObserver() {
 super(new Handler());
 }

 @Override
 public void onChange(boolean selfChange) {
 setFormat();
 }
 }

 public void setClockListener(ClockListener clockListener) {
 this.mClockListener = clockListener;
 }

 public interface ClockListener{
 void timeEnd();
 void remainFiveMinutes();
 }

}

使用:

remainTime.setEndTime(mItems.get(position).getRemainTime());
 remainTime.setClockListener(new CustomDigitalClock.ClockListener() { // register the clock's listener

 @Override
 public void timeEnd() {
 // The clock time is ended.
 }

 @Override
 public void remainFiveMinutes() {
 // The clock time is remain five minutes.
 }
 });

倒计时剩余时间最好从服务器获取。

代码下载:DigitalClock实现倒计时

原创作者:veally@foxmail.com 源链接不详,工作用到就记录分享下!

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


推荐阅读
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • Android中高级面试必知必会,积累总结
    本文介绍了Android中高级面试的必知必会内容,并总结了相关经验。文章指出,如今的Android市场对开发人员的要求更高,需要更专业的人才。同时,文章还给出了针对Android岗位的职责和要求,并提供了简历突出的建议。 ... [详细]
  • Centos7.6安装Gitlab教程及注意事项
    本文介绍了在Centos7.6系统下安装Gitlab的详细教程,并提供了一些注意事项。教程包括查看系统版本、安装必要的软件包、配置防火墙等步骤。同时,还强调了使用阿里云服务器时的特殊配置需求,以及建议至少4GB的可用RAM来运行GitLab。 ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
  • baresip android编译、运行教程1语音通话
    本文介绍了如何在安卓平台上编译和运行baresip android,包括下载相关的sdk和ndk,修改ndk路径和输出目录,以及创建一个c++的安卓工程并将目录考到cpp下。详细步骤可参考给出的链接和文档。 ... [详细]
  • 如何用UE4制作2D游戏文档——计算篇
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了如何用UE4制作2D游戏文档——计算篇相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 安卓select模态框样式改变_微软Office风格的多端(Web、安卓、iOS)组件库——Fabric UI...
    介绍FabricUI是微软开源的一套Office风格的多端组件库,共有三套针对性的组件,分别适用于web、android以及iOS,Fab ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • 本文介绍了解决Netty拆包粘包问题的一种方法——使用特殊结束符。在通讯过程中,客户端和服务器协商定义一个特殊的分隔符号,只要没有发送分隔符号,就代表一条数据没有结束。文章还提供了服务端的示例代码。 ... [详细]
  • Linux服务器密码过期策略、登录次数限制、私钥登录等配置方法
    本文介绍了在Linux服务器上进行密码过期策略、登录次数限制、私钥登录等配置的方法。通过修改配置文件中的参数,可以设置密码的有效期、最小间隔时间、最小长度,并在密码过期前进行提示。同时还介绍了如何进行公钥登录和修改默认账户用户名的操作。详细步骤和注意事项可参考本文内容。 ... [详细]
  • EPICS Archiver Appliance存储waveform记录的尝试及资源需求分析
    本文介绍了EPICS Archiver Appliance存储waveform记录的尝试过程,并分析了其所需的资源容量。通过解决错误提示和调整内存大小,成功存储了波形数据。然后,讨论了储存环逐束团信号的意义,以及通过记录多圈的束团信号进行参数分析的可能性。波形数据的存储需求巨大,每天需要近250G,一年需要90T。然而,储存环逐束团信号具有重要意义,可以揭示出每个束团的纵向振荡频率和模式。 ... [详细]
  • 本文介绍了在rhel5.5操作系统下搭建网关+LAMP+postfix+dhcp的步骤和配置方法。通过配置dhcp自动分配ip、实现外网访问公司网站、内网收发邮件、内网上网以及SNAT转换等功能。详细介绍了安装dhcp和配置相关文件的步骤,并提供了相关的命令和配置示例。 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • PHP设置MySQL字符集的方法及使用mysqli_set_charset函数
    本文介绍了PHP设置MySQL字符集的方法,详细介绍了使用mysqli_set_charset函数来规定与数据库服务器进行数据传送时要使用的字符集。通过示例代码演示了如何设置默认客户端字符集。 ... [详细]
author-avatar
黑暗中的数字
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有