Swift - 使用UIDatePicker实现倒计时功能
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
|
import UIKit class ViewController : UIViewController { var ctimer: UIDatePicker ! var btnstart: UIButton ! var leftTime: Int = 180 var alertView: UIAlertView ! var timer: NSTimer ! override func viewDidLoad() { super .viewDidLoad() // Do any additional setup after loading the view, typically from a nib. ctimer = UIDatePicker (frame: CGRectMake (0.0, 120.0, 200.0, 200.0)) self .ctimer.datePickerMode = UIDatePickerMode . CountDownTimer ; //必须为 60 的整数倍,比如设置为100,值自动变为 60 self .ctimer.countDownDuration = NSTimeInterval (leftTime); ctimer.addTarget( self , action: "timerChanged" , forControlEvents: UIControlEvents . ValueChanged ) self .view.addSubview(ctimer) btnstart = UIButton .buttonWithType( UIButtonType . System ) as ! UIButton btnstart.frame = CGRect (x:100, y:400, width:100, height:100); btnstart.setTitleColor( UIColor .redColor(), forState: UIControlState . Normal ) btnstart.setTitleColor( UIColor .greenColor(), forState: UIControlState . Disabled ) btnstart.setTitle( "开始" , forState: UIControlState . Normal ) btnstart.setTitle( "倒计时中" , forState: UIControlState . Disabled ) btnstart.clipsToBounds = true ; btnstart.layer.cornerRadius = 5; btnstart.addTarget( self , action: "startClicked:" , forControlEvents: UIControlEvents . TouchUpInside ) self .view.addSubview(btnstart) } func timerChanged() { println ( "倒计时:\(self.ctimer.countDownDuration)" ) } /** *开始倒计时按钮点击 */ func startClicked(sender: UIButton ) { self .btnstart.enabled = false ; // 获取该倒计时器的剩余时间 leftTime = Int ( self .ctimer.countDownDuration); // 禁用UIDatePicker控件和按钮 self .ctimer.enabled = false ; // 创建一个UIAlertView对象(警告框),并确认,倒计时开始 alertView = UIAlertView () alertView.title = "到计时开始" alertView.message = "倒计时开始,还有 \(leftTime) 秒..." alertView.addButtonWithTitle( "确定" ) // 显示UIAlertView组件 alertView.show() // 启用计时器,控制每秒执行一次tickDown方法 timer = NSTimer .scheduledTimerWithTimeInterval( NSTimeInterval (1), target: self ,selector: Selector ( "tickDown" ), userInfo: nil ,repeats: true ) } /** *计时器每秒触发事件 **/ func tickDown() { alertView.message = "倒计时开始,还有 \(leftTime) 秒..." // 将剩余时间减少1秒 leftTime -= 1; // 修改UIDatePicker的剩余时间 self .ctimer.countDownDuration = NSTimeInterval (leftTime); println (leftTime) // 如果剩余时间小于等于0 if (leftTime <= 0) { // 取消定时器 timer.invalidate(); // 启用UIDatePicker控件和按钮 self .ctimer.enabled = true ; self .btnstart.enabled = true ; alertView.message = "时间到!" } } } |
Swift - 使用UIDatePicker实现倒计时功能的更多相关文章
- Java第十二次作业:什么是一维数组?什么是对象数组?吃金币游戏2.0版 新增炸弹功能 新增游戏倒计时功能 新增胜利失败检测功能 使用如鹏游戏引擎制作窗体 一维数组设置金币
什么是数组? 数组的定义:是用统一的名字代表这批数据,用序号来区分各个数据.数组是无序的数据元素按有序的下标组成的集合,分配固定空间大小的一种容器. 如何理解:其实就是一个同时放很多数据的变量. a= ...
- html5 canvas 实现倒计时 功能
function showTime(a) { var b = { id: "showtime", //canvasid x: 60, //中心点坐标 X轴; y: 60, //中心 ...
- 模块:js实现一个倒计时功能
1.给显示内容加样式 <style> #p1{font-size: large; color: red;} </style> 2.客户端页面 <div id=" ...
- iOS “获取验证码”按钮的倒计时功能
iOS 的倒计时有多种实现细节,Cocoa Touch 为我们提供了 NSTimer 类和 GCD 的dispatch_source_set_timer方法去更加方便的使用计时器.我们也可以很容易的的 ...
- Android 关于倒计时功能的实现
关于倒计时的实现,可以说有很多的方法,比较常见的就是Timer+TimerTask+Handler了,或者还可以配合Runnable.例如下面的代码: import java.util.Timer; ...
- iOS 按钮倒计时功能
iOS 按钮倒计时功能, 建议把按钮换成label,这样会避免读秒时闪烁 __block ; __block UIButton *verifybutton = _GetverificationBtn; ...
- Swift得知——使用和分类功能(四)
Swift得知--使用和分类功能(四) 总结Swift该功能使用的总可分为七类 1 ---- 没有返回值,没有參数的函数 2 ---- 有參数和返回值的函数 3 ---- 使用元祖来返回多个值 4 - ...
- js实现是倒计时功能
工作中经常用到倒计时的功能,最近在整理之前做的项目的时候,发现自己写过一个倒计时的功能的效果,这里和大家分享下!实现这个功能是用原生js写的,不需要加载额外的库文件!功能比较简单,但是可以在此基础上扩 ...
- App启动页倒计时功能
转载请注明出处:http://www.cnblogs.com/cnwutianhao/p/6753418.html 示例代码采用 RxJava + RxLifecycle + Data-Binding ...
随机推荐
- JQuery - 提交表单
[JavaScript] JQuery异步提交表单与文件上传 Jquery.form.js是一个可以异步提交表单及上传文件的插件. 文档地址:http://jquery.malsup.com/form ...
- SICP中sqrt(开方)的实现(附C#实现)
#lang racket (define (square x) (* x x)) (define (sqrt-iter guess x) (if (good-enough? guess x) gues ...
- javascript每日一练(九)——运动一:匀速运动
一.js的运动 匀速运动 清除定时器 开启定时器 运动是否完成:a.运动完成,清除定时器:b.运动未完成继续 匀速运动停止条件:距离足够近 Math.abs(当然距离-目标距离) < 最小运动 ...
- Android调整TimePicker和DatePicker大小
最近写了个app,里面要将DatePicker和TimePicker并列显示.但是,Android内部把DatePicker和 TimePicker大小固定了,导致4.5寸手机屏幕一行只能显示出一个, ...
- Server是如何完成针对请求的监听、接收与响应1
Server是如何完成针对请求的监听.接收与响应的[上] Server是ASP .NET Core管道的第一个节点,负责完整请求的监听和接收,最终对请求的响应同样也由它完成.Server是我们对所有实 ...
- 关于QT的系统总结(非常全面,非常好)
源地址:http://www.cnblogs.com/wangqiguo/p/4625611.html 阅读目录 编译环境与开发流程 QT项目的构成及原理 QT中的布局 QT中的通用控件 QVaria ...
- zookeeer 集群和伪集群模式
环境变量设置: # .bash_profile # Get the aliases and functions if [ -f ~/.bashrc ]; then . ~/.bashrc fi # U ...
- 基于visual Studio2013解决C语言竞赛题之0707月份输出
题目 解决代码及点评 /* 编一程序,打入月份号,输出该月的英文月名. 例如,输入"3",则输出"March",要求用指针数组处理. */ #includ ...
- Ultra Office Control 2.0
http://www.ultrashareware.com/Ultra-Office-Control.htm
- WM_PAINT消息详解,使用InvalidateRect或InvalidateRgn函数刻意产生WM_PAINT消息(WIN7里有变化,“调整视觉效果”,将“启用桌面组合”去掉)
什么时候会触发WM_PAINT消息消息呢? 以下内容来自大名鼎鼎的<Windows程序设计(第五版)> 大多数Windows程序在WinMain中进入消息循环之前的初始化期间都要呼叫函数U ...