50天iOS挑战(Swift) - 第1天:秒表计时器

50天iOS挑战(Swift) - 第1天:秒表计时器

50天,每天一个Swift语言的iOS练手项目,覆盖iOS开发的主要知识。贵在坚持,重在思考


文章列表:http://blog.csdn.net/b735098742/article/category/6978601
Github项目:https://github.com/Minecodecraft/50DaysOfSwift


简介

本项目为仿照系统样式的计时器
主要知识点: Timer、Storyboard、StatuBar

Showcase

过程

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
plist
步骤2:在代码中设置
UIApplication.shared.statusBarStyle = .lightContent

具体请查看项目源代码

发布了56 篇原创文章 · 获赞 16 · 访问量 10万+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章