Android 中不用線程如何實現(xiàn)倒計時
需求:
有多個組件可以開啟倒計時,正常情況下默認倒計時時間終了后更新UI,另,用戶可以取消指定倒計時。
這里使用CountDownTimer進行倒計時,其中回調(diào)函數(shù)onFinish是在倒計時終了時回調(diào),onTick是在倒計時開始時回調(diào),用戶可以使用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;
}
}
/*定義一個倒計時的內(nèi)部類*/
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 中不用線程如何實現(xiàn)倒計時,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Android ViewPager制作新手導航頁(動態(tài)加載)
這篇文章主要為大家詳細介紹了Android ViewPager制作新手導航頁,了解什么是動態(tài)加載指示器,感興趣的小伙伴們可以參考一下2016-05-05
Android 5.0及以上編程實現(xiàn)屏幕截圖功能的方法
這篇文章主要介紹了Android 5.0及以上編程實現(xiàn)屏幕截圖功能的方法,結(jié)合實例形式分析了Android5.0以上實現(xiàn)截圖功能的相關(guān)類、函數(shù)及權(quán)限控制等操作技巧,需要的朋友可以參考下2018-01-01
Android開發(fā)使用Activity嵌套多個Fragment實現(xiàn)橫豎屏切換功能的方法
這篇文章主要介紹了Android開發(fā)使用Activity嵌套多個Fragment實現(xiàn)橫豎屏切換功能的方法,結(jié)合實例形式分析了Android使用Activity嵌套多個Fragment進行橫豎屏切換的原理與具體操作技巧,需要的朋友可以參考下2017-11-11
android使用ViewPager組件實現(xiàn)app引導查看頁面
這篇文章主要為大家詳細介紹了android使用ViewPager組件實現(xiàn)app引導查看頁面,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-07-07

