android 倒计时 界面,Android倒计时控件实现

原标题:Android倒计时控件实现

今日科技快讯

今年二季度小米手机出货2316万台,环比增长70%,预计明年小米手机的出货量将突破一亿台。而就在昨天,小米手机官微发布了招聘启事:“小米未来一年需要在手机业务上招募上千名研发人才,急需各种工程师,包括天线工程师、射频电路设计工程师、基带硬件工程师、资深结构工程师、摄像头项目开发工程师、图像工程师、相机工程师、显示模组开发工程师、高级音频硬件工程师等等。”

作者简介

本篇来自 caotong1的投稿,分享了一个功能全面的倒计时控件,希望大家喜欢。

caotong1的博客地址:

http://blog.csdn.net/qq654115417

正文

学如逆水行舟,不进则退,借之自勉,从今天开始更新博客。倒计时是一个可满足多环境的功能,如:会议、学校等。因为应用广泛,所以要具备满足不同情况下的用户需求,起码要有如下功能点:悬浮、拖动、全屏、缩小、纪录时间、暂停、播放。效果图如下:

24b75cb1d81dae8d70f09094344946c3.gif

那么如何实现这个倒计时功能?需要围绕核心功能来延伸开发:

59d1134307112302885b46ab208dc42e.png

不论是全屏还是缩小,都需要选择时间之后才能开始倒计时,那么首先实现自定义滑动时间。

实现一个如此功能的自定义view,需要如下为步骤:以选择中的时间字体为轴心,分上、下2部分时间,和上下滑动选择时间,首先绘制时间显示字体:

0517cf0b5d4f389c92f956b8ea59eb7e.png

Paint.FontMetricsInt 绘制文本对象。fmi.top,fmi.bottom 获取最高字符和最低字符到基准点的值。 因为选择和未选择的时间需要大小亮度区分出来,所有上下方的时间需要另行绘制:

18027989075e975e2a631a947d3e273c.png

如此显示时间绘制完毕,之后再定义随手势拖动来选择时间,这里需要定义 onTouch 事件:

MotionEvent.ACTION_DOWN:纪录 y 坐标

MotionEvent.ACTION_MOVE:根据先前手势按下时的坐标,再与移动时的坐标对比来判断是向上还是向下滑动

13e0d7ecb2cb4bb444234423abc2fc9d.png

MotionEvent.ACTION_UP:

30c7dac128b36e69253ff9214896fc52.png

当抬手的时候纪录当前选中时间,定义接口获取时间。

完成自定义滑动时间后,可以来创建正常形态下的倒计时界面了,因为要满足所有环境下能使用倒计时,所以这里 3个view 都是用 WindowManager 来创建悬浮窗:

dc9c330ef9303155aa5a9d4e0a837a92.png

接下来在创建 TimerStandardView 时需要设置滑动条的时间:

a2d7ac77614311d2d25e697e9a9a9ae6.png

这里设置的是一个小时的倒计时,足够满足大部分的需求,另外在这里需要注意在缩小和全屏下切换回正常形态的倒计时,需要判断是否计时结束切换回来:

6b0bc2eb0679f3c6c4dd27a2408e7e5a.png

Create view 之后当点击开始倒计时之后,如果用户不进行操作,这里设计4秒之后自动切换至缩小形态,这里使用 CountDownTimer 来倒计时执行。

CountDownTimer 的相关知识网上很多这里就不再赘述。这么设计之后,那么问题来了,如果用户拖动了这个悬浮窗,是不是这里倒计时就不能再执行4秒切换,用户不再拖动,又需要重新开始4秒倒计时,这里可以使用 handle 来传递停止和开始的指令:

2a473b9d71253bff16f4d4bb3e89fe0c.png

a16d9b177915f0fcb4aeeba516fe29f1.png

在用户拖动悬浮窗改变位置后需要注意,如果切换形态是需要记录相互位置的,以此来提高用户体验,比如在TV上如果不记录位置还得重新点击拖动,所以使用本地存储来保存x,y的坐标,在拖动悬浮窗时存储位置:

fba637744cd7656f0fc071a1b0c6b8ff.png

在创建悬浮窗时再获取位置:

9540c236fbf4ad7dc809bf1ade226754.png

以上基本就完成大部分的功能需求,然后就只剩下开始和暂停功能了:

04b2d70c85bdb4d60f7f2645d09a89eb.png

19387699f4d45c0b3e72f12450682269.png

倒计时计算非常简单,这里我就不再浪费时间了,具体可以看源码,至于剩下的缩小和全屏倒计时界面基本是一样的流程。另外需要注意的是如果是在TV和平板上是不会出现适配不佳的问题,要是用手机调试的话需要修改下 dimens。那么到这里这篇博客就告一段落了。第一次写博客也不知道质量如何,欢迎大家拍砖,谢谢。代码地址:

http://download.csdn.net/download/qq654115417/9854122

更多

每天学习累了,看些搞笑的段子放松一下吧。关注最具娱乐精神的公众号,每天都有好心情。

如果你有好的技术文章想和大家分享,欢迎向我的公众号投稿,投稿具体细节请在公众号主页点击“投稿”菜单查看。返回搜狐,查看更多

责任编辑:

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值