轉(zhuǎn)載請注明出處:http://www.reibang.com/p/d487a87105e7 尽楔,本文出自老初的簡書.
如何自定義TabBarController我們在上一篇已經(jīng)講過六水,現(xiàn)在為自定義的TabBar增加動畫效果鲁僚。
直接上代碼:
// 用來記錄當前選中按鈕
private var currentSelectedButton = UIButton()
// 用來指示選中的背景
private var selectionIndicatorImageView: UIImageView!
// 單個item的寬度
private var itemWidth: CGFloat!
在viewDidLoad()方法中加入以下代碼:
override func viewDidLoad() {
super.viewDidLoad()
// 記錄TabBarController自帶TabBar的位置
let rect = self.tabBar.frame
// 移除TabBarController自帶的TabBar
self.tabBar.removeFromSuperview()
// 自定義TabBar的背景
let backgroundView = UIView(frame: rect)
backgroundView.backgroundColor = UIColor(patternImage: UIImage(named: "TabBarBG")!)
self.view.addSubview(backgroundView)
itemWidth = backgroundView.frame.size.width / CGFloat(self.viewControllers!.count)
selectionIndicatorImageView = UIImageView(frame: CGRectMake(0, 0, itemWidth, backgroundView.frame.size.height))
selectionIndicatorImageView.image = UIImage(named: "TabBarBGSel")
backgroundView.addSubview(selectionIndicatorImageView)
for var i = 0; i < viewControllers!.count; i++ {
let button = CGMTabBarButton(frame: CGRectMake(itemWidth * CGFloat(i), 0, itemWidth, backgroundView.frame.size.height))
let image = UIImage(named: "TabBar\(i)")!
let selImage = UIImage(named: "TabBar\(i)Sel")!
button.setImage(image, forState: UIControlState.Normal)
button.setImage(selImage, forState: UIControlState.Selected)
button.addTarget(self, action: "onClick:", forControlEvents: UIControlEvents.TouchUpInside)
button.tag = i
// 去掉buttond的高光效果
button.adjustsImageWhenHighlighted = false
backgroundView.addSubview(button)
}
}
添加onClick方法,動畫效果也在這里面實現(xiàn):
func onClick(button: UIButton) {
// 將上個選中俺就設(shè)置為為選中
self.currentSelectedButton.selected = false
// 當前按鈕設(shè)置為選中
button.selected = true
self.currentSelectedButton = button
let x = CGFloat(button.tag) + 0.5
// 為TabBarItem的背景添加動畫
UIView.animateWithDuration(0.4, delay: 0.0, usingSpringWithDamping: 0.7, initialSpringVelocity: 10.0, options: UIViewAnimationOptions.CurveEaseInOut, animations: { () -> Void in
self.selectionIndicatorImageView.center.x = self.itemWidth * x
}, completion: nil)
self.selectedIndex = button.tag
}
最終效果如下:
效果展示.gif
GIF截的不好,各位老師都是用的什么截圖軟件啊?