50天iOS挑戰(zhàn)(Swift) - 第7天:彈出View后背景變暗效果
50天努溃,每天一個Swift語言的iOS練手項目,覆蓋iOS開發(fā)的主要知識搀突。貴在堅持漾月,重在思考
文章列表:http://www.reibang.com/nb/13566182
Github項目:https://github.com/Minecodecraft/50DaysOfSwift
簡介
很多項目都會有彈出view效果,同時背景會變暗瘦赫,這個demo就實現(xiàn)一下背景變暗效果
主要知識點: 動畫閉包辰晕、彈出view
過程
1、 分析
要實現(xiàn)彈出view后背景變暗的效果确虱,只需要在原有view之上添加一個帶透明度背景即可含友,然后再添加彈出框即可滿足需求。
2蝉娜、 界面實現(xiàn)
首先添加上述兩個view唱较,bkgView為背景,popupView為彈出窗口
// 添加帶透明度的背景視圖召川,從而實現(xiàn)下方視圖變暗
guard let window = UIApplication.shared.keyWindow else { return }
bkgView = UIView()
bkgView.frame = window.bounds
bkgView.backgroundColor = UIColor(white: 0.1, alpha: 0.6)
window.addSubview(bkgView)
// 添加彈出控件南缓,添加到window而不是bkgView
popupView = UIView()
popupView.frame = CGRect(x: 30, y: kScreenHeight, width: kScreenWidth-60, height: 60)
popupView.backgroundColor = UIColor.orange
popupView.layer.cornerRadius = 15
window.addSubview(popupView)
3、 動畫實現(xiàn)
iOS簡單動畫實現(xiàn)起來很容易荧呐,通過UIView提交一個動畫即可汉形,采用尾隨閉包來寫纸镊。
// 添加一個彈出動畫
UIView.animate(withDuration: 0.3) {
// 尾隨閉包播放彈出動畫
self.popupView.frame = CGRect(x: 30, y: (kScreenHeight-60)/2, width: kScreenWidth-60, height: 60)
}
// 收回動畫
UIView.animate(withDuration: 0.3) {
// 尾隨閉包播放彈出動畫
self.popupView.frame = CGRect(x: 30, y: kScreenHeight, width: kScreenWidth-60, height: 60)
// 提交一個延時任務線程
DispatchQueue.main.asyncAfter(deadline: .now() + 0.3) {
self.popupView.removeFromSuperview()
self.bkgView.removeFromSuperview()
}
}
一點小小的補充
- 項目源碼地址 GitHub,歡迎大家前來支持概疆,希望可以隨手留個Star逗威。多謝~