50天iOS挑戰(Swift) - 第7天:彈出View后背景變暗效果
50天,每天一個Swift語言的iOS練手項目,覆蓋iOS開發的主要知識。貴在堅持,重在思考
文章列表:http://www.lxweimin.com/nb/13566182
Github項目:https://github.com/Minecodecraft/50DaysOfSwift
簡介
很多項目都會有彈出view效果,同時背景會變暗,這個demo就實現一下背景變暗效果
主要知識點: 動畫閉包、彈出view
GIF
過程
1、 分析
要實現彈出view后背景變暗的效果,只需要在原有view之上添加一個帶透明度背景即可,然后再添加彈出框即可滿足需求。
2、 界面實現
首先添加上述兩個view,bkgView為背景,popupView為彈出窗口
// 添加帶透明度的背景視圖,從而實現下方視圖變暗
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、 動畫實現
iOS簡單動畫實現起來很容易,通過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。多謝~