Swift自定义iOS中的TabBarController并为其添加动画_Swift

自定义TabBarController
有时候默认的TabBarController不能满足我们的开发需求,比如你想用彩色的图标,系统却只调用图标的轮廓,所以我们需要自己定义一下TabBar。

方法一:修改TabBarController中的TabBar
新建 CustomTabBarController 类继承自 UITabBarController,并在Storyboard中设置:

首先自定义 tabBar 的背景,在 viewDidLoad() 方法中添加:

复制代码 代码如下:

// 用图片
self.tabBar.backgroundImage = UIImage(named: "TabBarBG")
// 或
// 直接用颜色
self.tabBar.barTintColor = UIColor.blackColor()

然后修改每个子ViewController中的TabBarItem,在 viewDidLoad() 方法中继续添加:

复制代码 代码如下:

for (index, viewController) in self.viewControllers!.enumerate() {
    // 声明 TabBarItem 的Image,如果没有imageWithRenderingMode方法Image只会保留轮廓
    let image = UIImage(named: "TabBar\(index)")?.imageWithRenderingMode(.AlwaysOriginal)
    let selectedImage = UIImage(named: "TabBar\(index)Sel")?.imageWithRenderingMode(.AlwaysOriginal)

    // 声明新的无标题TabBarItem    
    let tabBarItem = UITabBarItem(title: nil, image: image, selectedImage: selectedImage)
    // 设置 tabBarItem 的 imageInsets 可以使图标居中显示
    tabBarItem.imageInsets = UIEdgeInsetsMake(6, 0, -6, 0)

    viewController.tabBarItem = tabBarItem
}

完成!效果如下所示:

方法二:自定义TabBar
上述方法唯一的问题是,当你想设置item的选定背景时:

复制代码 代码如下:

self.tabBar.selectionIndicatorImage = UIImage(named: "TabBarBGSel")

背景图不能铺满整个item,两边会有空隙(如果大家有更好的方法解决可以留言,谢谢),如图:

这个时候需要自定义TabBar,首先声明一个UIButton用来记录当前选中的Button:

复制代码 代码如下:

var selectButton: UIButton!

在viewDidLoad()方法的底部加入以下代码:

复制代码 代码如下:

// 先记录下Controller自带的tabBar的frame
let rect = self.tabBar.frame
// 移除Controller自带的TabBar
self.tabBar.removeFromSuperview()

// 用记录下的frame建立一个UIView
let myView = UIView(frame: rect)
// 设置这个View的背景色
myView.backgroundColor = UIColor(patternImage: UIImage(named: "TabBarBG")!)
self.view.addSubview(myView)

for var i = 0; i < self.viewControllers?.count; i++ {

    let button = UIButton()

    // 根据子ViewController的个数计算Button的宽度
    let width = myView.frame.size.width / CGFloat(self.viewControllers!.count)
    let x = CGFloat(i) * width
    button.frame = CGRectMake(x, 0, width, myView.frame.size.height)

    // 设置Button未选中时候的图标
    let image = UIImage(named: "TabBar\(i)")?.imageWithRenderingMode(UIImageRenderingMode.AlwaysOriginal)
    button.setImage(image, forState: UIControlState.Normal)

    // 设置Button选中时候的图标,注意这里Button的状态是Selected,而不是Highlighted
    let selImage = UIImage(named: "TabBar\(i)Sel")?.imageWithRenderingMode(UIImageRenderingMode.AlwaysOriginal)
    button.setImage(selImage, forState: UIControlState.Selected)

    // 设置Button未选中和选中时候的背景图
    button.setBackgroundImage(UIImage(named: "TabBarBG"), forState: UIControlState.Normal)
    button.setBackgroundImage(UIImage(named: "TabBarBGSel"), forState: UIControlState.Selected)

    // 去掉UIButton自带的高光效果
    button.adjustsImageWhenHighlighted = false

    myView.addSubview(button)

    // 设置UIButton的标记
    button.tag = i

    button.addTarget(self, action: "onClick:", forControlEvents: UIControlEvents.TouchUpInside)

    // 设置默认的选中项
    if i == 0 {
        button.selected = true
        self.selectButton = button
    }
}
    /**
    自定义Button的点击事件

    :param: button
    */
    func onClick(button: UIButton) {
        // 将上个选中按钮设置为未选中
        self.selectButton.selected = false
        // 当前按钮设置为选中
        button.selected = true
        // 记录选中按钮
        self.selectButton = button

        // 通过UITabBarController的selectedIndex属性设置选中了哪个UIViewController
        self.selectedIndex = button.tag
    }

最终效果如下:

给自定义TabBarController添加动画
如何自定义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
}

最终效果如下:

时间: 2024-10-31 20:10:28

Swift自定义iOS中的TabBarController并为其添加动画_Swift的相关文章

