[iOS]給自定義TabBarController添加動畫 (Swift)

轉(zhuǎn)載請注明出處:http://www.itdecent.cn/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截的不好,各位老師都是用的什么截圖軟件???

GitHub地址

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 179,037評論 25 709
  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫、插件、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 15,315評論 4 61
  • 而且時間還在走 拉起窗簾的房間沒有影子 睡眠像是水里的花 空調(diào)安靜得像個孩子 貓在客廳里沒有聲響 擋住了春天氣溫卻...
    向一閱讀 629評論 0 0
  • “王滿倉和蔣小薇要結(jié)婚了!” 這個消息在醫(yī)院炸開了鍋。 “王滿倉,你好福氣!”主任拍著我的肩膀說。 我這個平日里不...
    酸杏兒閱讀 658評論 8 11
  • 他,從繁復(fù)中抽離出生活本真,回歸自然舒適的溫暖與感動,每一幅作品的創(chuàng)作與呈現(xiàn),均在與曾經(jīng)的自己作全面深度的揉合,在...
    朱三妹閱讀 356評論 1 0

友情鏈接更多精彩內(nèi)容