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

轉(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截的不好,各位老師都是用的什么截圖軟件啊?

GitHub地址

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末混聊,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子乾巧,更是在濱河造成了極大的恐慌句喜,老刑警劉巖,帶你破解...
    沈念sama閱讀 223,207評論 6 521
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件沟于,死亡現(xiàn)場離奇詭異咳胃,居然都是意外死亡,警方通過查閱死者的電腦和手機旷太,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,455評論 3 400
  • 文/潘曉璐 我一進店門拙绊,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事标沪¢剩” “怎么了?”我有些...
    開封第一講書人閱讀 170,031評論 0 366
  • 文/不壞的土叔 我叫張陵金句,是天一觀的道長檩赢。 經(jīng)常有香客問我,道長违寞,這世上最難降的妖魔是什么贞瞒? 我笑而不...
    開封第一講書人閱讀 60,334評論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮趁曼,結(jié)果婚禮上军浆,老公的妹妹穿的比我還像新娘。我一直安慰自己挡闰,他們只是感情好乒融,可當我...
    茶點故事閱讀 69,322評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著摄悯,像睡著了一般赞季。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上奢驯,一...
    開封第一講書人閱讀 52,895評論 1 314
  • 那天申钩,我揣著相機與錄音,去河邊找鬼瘪阁。 笑死撒遣,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的管跺。 我是一名探鬼主播愉舔,決...
    沈念sama閱讀 41,300評論 3 424
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼伙菜!你這毒婦竟也來了轩缤?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,264評論 0 277
  • 序言:老撾萬榮一對情侶失蹤贩绕,失蹤者是張志新(化名)和其女友劉穎火的,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體淑倾,經(jīng)...
    沈念sama閱讀 46,784評論 1 321
  • 正文 獨居荒郊野嶺守林人離奇死亡馏鹤,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,870評論 3 343
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了娇哆。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片湃累。...
    茶點故事閱讀 40,989評論 1 354
  • 序言:一個原本活蹦亂跳的男人離奇死亡勃救,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出治力,到底是詐尸還是另有隱情蒙秒,我是刑警寧澤,帶...
    沈念sama閱讀 36,649評論 5 351
  • 正文 年R本政府宣布宵统,位于F島的核電站晕讲,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏马澈。R本人自食惡果不足惜瓢省,卻給世界環(huán)境...
    茶點故事閱讀 42,331評論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望痊班。 院中可真熱鬧勤婚,春花似錦、人聲如沸涤伐。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,814評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽废亭。三九已至,卻和暖如春具钥,著一層夾襖步出監(jiān)牢的瞬間豆村,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,940評論 1 275
  • 我被黑心中介騙來泰國打工骂删, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留掌动,地道東北人。 一個月前我還...
    沈念sama閱讀 49,452評論 3 379
  • 正文 我出身青樓宁玫,卻偏偏與公主長得像粗恢,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子欧瘪,可洞房花燭夜當晚...
    茶點故事閱讀 45,995評論 2 361

推薦閱讀更多精彩內(nèi)容

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