Android使用Handler+postDelayed实现简单计时器

我们在开发中会时常用到计时器,比如计算我们的APP工作的时长,下面介绍两种实现方案。

一、使用Handler+postDelayed实现计时器

先看效果图:



实现的代码:

public class MainActivity extends AppCompatActivity {

    protected Button btnStart;
    protected Button btnEnd;
    static TextView tvWorkTime;
    static Handler timeHandler = new Handler();
    static Date beginDate = null;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        super.setContentView(R.layout.activity_main);
        initView();
    }

    private void initView() {
        btnStart = (Button) findViewById(R.id.btn_start);
        btnEnd = (Button) findViewById(R.id.btn_end);
        tvWorkTime = (TextView) findViewById(R.id.tv_work_time);
    }

    public void start(View view) {
        btnStart.setVisibility(View.GONE);
        btnEnd.setVisibility(View.VISIBLE);
        beginDate = new Date();
        timeHandler.postDelayed(runnable, 1000);
    }

    public void end(View view) {
        btnStart.setVisibility(View.VISIBLE);
        btnEnd.setVisibility(View.GONE);
        timeHandler.removeCallbacks(runnable);
    }

    static Runnable runnable = new Runnable() {
        @Override
        public void run() {
            TimeUtils(beginDate, new Date());
            timeHandler.postDelayed(this, 1000);
        }
    };

    public static void TimeUtils(Date beginDate, Date endDate){
        SimpleDateFormat dfs = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        long between = 0;
        Date begin = null;
        Date end = null;
        try {
            begin = dfs.parse(datetimeToString(beginDate));
            end = dfs.parse(datetimeToString(endDate));
            between = (end.getTime() - begin.getTime());// 得到两者的毫秒数
        } catch (ParseException e) {
            e.printStackTrace();
        }
        long day = between / (24 * 60 * 60 * 1000);
        long hour = (between / (60 * 60 * 1000) - day * 24);
        long min = ((between / (60 * 1000)) - day * 24 * 60 - hour * 60);
        long s = (between / 1000 - day * 24 * 60 * 60 - hour * 60 * 60 - min * 60);
        tvWorkTime.setText("工作时长:" + hour + " : " + min + " : " + s);
    }

    public static String datetimeToString(Date date) {
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        return sdf.format(date);
    }
}


布局文件:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <Button
        android:id="@+id/btn_start"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerVertical="true"
        android:layout_marginLeft="30dp"
        android:layout_marginTop="20dp"
        android:background="@drawable/button"
        android:onClick="start"
        android:text="开始计时"
        android:textSize="24sp"/>

    <Button
        android:id="@+id/btn_end"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerVertical="true"
        android:layout_marginLeft="30dp"
        android:layout_marginTop="20dp"
        android:background="@drawable/button"
        android:onClick="end"
        android:visibility="gone"
        android:text="结束计时"
        android:textSize="24sp"/>

    <TextView
        android:id="@+id/tv_work_time"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="工作时长:0 : 0 : 0"
        android:layout_marginTop="30dp"
        android:layout_marginLeft="20dp"
        android:textSize="20sp"
        android:layout_alignParentBottom="true"
        android:layout_marginBottom="12dp"/>
</LinearLayout>

按钮样式:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_pressed="false">
        <shape android:shape="rectangle" >
            <solid android:color="#0FFFFF" />
            <corners android:radius="15dip" />
            <padding android:bottom="10dp" android:left="10dp" android:right="10dp" android:top="10dp" />
        </shape>
    </item>
    <item android:state_pressed="true">
        <shape android:shape="rectangle">
            <solid android:color="#FFFF0F" />
            <corners android:radius="15dip" />
        </shape>
    </item>
</selector>



二、使用Chronometer实现计时器

public class Main2Activity extends AppCompatActivity {

    protected Chronometer timer;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        super.setContentView(R.layout.activity_main2);
        initView();
    }

    private void initView() {
        timer = (Chronometer) findViewById(R.id.timer);
    }
    public void start(View view){
        timer.setBase(SystemClock.elapsedRealtime());//计时器清零
        int hour = (int) ((SystemClock.elapsedRealtime() - timer.getBase()) / 1000 / 60);
        timer.setFormat("0"+String.valueOf(hour)+":%s");
        timer.start();

    }
    public void stop(View view){
        timer.stop();
    }
}

布局文件:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical" android:layout_width="match_parent"
    android:layout_height="match_parent">

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="start"
        android:onClick="start"/>
    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="stop"
        android:onClick="stop"/>
    <Chronometer
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:format="00:00:00"
        android:textSize="20sp"
        android:id="@+id/timer"/>
</LinearLayout>




  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个使用handler进行UI显示的计时器的示例代码: ``` public class MainActivity extends AppCompatActivity { private TextView textViewTimer; private Handler handler = new Handler(); private int seconds = 0; private boolean isRunning = false; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); textViewTimer = findViewById(R.id.textViewTimer); runTimer(); } public void onClickStart(View view) { isRunning = true; } public void onClickPause(View view) { isRunning = false; } public void onClickReset(View view) { isRunning = false; seconds = 0; } private void runTimer() { handler.post(new Runnable() { @Override public void run() { int hours = seconds / 3600; int minutes = (seconds % 3600) / 60; int secs = seconds % 60; String time = String.format("%d:%02d:%02d", hours, minutes, secs); textViewTimer.setText(time); if (isRunning) { seconds++; } handler.postDelayed(this, 1000); } }); } @Override protected void onPause() { super.onPause(); isRunning = false; } @Override protected void onResume() { super.onResume(); isRunning = true; } } ``` 在这个示例中,我们使用了一个handler对象来更新UI中的计时器计时器的值由一个整数变量seconds表示,每秒钟增加1。当用户点击“开始”按钮时,isRunning标志设置为true,计时器开始增加。当用户点击“暂停”按钮时,isRunning标志设置为false,计时器停止增加。当用户点击“重置”按钮时,isRunning标志设置为false,计时器重置为0。计时器的值被格式化为小时:分钟:秒,并显示在textViewTimer TextView中。handler.postDelayed()方法使用延迟1秒钟的Runnable对象来更新计时器。在onPause()和onResume()方法中,我们设置isRunning标志以控制计时器的运行状态。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值