[Android1.5]DigitalClock自定义日期输出格式

简介:

一、需求

    修改时间输出格式为仅显示小时和分钟。

二、效果图

    

三、说明

    通过看源码可知,只需修改以下两行代码其他全部复制过来即可:

     private   final   static  String m12  =   " h:mm:ss aa " ;
    
private   final   static  String m24  =   " k:mm:ss " ;

    如果想做得更好更通用的话可以把设置日期格式的方法暴露出来,或者为其增加一个xml属性。

四、完整代码

package  com.test;

import  java.util.Calendar;

import  android.content.Context;
import  android.content.res.Resources;
import  android.database.ContentObserver;
import  android.os.Handler;
import  android.os.SystemClock;
import  android.provider.Settings;
import  android.text.format.DateFormat;
import  android.util.AttributeSet;

/**
 * 自定义DigitalClock输出格式
 * 
@author  农民伯伯
 *
 
*/
public   class  DigitalClock  extends  android.widget.DigitalClock {

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

    
private  Runnable mTicker;
    
private  Handler mHandler;

    
private   boolean  mTickerStopped  =   false ;

    String mFormat;

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

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

    
private   void  initClock(Context context) {
        Resources r 
=  context.getResources();

        
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 ;
                    mCalendar.setTimeInMillis(System.currentTimeMillis());
                    setText(DateFormat.format(mFormat, mCalendar));
                    invalidate();
                    
long  now  =  SystemClock.uptimeMillis();
                    
long  next  =  now  +  ( 1000   -  now  %   1000 );
                    mHandler.postAtTime(mTicker, next);
                }
            };
        mTicker.run();
    }

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

    
/**
     * 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();
        }
    }
}

五、使用方法

< com.test.DigitalClock android:layout_x = " 15dp "  android:layout_y = " 30dp "  
            android:layout_width
= " wrap_content "  android:layout_height = " wrap_content "
            android:textColor
= " @android:color/white "  android:textSize = " 55sp "
             android:shadowColor
= " @android:color/white "  android:shadowRadius = " 2.0 "
            
>
        
</ com.test.DigitalClock >

    代码说明:

      关于android:shadowColor可以参见我的中文API文档翻译。

本文转自博客园农民伯伯的博客,原文链接:[Android1.5]DigitalClock自定义日期输出格式,如需转载请自行联系原博主。

目录
相关文章
|
15天前
|
存储 Shell Android开发
基于Android P,自定义Android开机动画的方法
本文详细介绍了基于Android P系统自定义开机动画的步骤,包括动画文件结构、脚本编写、ZIP打包方法以及如何将自定义动画集成到AOSP源码中。
40 2
基于Android P,自定义Android开机动画的方法
|
13天前
|
供应链 物联网 区块链
未来触手可及:探索新兴技术的趋势与应用安卓开发中的自定义视图:从基础到进阶
【8月更文挑战第30天】随着科技的飞速发展,新兴技术如区块链、物联网和虚拟现实正在重塑我们的世界。本文将深入探讨这些技术的发展趋势和应用场景,带你领略未来的可能性。
|
14天前
|
测试技术 Android开发 Python
探索软件测试的艺术:从基础到高级安卓应用开发中的自定义视图
【8月更文挑战第29天】在软件开发的世界中,测试是不可或缺的一环。它如同艺术一般,需要精细的技巧和深厚的知识。本文旨在通过浅显易懂的语言,引领读者从软件测试的基础出发,逐步深入到更复杂的测试策略和工具的使用,最终达到能够独立进行高效测试的水平。我们将一起探索如何通过不同的测试方法来确保软件的质量和性能,就像艺术家通过不同的色彩和笔触来完成一幅画作一样。
|
13天前
|
XML 搜索推荐 Android开发
安卓开发中的自定义View组件实践
【8月更文挑战第30天】探索Android世界,自定义View是提升应用界面的关键。本文以简洁的语言带你了解如何创建自定义View,从基础到高级技巧,一步步打造个性化的UI组件。
|
15天前
|
Android开发
Android在rootdir根目录创建自定义目录和挂载点的方法
本文介绍了在Android高通平台的根目录下创建自定义目录和挂载点的方法,通过修改Android.mk文件并使用`LOCAL_POST_INSTALL_CMD`变量在编译过程中添加目录,最终在ramdisk.img的系统根路径下成功创建了`/factory/bin`目录。
35 1
|
5天前
|
前端开发 搜索推荐 Android开发
探索安卓开发中的自定义视图##
【9月更文挑战第6天】 在安卓应用开发的世界里,自定义视图如同绘画艺术中的色彩,它们为界面设计增添了无限可能。通过掌握自定义视图的绘制技巧,开发者能够创造出既符合品牌形象又提升用户体验的独特界面元素。本文将深入浅出地介绍如何从零开始构建一个自定义视图,包括基础框架搭建、关键绘图方法实现、事件处理机制以及性能优化策略。准备好让你的安卓应用与众不同了吗?让我们开始吧! ##
|
17天前
|
前端开发 Android开发 开发者
安卓开发中的自定义视图:构建你的第一个控件
【8月更文挑战第26天】在安卓开发的浩瀚海洋中,自定义视图是一块充满魔力的乐土。它不仅是开发者展示创造力的舞台,更是实现独特用户体验的关键。本文将带你步入自定义视图的世界,从基础概念到实战应用,一步步教你如何打造自己的第一个控件。无论你是初学者还是有经验的开发者,这篇文章都将为你的开发之旅增添新的风景。
|
Android开发
Android Studio 自定义设置注释模板
Android Studio 自定义设置注释模板
447 0
Android Studio 自定义设置注释模板
|
8天前
|
存储 Android开发 开发者
探索安卓开发之旅:从新手到专家的必经之路
【9月更文挑战第3天】在这篇文章中,我们将踏上一场激动人心的旅程,深入探索安卓开发的广阔天地。无论你是初涉编程世界的新手,还是期望提升技能的开发者,这里都有你需要的知识与技巧。我们将从基础概念讲起,逐步引导你了解安卓应用的核心组件,并分享实用的开发建议。准备好了吗?让我们一起开启这段成长之旅吧!
|
2天前
|
安全 Android开发 开发者
探索安卓开发的未来:Kotlin的崛起与Flutter的挑战
在移动开发的广阔天地中,安卓平台始终占据着举足轻重的地位。随着技术的不断进步和开发者需求的多样化,Kotlin和Flutter成为了改变游戏规则的新玩家。本文将深入探讨Kotlin如何以其现代化的特性赢得开发者的青睐,以及Flutter凭借跨平台的能力如何挑战传统的安卓开发模式。通过实际案例分析,我们将揭示这两种技术如何塑造未来的安卓应用开发。
17 6