android时间倒计时自定义控件天时分,安卓自定义倒计时控件

用途

实现倒计时效果.

效果图

9316efb46754

主要代码

class CountDownTextView(context: Context, attrs: AttributeSet? = null) :

AppCompatTextView(context, attrs) {

private var mOnFinishCallback: OnFinishCallback? = null

private var startNum = 10

private var endNum = 1

private val intervalTime = 500 //重绘间隔时间

var currentNum = startNum

init {

background = getCircleDrawable()

text = currentNum.toString()

}

fun setCallback(onFinishCallback: OnFinishCallback) {

mOnFinishCallback = onFinishCallback

}

override fun onDraw(canvas: Canvas) {

super.onDraw(canvas)

// 隔一段时间重绘一次, 动画效果

handler.postDelayed(runnable, intervalTime.toLong())

}

private val runnable = Runnable {

changeText()

invalidate()

}

private fun changeText() {

if (currentNum > endNum) {

currentNum--

} else {

mOnFinishCallback?.onFinished()

visibility = GONE

}

text = currentNum.toString()

}

private fun getCircleDrawable() = GradientDrawable().also {

it.shape = GradientDrawable.OVAL

val strokeWidth = 4 // 边框宽度

val strokeColor = Color.parseColor("#FFD700") //边框颜色

it.setStroke(strokeWidth, strokeColor)

it.setColor(Color.parseColor("#DA70D6"))

}

}

interface OnFinishCallback {

fun onFinished()

}

使用样例

布局文件中增加如下内容:

android:id="@+id/countDownTv"

android:layout_width="100dp"

android:layout_height="100dp"

android:gravity="center"

android:textColor="#FFFFFF"

android:textSize="50sp" />

设置回调

countDownTv.setCallback(object : OnFinishCallback {

override fun onFinished() {

Toast.makeText(this@MainActivity, "dddd", Toast.LENGTH_LONG).show()

}

})

完整源代码

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值