需求:
有多个组件可以开启倒计时,正常情况下默认倒计时时间终了后更新UI,另,用户可以取消指定倒计时。
这里使用CountDownTimer进行倒计时,其中回调函数onFinish是在倒计时终了时回调,onTick是在倒计时开始时回调,用户可以使用CountDownTimer对象的cancel方法取消倒计时。
这样做的好处:不需要使用繁琐的线程去控制倒计时,更方便的进行UI更新。
上代码:
MainActivity
package test.demo.countdowntest; import android.os.Bundle; import android.os.CountDownTimer; import android.support.v7.app.AppCompatActivity; import android.view.View; import android.widget.Button; import android.widget.ProgressBar; import android.widget.Toast; public class MainActivity extends AppCompatActivity implements View.OnClickListener{ private Button bt1, bt2, bt3; private ProgressBar pb1, pb2, pb3; private MyCount mc1,mc2, mc3; private boolean mc1Click = false; private boolean mc2Click = false; private boolean mc3Click = false; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); bt1 = ((Button) findViewById(R.id.bt1)); bt2 = ((Button) findViewById(R.id.bt2)); bt3 = ((Button) findViewById(R.id.bt3)); bt1.setOnClickListener(this); bt2.setOnClickListener(this); bt3.setOnClickListener(this); pb1 = ((ProgressBar) findViewById(R.id.pb1)); pb2 = ((ProgressBar) findViewById(R.id.pb2)); pb3 = ((ProgressBar) findViewById(R.id.pb3)); mc1 = new MyCount(30000, 1000); mc1.setPb(bt1, pb1); mc2 = new MyCount(30000, 1000); mc2.setPb(bt2, pb2); mc3 = new MyCount(30000, 1000); mc3.setPb(bt3, pb3); } @Override public void onClick(View view) { switch (view.getId()) { case R.id.bt1: if (mc1Click) { mc1.cancel(); pb1.setVisibility(View.GONE); mc1Click = false; } else { pb1.setVisibility(View.VISIBLE); mc1.start(); mc1Click = true; } break; case R.id.bt2: if (mc2Click) { pb2.setVisibility(View.GONE); mc2.cancel(); mc2Click = false; } else { pb2.setVisibility(View.VISIBLE); mc2.start(); mc2Click = true; } break; case R.id.bt3: if (mc3Click) { pb3.setVisibility(View.GONE); mc3.cancel(); mc3Click = false; } else { pb3.setVisibility(View.VISIBLE); mc3.start(); mc3Click = true; } break; } } /*定义一个倒计时的内部类*/ class MyCount extends CountDownTimer { Button mBt; ProgressBar mPb; public MyCount(long millisInFuture, long countDownInterval) { super(millisInFuture, countDownInterval); } public void setPb(Button bt, ProgressBar pb) { mBt = bt; mPb = pb; } @Override public void onFinish() { mPb.setVisibility(View.GONE); } @Override public void onTick(long millisUntilFinished) { mBt.setText("请等待30秒(" + millisUntilFinished / 1000 + ")..."); Toast.makeText(MainActivity.this, millisUntilFinished / 1000 + "", Toast.LENGTH_LONG).show(); } } }
activity_main.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/activity_main" android:layout_width="match_parent" android:layout_height="match_parent" android:paddingBottom="@dimen/activity_vertical_margin" android:paddingLeft="@dimen/activity_horizontal_margin" android:paddingRight="@dimen/activity_horizontal_margin" android:paddingTop="@dimen/activity_vertical_margin" android:orientation="vertical" tools:context="cn.sh.changxing.countdowntest.MainActivity"> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal"> <Button android:id="@+id/bt1" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="1" android:text="测试启动1"/> <ProgressBar android:id="@+id/pb1" style="?android:attr/progressBarStyleSmall" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" android:indeterminate="true"/> </LinearLayout> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal"> <Button android:id="@+id/bt2" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="1" android:text="测试启动2"/> <ProgressBar android:id="@+id/pb2" style="?android:attr/progressBarStyleSmall" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" android:indeterminate="true"/> </LinearLayout> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal"> <Button android:id="@+id/bt3" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="1" android:text="测试启动3"/> <ProgressBar android:id="@+id/pb3" style="?android:attr/progressBarStyleSmall" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" android:indeterminate="true"/> </LinearLayout> </LinearLayout>
以上所述是小编给大家介绍的Android 中不用线程如何实现倒计时,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对小牛知识库网站的支持!
本文向大家介绍Android实现自定义倒计时,包括了Android实现自定义倒计时的使用技巧和注意事项,需要的朋友参考一下 最近工作中遇到个要做倒计时60秒的进度条,经过参考别人的资料做出来需求的效果。废话少说先来个效果: 一定想知道是怎么实现的吧!下面是代码 然后新建一个attr.xml; 这样一个自定义的view就写完了;那怎么用呢;布局就不说了; 这样就轻轻松松的跑起来了,希望能帮助到需要的
本文向大家介绍Android实现订单倒计时功能,包括了Android实现订单倒计时功能的使用技巧和注意事项,需要的朋友参考一下 先上效果图 1.activity_main.xml 2.MainActivity.class 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。
本文向大家介绍Android实现倒计时方法汇总,包括了Android实现倒计时方法汇总的使用技巧和注意事项,需要的朋友参考一下 Android开发中经常会有倒计时的功能,下面将总结出常见的集中实现方式。 1.直接使用Handler的消息机制来实现 xml布局中文件如下: java代码如下: 2.使用Timer和TimerTask,结合handler一起实现倒计时 3.使用android自带的原生倒
本文向大家介绍Android 实现列表倒计时功能,包括了Android 实现列表倒计时功能的使用技巧和注意事项,需要的朋友参考一下 单个计时器,然后遍历数据 刷新条目; 两种实现方式:1、Handler轮询; 2、子线程睡眠(时间到后 移除列表中的条目会有问题); 代码很简单,没有任何难度,列表使用 RecyclerView+BaseRecyclerViewAdapterHelper实现; Ge
本文向大家介绍简单实现Android倒计时效果,包括了简单实现Android倒计时效果的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了Android倒计时效果的具体代码,供大家参考,具体内容如下 需求: a.在后台添加时,如果是今日直播,则需要添加开始时间(精确到秒); b.离开始时间超过1天,显示为:“离开时还有X天”; c.离开时时间不到1天,显示为:“离开时还有XX:XX:XX
有人能帮我理解什么是Java以及什么时候使用它吗? 我不太清楚这个程序是如何工作的。据我所知,所有三个线程都同时启动,每个线程在3000ms后都会调用CountDownLatch。所以倒计时会一个接一个地递减。闩锁变为零后,程序会打印“已完成”。也许我理解的方式不正确。 // -----------------------------------------------------