[iOS]给自定义TabBarController添加动画 (Swift)

转载请注明出处:http://www.jianshu.com/p/d487a87105e7 ,本文出自老初的简书.

如何自定义TabBarController我们在上一篇已经讲过,现在为自定义的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方法,动画效果也在这里面实现:

func onClick(button: UIButton) {
    // 将上个选中俺就设置为为选中
    self.currentSelectedButton.selected = false
    // 当前按钮设置为选中
    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地址

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,678评论 25 708
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,259评论 4 61
  • 而且时间还在走 拉起窗帘的房间没有影子 睡眠像是水里的花 空调安静得像个孩子 猫在客厅里没有声响 挡住了春天气温却...
    向一阅读 590评论 0 0
  • “王满仓和蒋小薇要结婚了!” 这个消息在医院炸开了锅。 “王满仓,你好福气!”主任拍着我的肩膀说。 我这个平日里不...
    酸杏儿阅读 608评论 8 11
  • 他,从繁复中抽离出生活本真,回归自然舒适的温暖与感动,每一幅作品的创作与呈现,均在与曾经的自己作全面深度的揉合,在...
    朱三妹阅读 320评论 1 0