[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文档翻译。



本文转自over140 51CTO博客,原文链接:http://blog.51cto.com/over140/582230,如需转载请自行联系原作者

相关文章
|
4月前
|
Android开发 UED 计算机视觉
Android自定义view之线条等待动画(灵感来源:金铲铲之战)
本文介绍了一款受游戏“金铲铲之战”启发的Android自定义View——线条等待动画的实现过程。通过将布局分为10份,利用`onSizeChanged`测量最小长度,并借助画笔绘制动态线条,实现渐变伸缩效果。动画逻辑通过四个变量控制线条的增长与回退,最终形成流畅的等待动画。代码中详细展示了画笔初始化、线条绘制及动画更新的核心步骤,并提供完整源码供参考。此动画适用于加载场景,提升用户体验。
401 5
Android自定义view之线条等待动画(灵感来源:金铲铲之战)
|
4月前
|
Android开发
Android自定义view之利用PathEffect实现动态效果
本文介绍如何在Android自定义View中利用`PathEffect`实现动态效果。通过改变偏移量,结合`PathEffect`的子类(如`CornerPathEffect`、`DashPathEffect`、`PathDashPathEffect`等)实现路径绘制的动态变化。文章详细解析了各子类的功能与参数,并通过案例代码展示了如何使用`ComposePathEffect`组合效果,以及通过修改偏移量实现动画。最终效果为一个菱形图案沿路径运动,源码附于文末供参考。
|
4月前
|
XML Java Android开发
Android自定义view之网易云推荐歌单界面
本文详细介绍了如何通过自定义View实现网易云音乐推荐歌单界面的效果。首先,作者自定义了一个圆角图片控件`MellowImageView`,用于绘制圆角矩形图片。接着,通过将布局放入`HorizontalScrollView`中,实现了左右滑动功能,并使用`ViewFlipper`添加图片切换动画效果。文章提供了完整的代码示例,包括XML布局、动画文件和Java代码,最终展示了实现效果。此教程适合想了解自定义View和动画效果的开发者。
207 65
Android自定义view之网易云推荐歌单界面
|
4月前
|
XML 前端开发 Android开发
一篇文章带你走近Android自定义view
这是一篇关于Android自定义View的全面教程,涵盖从基础到进阶的知识点。文章首先讲解了自定义View的必要性及简单实现(如通过三个构造函数解决焦点问题),接着深入探讨Canvas绘图、自定义属性设置、动画实现等内容。还提供了具体案例,如跑马灯、折线图、太极图等。此外,文章详细解析了View绘制流程(measure、layout、draw)和事件分发机制。最后延伸至SurfaceView、GLSurfaceView、SVG动画等高级主题,并附带GitHub案例供实践。适合希望深入理解Android自定义View的开发者学习参考。
504 84
|
4月前
|
前端开发 Android开发 UED
讲讲Android为自定义view提供的SurfaceView
本文详细介绍了Android中自定义View时使用SurfaceView的必要性和实现方式。首先分析了在复杂绘制逻辑和高频界面更新场景下,传统View可能引发卡顿的问题,进而引出SurfaceView作为解决方案。文章通过Android官方Demo展示了SurfaceView的基本用法,包括实现`SurfaceHolder.Callback2`接口、与Activity生命周期绑定、子线程中使用`lockCanvas()`和`unlockCanvasAndPost()`方法完成绘图操作。
102 3
|
4月前
|
Android开发 开发者
Android自定义view之围棋动画(化繁为简)
本文介绍了Android自定义View的动画实现,通过两个案例拓展动态效果。第一个案例基于`drawArc`方法实现单次动画,借助布尔值控制动画流程。第二个案例以围棋动画为例,从简单的小球直线运动到双向变速运动,最终实现循环动画效果。代码结构清晰,逻辑简明,展示了如何化繁为简实现复杂动画,帮助读者拓展动态效果设计思路。文末提供完整源码,适合初学者和进阶开发者学习参考。
Android自定义view之围棋动画(化繁为简)
|
4月前
|
Java Android开发 开发者
Android自定义view之围棋动画
本文详细介绍了在Android中自定义View实现围棋动画的过程。从测量宽高、绘制棋盘背景,到创建固定棋子及动态棋子,最后通过属性动画实现棋子的移动效果。文章还讲解了如何通过自定义属性调整棋子和棋盘的颜色及动画时长,并优化视觉效果,如添加渐变色让白子更明显。最终效果既可作为围棋动画展示,也可用作加载等待动画。代码完整,适合进阶开发者学习参考。
|
API Android开发 前端开发
|
2月前
|
安全 数据库 Android开发
在Android开发中实现两个Intent跳转及数据交换的方法
总结上述内容,在Android开发中,Intent不仅是活动跳转的桥梁,也是两个活动之间进行数据交换的媒介。运用Intent传递数据时需注意数据类型、传输大小限制以及安全性问题的处理,以确保应用的健壯性和安全性。
145 11