swift - 利用UIDatePicker实现定时器的效果
效果图如下:

可以通过UIDatePicker调整倒计时的时间,然后点击UIButton开始倒计时,使用NSTimer进行倒计时的时间展示,我是声明了一个label也进行了标记,
然后点击按钮开始倒计时的同时,弹出一个alertview,alertview上展示倒计时的一次递减的效果!结束后,改变下label、button、alertview的title的
显示字样!
具体代码如下:
1、声明所需各类控件
var datePicker = UIDatePicker()
var myBtn = UIButton()
var alertCon = UIAlertController()
var hTimers = Timer()
var labels = UILabel()
var leftTimes:Int =
2、创建datepicker,并绑定响应方法,可以进行倒计时时间的改变,默认初始是60s
func creatPicker(){
datePicker.frame = CGRect(x:,y:,width:kScreenWidth-,height:)
datePicker.backgroundColor = UIColor.yellow
datePicker.locale = Locale(identifier:"zh_CN")
datePicker.addTarget(self, action: #selector(valueChanged), for: .valueChanged)
datePicker.datePickerMode = .countDownTimer
datePicker.setValue(UIColor.red, forKey: "textColor")
self.view.addSubview(datePicker)
}
响应方法的实现:
//时间选择器的响应方法
func valueChanged() { print("选择倒计时间为-->:\(datePicker.countDownDuration)")
}
3、创建button,并绑定响应方法
func creatDatePicker(){
myBtn.frame = CGRect(x:,y:,width:kScreenWidth-,height:)
myBtn.setTitle("按钮", for: .normal)
myBtn.setTitle("倒计时中", for: .disabled)
myBtn.backgroundColor = UIColor.orange
myBtn.setTitleColor(UIColor.white, for: .normal)
myBtn.setTitleColor(UIColor.blue, for: .disabled)
myBtn.addTarget(self, action: #selector(btnClick), for: .touchUpInside)
self.view.addSubview(myBtn)
}
响应方法的实现,在按钮的响应方法里面绑定NSTimer的响应方法,在点击按钮的时候触发
unc btnClick(){
myBtn.isEnabled = false
// 获取该倒计时的剩余时间
leftTimes = Int(datePicker.countDownDuration)
datePicker.isEnabled = false
// 创建alertcontroller
alertCon = UIAlertController(title:"倒计时开始",message:"倒计时开始,还有\(leftTimes)",preferredStyle:.alert)
let cancel = UIAlertAction(title:"取消",style:.cancel,handler:nil)
let okAction = UIAlertAction(title:"确定",style:.default,handler:nil)
alertCon.addAction(cancel)
alertCon.addAction(okAction)
self.present(alertCon, animated: true, completion: nil)
// 启动定时器
hTimers = Timer.scheduledTimer(timeInterval: , target: self, selector: #selector(clickDown), userInfo: nil, repeats: true)
}
4、实现倒计时的响应方法
func clickDown(){
labels.text = "倒计时开始,还有\(leftTimes)s"
alertCon.message = "倒计时开始,还有\(leftTimes)s"
// 剩余时间少一秒
leftTimes -=
datePicker.countDownDuration = TimeInterval(leftTimes)
if leftTimes <= {
// 取消定时器
hTimers.invalidate()
// 改变UIDatePicker和UiButton,还有UILabel的状态
datePicker.isEnabled = true
myBtn.isEnabled = true
labels.text = "倒计时结束"
alertCon.message = "时间到!"
}
}
这样就完成了!
swift - 利用UIDatePicker实现定时器的效果的更多相关文章
- 利用div实现遮罩层效果
利用div实现遮罩层效果就是利用一个全屏.半透明的div遮住页面上其它元素,典型的例子就是百度的登录界面.下面贴出示例代码: <!DOCTYPE html> <html> &l ...
- 利用MARQUEE实现正在处理效果
ASP.NET服务器端事件利用MARQUEE实现正在处理效果 前言:ASP.NET同仁们应该都遇到过当触发一个比较耗时的服务器端事件时,页面会处在一个等待的状态(即假死状态),用户体验非常不好,很 ...
- Swift - 用CATransform3DMakeRotation实现翻页效果
Swift - 用CATransform3DMakeRotation实现翻页效果 效果 源码 https://github.com/YouXianMing/Swift-Animations // // ...
- Swift - 多个mask的动画效果
Swift - 多个mask的动画效果 效果 源码 https://github.com/YouXianMing/Swift-Animations // // TranformFadeView.swi ...
- Swift - 用UIScrollView实现视差动画效果
Swift - 用UIScrollView实现视差动画效果 效果 源码 https://github.com/YouXianMing/Swift-Animations // // MoreInfoVi ...
- Android利用温度传感器实现带动画效果的电子温度计
概述 Android利用温度传感器实现带动画效果的电子温度计. 详细 代码下载:http://www.demodashi.com/demo/10631.html 一.准备工作 需要准备一部带有温度传感 ...
- 我的Android进阶之旅------>Android利用温度传感器实现带动画效果的电子温度计
要想实现带动画效果的电子温度计,需要以下几个知识点: 1.温度传感器相关知识. 2.ScaleAnimation动画相关知识,来进行水印刻度的缩放效果. 3.android:layout_weight ...
- 利用GPU实现翻页效果(分享自知乎网)
https://zhuanlan.zhihu.com/p/28836892?utm_source=qq&utm_medium=social 首发于Runtime 写文章 利用GPU实现翻页效果 ...
- 不借助 Javascript,利用 SVG 快速构建马赛克效果
之前在公众号转发了好友 Vajoy 的一篇文章 -- 巧用 CSS 把图片马赛克风格化. 核心是利用了 CSS 中一个很有意思的属性 -- image-rendering,它可以用于设置图像缩放算法. ...
随机推荐
- Ubuntu12.04下tomcat的安装与配置
1.下载tomcat 我的tomcat是从 http://tomcat.apache.org/download-70.cgi 这里下载的tar.gz版本的. 2.解压tomcat $sudo tar ...
- C10K问题及解决方案
转载自:http://blog.csdn.net/wangtaomtk/article/details/51811011 1 C10K问题 大家都知道互联网的基础就是网络通信,早期的互联网可以说是一个 ...
- lighttpd + php 移植配置
buildroot 内添加 lighttpd 和php 等相关选项 // make menuconfig Target packages ---> Interpreter languages a ...
- SpringMVC 常用工具类与接口
ClassPathResource 在类路径下读取资源 public final String getPath()public boolean exists()public InputStream g ...
- iOS边练边学--图片的拉伸
图片拉伸方法一: IOS 5.0以后才有的方法: - (void)viewDidLoad { [super viewDidLoad]; UIImageView *imageView = [[UIIma ...
- hibernate不调用save也保存上了
List<Instrument> insts = instService.search(search); if (insts.size() == 1) { Instrument inst ...
- 有趣的 Mysql 存储引擎
Mysql 提供了一套统一的应用开发模型和核心 API,因此,尽管不同的存储引擎拥有不同的特性,不过对于开发人员,应用操作都是完全透明的.应用层的连接并不直接访问存储引擎层,而是访问 Mysql 提供 ...
- 如果通过html 链接打开app
https://my.oschina.net/liucundong/blog/354029 <!doctype html> <html> <head> <me ...
- QT 交叉编译工具选择
使用QT交叉编译,生成的都是x86的可执行文件.Zoro告诉我交叉工具配置错了. 参考链接: http://www.cnblogs.com/zengjfgit/p/4744507.html linux ...
- am335x backlight
/****************************************************************************** * am335x backlight * ...