50天iOS挑战(Swift) - 第1天:秒表计时器
50天,每天一个Swift语言的iOS练手项目,覆盖iOS开发的主要知识。贵在坚持,重在思考
文章列表://www.greatytc.com/nb/13566182
Github项目:https://github.com/Minecodecraft/50DaysOfSwift
简介
本项目为仿照系统样式的计时器
主要知识点: Timer、Storyboard、StatuBar
过程
1、 思路整理
该项目是简单的Timer使用,为了增加难度,特意只设置两个按钮,分别负责(记录、复位)和(开始、停止、继续) 多个操作,锻炼逻辑思维能力。
主要思想就是:对于左按钮,在未开始时复位按钮为不可用状态,开始时为记录按钮,暂停时为复位状态,而若继续计时,则恢复记录状态。对于右按钮,在左按钮复位时变为开始状态,并清空记录的数据,否则为继续状态。上方显示时间的label也随此逻辑变化。
2、 Timer的使用
Timer的使用与NSTimer一样,使用self.timer = Timer.scheduledTimer(timeInterval: 0.01, target: self, selector: #selector(updateTime), userInfo: nil, repeats: true)
创建每毫秒执行一次的Timer即可,停止时self.timer.invalidate()
即可。
注意:在之前使用Timer时遇到了没有开启计时器的问题,查阅了很久,发现忘记使用scheduledTimer()
函数,在创建时要注意这点。
3、 Storyboard使用
Storyboard来辅助界面设计是很方便的了。设置好控件之后,直接拖入代码中创建IBOutlet、IBAction即可。
在这里顺便说一下初学时遇到的空指针问题,如果只在代码中删除了IBOutlet或者IBAction,没有在Storyboard的控件中删除,将会在程序启动时crash,如果遇到在Appdelegate出Thread的情况,可以检查一下是否是此问题。曾经因为这个问题调了一晚上,于是对空指针记忆犹新(Java选手:emmmmmmm…)
4、 状态栏的设置
由于使用了深色背景,会导致深色状态栏被底色覆盖。在此修改一下状态栏主题。
iOS的状态栏提供了深色和浅色主题。需要现在plist中设置属性然后在代码中修改。
步骤1:在plist.Info中添加View controller-based status bar appearance
属性为NO
步骤2:在代码中设置
UIApplication.shared.statusBarStyle = .lightContent
具体请查看项目源代码