• 学习Android的第十三天


    目录

    Android TextClock 文本时钟控件

    TextClock 控件主要属性和方法

    简单的 TextClock

    参考文档

    Android AnalogClock 控件

    AnalogClock 属性

    Android Chronometer 计时器

    Chronometer 属性

    Chronometer 主要方法

    范例: 完整的计时器

    范例: 倒计时


    Android TextClock 文本时钟控件

    Android TextClock 是一个用于在 Android 应用中显示当前日期和时间的控件。它在 Android 4.2 (API 17) 后推出,并提供了两种不同的格式:24 小时制和 12 小时制。

    可以使用 is24HourModeEnabled() 方法来确定系统当前是否在使用 24 小时制。在 24 小时制模式下,系统将按照以下方式进行判断:

    • 首先尝试通过 getFormat24Hour() 方法获取时间格式。
    • 如果无法获取到时间格式,则尝试通过 getFormat12Hour() 方法获取时间格式。
    • 如果上述两种方式都无法获取到时间格式,则使用默认格式。

    TextClock 控件主要属性和方法

    下面是 TextClock 控件的主要属性和对应的方法:

    属性:

    • android:format12Hour:设置 12 小时制的格式。
    • android:format24Hour:设置 24 小时制的格式。
    • android:timeZone:设置时区。

    方法:

    • setFormat12Hour(CharSequence format):设置 12 小时制的时间格式。参数 format 是一个 CharSequence 对象,用于指定要显示的时间格式。
    • setFormat24Hour(CharSequence format):设置 24 小时制的时间格式。参数 format 是一个 CharSequence 对象,用于指定要显示的时间格式。
    • setTimeZone(String timeZone):设置 TextClock 控件的时区。参数 timeZone 是一个字符串,表示要设置的时区。

    简单的 TextClock

    1. "1.0" encoding="utf-8"?>
    2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    3. android:layout_width="match_parent"
    4. android:layout_height="match_parent"
    5. xmlns:app="http://schemas.android.com/apk/res-auto"
    6. android:orientation="vertical"
    7. android:gravity="center">
    8. <TextClock
    9. android:id="@+id/textClock"
    10. android:layout_width="wrap_content"
    11. android:layout_height="wrap_content"
    12. android:layout_gravity="center"
    13. android:textSize="24sp"
    14. android:format24Hour="HH:mm:ss"
    15. android:format12Hour="hh:mm:ss a"
    16. android:timeZone="GMT+08:00"/>
    17. LinearLayout>

    参考文档

    1. Android android.widget.TextClock

    Android AnalogClock 控件

    Android AnalogClock 控件是一个模拟时钟控件,用于在应用中显示模拟时钟的外观。但是,自 API 23 起,Android 官方已经将 AnalogClock 控件标记为废弃,并建议开发者使用其他替代方案,比如使用自定义绘制的方式或者使用第三方库来实现时钟功能。

    AnalogClock 属性

    在 Android 中,AnalogClock 控件是一个简单的模拟时钟,它显示了当前时间的模拟时钟表盘。尽管从 API 23 开始已经被废弃,但仍然可以使用。下面是 AnalogClock 控件的属性说明:

    • android:dial:用于设置模拟时钟的背景图片。您可以指定一个 drawable 资源作为时钟的表盘背景。这个属性允许您自定义时钟表盘的外观。
    • android:hand_hour:用于设置模拟时钟的时针图片。您可以指定一个 drawable 资源作为时钟的时针。这个属性允许您自定义时钟的时针外观。
    • android:hand_minute:用于设置模拟时钟的分针图片。您可以指定一个 drawable 资源作为时钟的分针。这个属性允许您自定义时钟的分针外观。

    Android Chronometer 计时器

    Android 中的 Chronometer 控件可以用于制作简单的计时器或倒计时功能。它可以显示经过的时间,并且可以方便地开始、停止和重置计时。

    默认情况下,Chronometer 控件会以 "MM:SS" 或 "H:MM:SS" 格式显示当前时间,我们也可以使用 setFormat(String) 方法设置为其它的格式

    Chronometer 控件可以使用 elapsedRealtime() 方法设置起始时间,如果未设置起始时间,就会在调用 start() 方法时使用当前时间作为起始时间

    Chronometer 控件也可以用来开发一个倒计时,可以使用 setCountDown(boolean) 方法来设置剩余时间

    Chronometer 属性

    • android:countDown:一个布尔值,用于设置 Chronometer 是否为倒计时模式。如果设置为 true,则 Chronometer 将显示倒计时的时间;如果设置为 false(默认值),则显示计时器的时间。
    • android:format:一个字符串值,用于设置 Chronometer 显示的时间格式。Android 将使用 %s 来代替显示时间的部分。您可以指定自己想要的时间格式,比如 "MM:SS"(分:秒)或者 "H:MM:SS"(小时:分:秒)。

    Chronometer 主要方法

    • isCountDown():这个方法用于设置 Chronometer 是否为倒计时模式。如果返回 true,则表示 Chronometer 是倒计时模式,否则表示为计时模式。
    • start():该方法用于启动 Chronometer,开始计时或倒计时。一旦调用该方法,Chronometer 将开始更新显示时间。
    • stop():该方法用于停止 Chronometer。一旦调用该方法,Chronometer 将停止更新显示时间,当前的时间将保持不变。

    范例: 完整的计时器

    1. "1.0" encoding="utf-8"?>
    2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    3. android:layout_width="match_parent"
    4. android:layout_height="match_parent"
    5. xmlns:app="http://schemas.android.com/apk/res-auto"
    6. android:orientation="vertical"
    7. android:gravity="center">
    8. <Chronometer
    9. android:id="@+id/chronometer"
    10. android:layout_width="fill_parent"
    11. android:layout_height="wrap_content"
    12. android:gravity="center"
    13. android:textColor="#ff0000"
    14. android:textSize="60dip" />
    15. <LinearLayout
    16. android:layout_width="fill_parent"
    17. android:layout_height="wrap_content"
    18. android:layout_margin="10dip"
    19. android:orientation="horizontal">
    20. <Button
    21. android:id="@+id/btnStart"
    22. android:layout_width="fill_parent"
    23. android:layout_height="wrap_content"
    24. android:layout_weight="1"
    25. android:text="开始记时" />
    26. <Button
    27. android:id="@+id/btnStop"
    28. android:layout_width="fill_parent"
    29. android:layout_height="wrap_content"
    30. android:layout_weight="1"
    31. android:text="停止记时" />
    32. <Button
    33. android:id="@+id/btnReset"
    34. android:layout_width="fill_parent"
    35. android:layout_height="wrap_content"
    36. android:layout_weight="1"
    37. android:text="重置" />
    38. <Button
    39. android:id="@+id/btn_format"
    40. android:layout_width="wrap_content"
    41. android:layout_height="wrap_content"
    42. android:text="格式化" />
    43. LinearLayout>
    44. LinearLayout>
    1. package com.example.myapplication;
    2. import android.os.Bundle;
    3. import android.os.SystemClock;
    4. import android.view.View;
    5. import android.widget.Button;
    6. import android.widget.Chronometer;
    7. import androidx.appcompat.app.AppCompatActivity;
    8. public class MainActivity extends AppCompatActivity {
    9. private Chronometer chronometer;
    10. private Button startButton, stopButton, resetButton, formatButton;
    11. private boolean isRunning = false;
    12. private boolean isFormatChanged = false;
    13. @Override
    14. protected void onCreate(Bundle savedInstanceState) {
    15. super.onCreate(savedInstanceState);
    16. setContentView(R.layout.activity_main);
    17. chronometer = findViewById(R.id.chronometer);
    18. startButton = findViewById(R.id.btnStart);
    19. stopButton = findViewById(R.id.btnStop);
    20. resetButton = findViewById(R.id.btnReset);
    21. formatButton = findViewById(R.id.btn_format);
    22. startButton.setOnClickListener(new View.OnClickListener() {
    23. @Override
    24. public void onClick(View v) {
    25. startChronometer();
    26. }
    27. });
    28. stopButton.setOnClickListener(new View.OnClickListener() {
    29. @Override
    30. public void onClick(View v) {
    31. stopChronometer();
    32. }
    33. });
    34. resetButton.setOnClickListener(new View.OnClickListener() {
    35. @Override
    36. public void onClick(View v) {
    37. resetChronometer();
    38. }
    39. });
    40. formatButton.setOnClickListener(new View.OnClickListener() {
    41. @Override
    42. public void onClick(View v) {
    43. changeChronometerFormat();
    44. }
    45. });
    46. }
    47. private void startChronometer() {
    48. if (!isRunning) {
    49. chronometer.setBase(SystemClock.elapsedRealtime());
    50. chronometer.start();
    51. isRunning = true;
    52. }
    53. }
    54. private void stopChronometer() {
    55. if (isRunning) {
    56. chronometer.stop();
    57. isRunning = false;
    58. }
    59. }
    60. private void resetChronometer() {
    61. chronometer.stop();
    62. chronometer.setBase(SystemClock.elapsedRealtime());
    63. isRunning = false;
    64. }
    65. private void changeChronometerFormat() {
    66. if (!isFormatChanged) {
    67. // 第一次点击,更改格式为 "时间:%s"
    68. chronometer.setFormat("时间:%s");
    69. isFormatChanged = true;
    70. } else {
    71. // 再次点击,恢复到原始格式
    72. chronometer.setFormat("%s");
    73. isFormatChanged = false;
    74. }
    75. }
    76. }

    范例: 倒计时

    1. "1.0" encoding="utf-8"?>
    2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    3. android:layout_width="match_parent"
    4. android:layout_height="match_parent"
    5. android:orientation="vertical"
    6. android:gravity="center">
    7. <Chronometer
    8. android:id="@+id/chronometer"
    9. android:layout_width="fill_parent"
    10. android:layout_height="wrap_content"
    11. android:gravity="center"
    12. android:countDown="true"
    13. android:textColor="#ff0000"
    14. android:textSize="60dip" />
    15. <LinearLayout
    16. android:layout_width="fill_parent"
    17. android:layout_height="wrap_content"
    18. android:layout_margin="10dip"
    19. android:orientation="horizontal">
    20. <Button
    21. android:id="@+id/btnStart"
    22. android:layout_width="fill_parent"
    23. android:layout_height="wrap_content"
    24. android:layout_weight="1"
    25. android:text="开始" />
    26. <Button
    27. android:id="@+id/btnReset"
    28. android:layout_width="fill_parent"
    29. android:layout_height="wrap_content"
    30. android:layout_weight="1"
    31. android:text="重置" />
    32. LinearLayout>
    33. LinearLayout>
    1. package com.example.myapplication;
    2. import android.app.Activity;
    3. import android.app.AlertDialog;
    4. import android.content.DialogInterface;
    5. import android.os.Bundle;
    6. import android.os.CountDownTimer;
    7. import android.view.View;
    8. import android.widget.Button;
    9. import android.widget.Chronometer;
    10. public class MainActivity extends Activity {
    11. private Chronometer chronometer;
    12. private Button btnStart;
    13. private Button btnReset;
    14. private CountDownTimer countDownTimer;
    15. @Override
    16. protected void onCreate(Bundle savedInstanceState) {
    17. super.onCreate(savedInstanceState);
    18. setContentView(R.layout.activity_main);
    19. chronometer = findViewById(R.id.chronometer);
    20. btnStart = findViewById(R.id.btnStart);
    21. btnReset = findViewById(R.id.btnReset);
    22. btnStart.setOnClickListener(new View.OnClickListener() {
    23. @Override
    24. public void onClick(View v) {
    25. startCountdown();
    26. }
    27. });
    28. btnReset.setOnClickListener(new View.OnClickListener() {
    29. @Override
    30. public void onClick(View v) {
    31. resetChronometer();
    32. }
    33. });
    34. }
    35. private void startCountdown() {
    36. countDownTimer = new CountDownTimer(11000, 1000) {
    37. @Override
    38. public void onTick(long millisUntilFinished) {
    39. long secondsRemaining = millisUntilFinished / 1000;
    40. chronometer.setText(String.valueOf(secondsRemaining));
    41. }
    42. @Override
    43. public void onFinish() {
    44. chronometer.setText("0");
    45. showTimeUpDialog();
    46. }
    47. }.start();
    48. }
    49. private void resetChronometer() {
    50. if (countDownTimer != null) {
    51. countDownTimer.cancel();
    52. }
    53. chronometer.setText("");
    54. }
    55. private void showTimeUpDialog() {
    56. AlertDialog.Builder builder = new AlertDialog.Builder(this);
    57. builder.setMessage("时间到了!")
    58. .setPositiveButton("确定", new DialogInterface.OnClickListener() {
    59. public void onClick(DialogInterface dialog, int id) {
    60. // 点击确定按钮后的操作
    61. }
    62. });
    63. builder.create().show();
    64. }
    65. }

  • 相关阅读:
    南大通用GBase8s 常用SQL语句(236)
    VINS学习04———Omni教程
    echarts 图片导入到 word pdf
    matlab回归学习
    传神论文中心|第25期人工智能领域论文推荐
    【牛客刷题】带你在牛客刷题第八弹(简单排序)
    日志技术-logback
    [LCT刷题][边双缩点] P2542 [AHOI2005] 航线规划
    HTML显示中文空格字符,&emsp;一个中文字符,&ensp;半个中文字符
    ShowDoc突破边界上线Linux不出网主机
  • 原文地址:https://blog.csdn.net/m0_74293254/article/details/136135415