Android倒计时控件的实现

2016年9月20日 更新
之前制作的Timer虽然可以完成计时的功能,但是使用时还是要进行复杂的处理操作,而倒计时通常都是使用在TextView上,以显示给用户。比如,”跳过广告”等,所以我就对倒计时进行了适当的封装,使其更方便我的使用。

基本思想就是给这个倒计时控件传入一个TextView,让其倒计时的时间可以显示在这个TextView中。
当然,你也可以直接将它封装为一个拥有计时功能的TextView。

/**
 * 倒计时
 * 
 * Created by feathers on 16-9-18.
 * @author Feathers
 */
public abstract class CountTimer {

    private Handler mHandler;
    private Timer mTimer;
    private TimerTask mTask;

    private int TIME = 0;

    private TextView textView;

    /**
     * 创建一个倒计时,以秒为单位
     *
     * @param timeSec  倒计时时间
     * @param textView 倒计时要显示在哪个textView
     */
    public CountTimer(int timeSec, TextView textView) {
        this.TIME = timeSec;
        this.textView = textView;
        initCountTimer();
    }

    /**
     * 初始化倒计时
     */
    public void initCountTimer() {
        UIUtils.runOnUIThread(new Runnable() {
            @Override
            public void run() {
                mHandler = new Handler() {
                    @Override
                    public void handleMessage(Message msg) {
                        if (msg.what == 0x123) {
                            int i = msg.arg1;
                            if (textView != null) {
                                textView.setText("跳过" + String.valueOf(i) + "s");
                            }
                     /*显示完后 在次启动计时器*/
                            if (TIME > 0) {
                                startTimer();
                            } else {
                                onFinish();
                            }
                        }
                    }
                };
            }
        });
    }


    public void startTimer() {
        mTimer = new Timer();
        mTask = new TimerTask() {
            @Override
            public void run() {
                TIME--;
                Message msg = mHandler.obtainMessage();
                msg.what = 0x123;
                msg.arg1 = TIME;
                mHandler.sendMessage(msg);
            }
        };
        mTimer.schedule(mTask, 1000);
    }

    /**
     * 重新设置事件,并运行倒计时
     *
     * @param timerSec
     */

    public void setTime(int timerSec) {
        this.TIME = timerSec;
        startTimer();
    }

    /**
     * 终止任务
     */
    public void stopTimer() {
        if (mTimer != null) {
            mTimer.cancel();
            mTimer = null;
        }
        if (mTask != null) {
            mTask.cancel();
            mTask = null;
        }
    }

    /**
     * 计时结束后要做的事情
     */
    protected abstract void onFinish();
}

举个栗子,欢迎界面延时跳转下一个Activity,附一个计时的TextView:

<TextView
            android:id="@+id/tv_jump_over"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentRight="true"
            android:layout_marginRight="30dp"
            android:layout_marginTop="40dp"
            android:background="@drawable/bt_jump_over_background"
            android:text="跳过3s"
            android:textColor="#FFFFFF"/>
 /**
     * 初始化倒计时小组件以及功能
     */
    private void initTimer() {
        mTextView = (TextView) findViewById(R.id.tv_jump_over);

        // 创建一个倒计时
        mCountTimer = new CountTimer(TIME_SEC, mTextView) {
            @Override
            protected void onFinish() {
                // 倒计时结束时,开启下一个activity
                MainActivity.actionStart();
            }
        };
        mCountTimer.startTimer();

        // 让textView拥有跳过计时的功能
        assert mTextView != null;
        mTextView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                mCountTimer.stopTimer();
                MainActivity.actionStart();//跳转到MainActivity
            }
        });
    }

以下是原来的文章,我是华丽的分割线


2016年2月14日 累吗?累就对了!舒服是留给死人的!

自学android也有差不多一个学期了,为了防止自己把辛辛苦苦所学的android知识丢干净,所以本大专屌丝决定,在这期间每天花点时间来充电,以防大脑饿死!
再说不写点东东怎么能找到成就感。

目的:巩固Timer、TimerTask这两个类,还有Hanler的简单实用。
好吧,先介绍一下Timer、TimerTask这两个类。

Timer、TimerTask均在java.util包下
Timer,顾名思义,计时器,用来计时。
而TimerTask,计时器的任务,也就是对什么事情计时。
我们通常通过Timer创建计时器,用schedule指派任务设置时间

让我们开始学习最简单的倒计时:

一、UI设计

灰常简单:
counttime UI

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: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="com.example.feathers.counttime.MainActivity">
    <TextView
        android:id="@+id/text_time"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" />
    <EditText
        android:id="@+id/edit_time"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" />
    <Button
        android:id="@+id/bt_start"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="点击开始倒计时"/>
</LinearLayout>

二、逻辑实现

MainActivity.java

package com.example.feathers.counttime;
import android.app.Activity;
import android.os.Handler;
import android.os.Message;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
import java.util.Timer;
import java.util.TimerTask;
public class MainActivity extends Activity {
    private EditText editText;
    private TextView textView;
    private Button button;
    private int time = 0;
    private Timer timer = null;
    private TimerTask task = null;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        init();/*初始化UI*/
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                /*点击后会自动将设置的时间显示在textView中*/
                textView.setText(editText.getText().toString());
                /*获取用户输入的时间*/
                time = Integer.parseInt(editText.getText().toString());
                /*开始计时*/
                if (time > 0)
                startTimer();
            }
        });
    }
    private Handler mHandler = new Handler(){
        @Override
        public void handleMessage(Message msg) {
            if (msg.what == 0x123) {
                int i = msg.arg1;
                textView.setText(String.valueOf(i));
                /*显示完后 在次启动计时器*/
                if (time > 0)
                startTimer();
            }
        }
    };
    private void startTimer() {
        timer = new Timer();
        task = new TimerTask() {
            @Override
            public void run() {
                time--;
                Message msg = mHandler.obtainMessage();
                msg.what = 0x123;
                msg.arg1 = time;
                mHandler.sendMessage(msg);
            }
        };
        timer.schedule(task,1000);
    }
    public void init() {
        editText = (EditText) findViewById(R.id.edit_time);
        textView = (TextView) findViewById(R.id.text_time);
        button = (Button) findViewById(R.id.bt_start);
    }
}

欢迎指出错误或给出意见!

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值