android 中文 api (43) —— Chronometer

简介:

一、结构

    public class Chronometer extends TextView

    java.lang.Object

    android.view.View

      android.widget.TextView

        android.widget.Chronometer

二、概述

    

  类实现了一个简单的计时器。

     你可以通过 elapsedRealtime() 给它一个基准时间,并从该时间开始计数。如果你不给它基准时间,它将使用你调用 start() 时的时间。默认它将显示当前 "MM:SS"  "H:MM:SS" 格式的时间 , 或者你能通过 setFormat(String) 设置一个任意字符串来格式化显示计时器显示的时间。

三、XML属性

属性名称

描述

android:format

格式化字符串:如果指定,计时器将根据这个字符串来显示,替换字符串中第一个“%s”为当前"MM:SS""H:MM:SS"格式的时间显示。如果不指定,计时器将简单的显示"MM:SS" or "H:MM:SS"格式的时间。(译者注:如:“This is a Chronometer %s”


四、构造函数

         public Chronometer (Context context)

  初始化计时器对象。设置当前时间为基准时间。(译者注:通过程序动态创建计时器对象) 

  public Chronometer (Context context, AttributeSet attrs)

  初始化标准视图布局信息。设置当前时间为基准时间。(译者注:指通过XML来指定一个计时器)

  public Chronometer (Context context, AttributeSet attrs, int defStyle)

     初始化标准视图布局信息和风格。设置当前时间为基准时间。  

五、公共方法

         public long getBase ()

         返回先前由setBase(long)设置的基准时间。

         public String getFormat ()

         返回先前由setFormat(String)设置的格式化字符串。

         public Chronometer.OnChronometerTickListener getOnChronometerTickListener ()

                   返回值

                            返回这个监听器(可能为空)是用于监听计时器变化的事件。

         public void setBase (long base)

         设置基准时间(译者注:基准时间为真正意义上开始计时的时间,而不是调用start时时间,比如调用本函数并设置参数baseSystemClock.elapsedRealtime()即表示从当前时间开始重新计时)。

                   参数

                            base        使用elapsedRealtime()为基准时间

         public void setFormat (String format)

         设置用于显示的格式化字符串。格式化字符串:如果指定,计时器将根据这个字符串来显示,替换字符串中第一个“%s”为当前"MM:SS" "H:MM:SS"格式的时间显示。如果这个格式化字符串为空,或者你从未调用过setFormat()方法,计时器将简单的显示"MM:SS" or "H:MM:SS"格式的时间。(译者注:如:"This is a Chronometer %s"

                   参数

                            format    格式化字符串

         public void setOnChronometerTickListener(Chronometer.OnChronometerTickListener listener)

         设置计时器变化时调用的监听事件。

                   参数

                            listener  The listener.

         public void start ()

         开始计时。不会影响到由setBase(long)设置的基准时间,仅显示视图。即使部件不显示,计时器也会通过定时处理消息来工作。为了确保不发生资源泄漏,用户应确保每个start()方法都有对应的stop()调用(译者注:有一个start就有一个stop)。(译者注:start只是显示计时,实际上计时是从基准时间开始的,所以通过stop停止计时若干秒后再start时,显示的计时会突然跳到当前显示的计时后的若干秒后继续计时,见此帖子。)

         public void stop ()

         停止计时。不会影响到由setBase(long)设置的基准时间,仅显示视图。这将停止消息发送,有效地释放计时器运行时start()占用的资源。

六、受保护方法

         protected void onDetachedFromWindow ()

         视图从窗体上移除时调用,同时窗体表面不再显示视图。

         protected void onWindowVisibilityChanged (int visibility)

         当窗体中视图的可视性(GONE, INVISIBLE, VISIBLE)发生改变时调用。注意它将告诉你你的窗口是否可以被窗口管理器识别,这并不能说明窗口是否被屏幕上的其他窗口遮挡,即使它本身是可见的。

                   参数

                           visibility 窗口新的可见性

七、补充

    文章链接

      android中的时间服务–Chronometer计时器服务

    示例代码

      Java文件

     public   class  ChronometerDemo  extends  Activity {
            
private  Chronometer cher1;
            @Override
            
protected   void  onCreate(Bundle savedInstanceState) {
                
super .onCreate(savedInstanceState);
                setContentView(R.layout.chronometer);
                cher1 
=  (Chronometer) findViewById(R.id.cher1);
                cher1.setFormat(
" 计时:%s " );
            }
            
/**
            * 开始计时
             * 
@param  view
             
*/
            
public   void  onStart(View view) {
                cher1.start();
            }
            
/**
             * 停止计时
             * 
@param  view
             
*/
            
public   void  onStop(View view) {
                cher1.stop();
            }
            
/**
             * 重置
             * 
@param  view
             
*/
            
public   void  onReset(View view) {
                cher1.setBase(SystemClock.elapsedRealtime());
            }
     }

      XML文件

         < LinearLayout  xmlns:android ="http://schemas.android.com/apk/res/android"  android:orientation ="vertical"
    android:layout_width
="wrap_content"  android:layout_height ="wrap_content" >
    
< Chronometer  android:id ="@+id/cher1"  android:layout_width ="wrap_content"
        android:layout_height
="wrap_content" ></ Chronometer >
    
< LinearLayout  android:layout_width ="wrap_content"  android:layout_height ="wrap_content" >
        
< Button  android:onClick ="onStart"  android:text ="开始计时"  android:layout_width ="wrap_content"  android:layout_height ="wrap_content" ></ Button >
        
< Button  android:onClick ="onStop"  android:text ="停止计时"  android:layout_width ="wrap_content"  android:layout_height ="wrap_content" ></ Button >
        
< Button  android:onClick ="onReset"  android:text ="重置"  android:layout_width ="wrap_content"  android:layout_height ="wrap_content" ></ Button >     
    
</ LinearLayout >
</ LinearLayout >

本文转自博客园农民伯伯的博客,原文链接:android 中文 api (43) —— Chronometer,如需转载请自行联系原博主。


目录
相关文章
|
9月前
|
定位技术 API 开发工具
Android 按照步骤接入百度地图API,定位显示不了解决办法
Android 按照步骤接入百度地图API,定位显示不了解决办法
250 0
|
19天前
|
API Android开发
Android Framework增加API 报错 Missing nullability on parameter
Android Framework增加API 报错 Missing nullability on parameter
10 1
|
8月前
|
API Android开发
mPaaS(移动跨平台框架)目前已经支持了Android API级别21
mPaaS(移动跨平台框架)目前已经支持了Android API级别21
108 2
|
9月前
|
API 数据库 Android开发
Android SQLite数据库中基础的增删改查操作以及API的详解
Android SQLite数据库中基础的增删改查操作以及API的详解
67 0
|
11月前
|
API Android开发
Android Activity Result API
Android Activity Result API
103 0
|
12月前
|
Java API Android开发
Sui为根应用提供Java APIs,滴API。主要提供直接使用Android APIs的能力(几乎以Java作为root的身份
Sui为根应用提供Java APIs,滴API。主要提供直接使用Android APIs的能力(几乎以Java作为root的身份,在root下启动app自己的AIDL风格的Java服务。这将使root应用程序开发变得更加容易。
143 0
|
缓存 Java API
Android音频API
MediaRecorder与MediaPlayer并不能算完整意义的音频API,它们只是系统音频API的封装,除了采集/播放,他们集成了编码/解码、复用/解复用等能力。它们在最底层还是调用了AudioRecorder、AudioTrack。下面主要介绍它们的几个主要的配置项。
370 0
|
Ubuntu Java Shell
Android使用FFmpeg的API库
Android使用FFmpeg的API库
299 1
|
定位技术 API Android开发
Android Studio进行APP设计调用百度地图API接口隐藏百度地图的logo方法
Android Studio进行APP设计调用百度地图API接口隐藏百度地图的logo方法
319 0
Android Studio进行APP设计调用百度地图API接口隐藏百度地图的logo方法
|
存储 缓存 Java
Android 百度语音合成 (含离线、在线、API合成方式,详细步骤+源码)
Android 百度语音合成 (含离线、在线、API合成方式,详细步骤+源码)
510 0
Android 百度语音合成 (含离线、在线、API合成方式,详细步骤+源码)