Swift自定义cell中如何做到页面跳转并且传值

问题描述 Swift自定义cell中如何做到页面跳转并且传值 Swift语言, 我是折叠tableview,自定义了一个cell,cell里面有很多按钮,点击每个按钮都跳转到不同的页面,我想请教下如何带值跳转呢? 解决方案 cell中的按钮添加的时候设置button的tag.然后点击的时候获取tag来得到不同的值跳转页面

iOS中UIActivityIndicatorView的用法及齿轮等待动画实例_IOS

基础@派生自UIView,所以它是视图,也可以附着在视图上.一.创建 复制代码 代码如下: // 因为UIActivityIndicatorView的大小是固定的,可以直接设置它.center UIActivityIndicatorView* activityIndicatorView = [ [ UIActivityIndicatorView alloc ] initWithFrame:CGRectMake(250.0,20.0,30.0,30.0)]; 二. 属性设置风格 复制代码 代码如下

iOS中几种数据持久化方案:我要永远地记住你!

概论 所谓的持久化,就是将数据保存到硬盘中,使得在应用程序或机器重启后可以继续访问之前保存的数据.在iOS开发中,有很多数据持久化的方案,接下来我将尝试着介绍一下5种方案: plist文件(属性列表) preference(偏好设置) NSKeyedArchiver(归档) SQLite 3 CoreData 沙盒 在介绍各种存储方法之前,有必要说明以下沙盒机制.iOS程序默认情况下只能访问程序自己的目录,这个目录被称为"沙盒". 1.结构 既然沙盒就是一个文件夹,那就看看里面有什么吧

Swift开发iOS应用过程中的问题和解决记录

Swift开发iOS应用过程中的问题和解决记录 虚拟机里安装OSX+XCode开发环境 用真机的请直接跳过这个部分. 主要是在VitrualBox里安装mac系统和xcode,参考这篇教程,VirtualBox的版本是4.3.18 r96156,OSX版本是10.11 El Capitan,XCode版本是7.1 (7B91b). 经过几天的初步使用,感觉用虚拟机开发iOS基本能够满足要求,i5/8g/ssd的配置目测能达到真机70%的开发效率.主要存在的问题是:1)在宽屏上无法满屏,两边会留有

Android UI设计系列之自定义SwitchButton开关实现类似IOS中UISwitch的动画效果(2)_Android

做IOS开发的都知道,IOS提供了一个具有动态开关效果的UISwitch组件,这个组件很好用效果相对来说也很绚丽,当我们去点击开关的时候有动画效果,但遗憾的是Android上并没有给我们提供类似的组件(听说在Android4.0的版本上提供了具有动态效果的开关组件,不过我还没有去看文档),如果我们想实现类似的效果那该怎么办了呢?看来又得去自定义了. 公司的产品最近一直在做升级,主要做的就是把界面做的更绚丽更美观给用户更好的体验(唉,顾客是上帝......),其中的设置功能中就有开关按钮,原来的开

ios中带TabBar的导航控制器,自定义右滑手势返回

问题描述 ios中带TabBar的导航控制器,自定义右滑手势返回 右滑返回上一级页面时,tabBar不能紧贴着第一级页面,而是浮在最上层 解决方案 看不明白是什么情况...看不明白是什么情况...看不明白是什么情况...看不明白是什么情况...看不明白是什么情况...看不明白是什么情况...

iOS中给自定义tabBar的按钮添加点击放大缩小的动画效果_IOS

之前想过一些通过第三方的方式实现动画,感觉有点麻烦,就自己写了一个 不足之处还望大家多多指出 // 一句话,写在UITabBarController.m脚本中,tabBar是自动执行的方法 // 点击tabbarItem自动调用 -(void)tabBar:(UITabBar *)tabBar didSelectItem:(UITabBarItem *)item { NSInteger index = [self.tabBar.items indexOfObject:item]; [self a

使用Swift实现iOS App中解析XML格式数据的教程_Swift

在IOS中,提供了一套解析XML数据的API.其实也很简单,就是NSXMLParser和NSXMLParserDelegate. 可以直接指定到XML的URL去实例化NSXMLParser 复制代码 代码如下: public convenience init?(contentsOfURL url: NSURL) 解析文件,返回的是一次解析的结果 复制代码 代码如下: NSXMLParser.parse() -> Bool 监听解析节点的属性 复制代码 代码如下: NSXMLParserDeleg

iOS中 图文混排/自定义图文混排 作者:韩俊强

指示根视图:(准备几张图片,把label加载在window上) CustomLable *label = [[CustomLable alloc]initWithFrame:CGRectMake(0, 60, self.window.bounds.size.width, self.window.bounds.size.height)]; label.backgroundColor = [UIColor greenColor]; [self.window addSubview:label]; 引进