封装Android发送短信倒计时控件TimingTextView

首先既然是封装发送短信控件,那么这个控件里就需要文本,我们有两个系统控件可以选择。一个是TextView,一个是Button。由于Button会自带padding、gravity等属性不便自定义布局,所以我选择TextView作为此次自定义控件的父类。
由于该控件比较简单我就不多BB了,直接上代码,代码上注释很清楚。

package com.zhongde.haokuai.widget

import android.content.Context
import android.os.Handler
import android.util.AttributeSet
import android.widget.TextView
import java.lang.StringBuilder

/**
 * @package     com.goume.heyding.widget
 * @author      lucas
 * @date        2018/9/25
 * @des    倒计时
 */
class TimingTextView(context: Context?, attrs: AttributeSet?) : TextView(context, attrs) {
    //时长
    open var currentTime = 60
    //倒计时结束回调
    var onStopTime: (TimingTextView) -> Unit = {}
    //倒计时开始回调
    var onStartTime: (TimingTextView) -> Unit = {}
    val timeHandler = Handler()
    //计时任务
    val task = Task()
    //控件文本前缀
    var prefix = "重新发送("
    //后缀
    var suffix = "s)"
    //运行状态
    var isRunning = false

    inner class Task : Runnable {
        override fun run() {
            if (currentTime == 0) {
                //计时结束
                onStopTime(this@TimingTextView)
                isRunning = false
                return
            }
            //更新计时文本
            text = StringBuilder().append(prefix).append(currentTime).append(suffix).toString()
            currentTime--
            //每间隔一秒更新文本
            timeHandler.postDelayed(this, 1000)
        }

        //开始计时
        fun start() {
            onStartTime(this@TimingTextView)
            isRunning = true
            timeHandler.post(this)
        }

        //结束
        fun stop() {
            isRunning = false
            timeHandler.removeCallbacks(this)
        }
    }
}

此博客的目的只是为了提高开发效率和避免重复造轮子。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值