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

自定义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
}

最终效果如下:

(0)

相关推荐

  • Swift洗牌动画效果的实现方法

    目标效果: 点击动画按钮之后每张牌各自旋转 散开到屏幕上半部分的任意位置之后回到初始位置 比较像LOL男刀的技能动画 : ) 1: 创建卡牌对象 for _ in 0...49 { let cardSet = UIImageView(image: UIImage(named: "cardBackLandscape")) self.view.addSubview(cardSet) cardSet.frame = self.landscapeCardBack.frame self.card

  • iOS swift实现转场动画的方法示例

    转场动画介绍 转场动画在我们日常开发中是经常遇到的,所谓转场动画,就是一个控制器的view切到另一个控制器的view上过程中过的动画效果.本例子是实现了在导航控制器的titleView边上慢慢弹出一个控制器.下面话不多说,来一起看看详细的介绍: 效果图: 专场前 专场后 示例代码 首先自定义一个animator类.在需要转场的控制器内,设置代理 //需要设置转场动画的控制器titleViewVc.transitioningDelegate = aniamator//这里的animator是ani

  • 利用Swift实现各类的CATransition动画详解

    前言 最近因为工作的需要,打算用swift重构现有项目,实现过程中发现用到了很多系统的动画实现,因为之前的都是用OC实现的,这里主要是把一些动画效果来通过swift实现一下. 这篇文章主要是实现一下CATransition动画的不同效果. 第一步 创建一个swift文件并声明相应的枚举类型 enum TransitionAnimType : Int { case fade = 0, //淡入淡出 push, //推挤 reveal, //揭开 moveIn, //覆盖 cube, //立方体 s

  • Swift语言实现地图坐标弹跳动画

    下面应用Swift语言做地图坐标实现弹簧跳动的效果,具体实现方法如下所示: iOS动画大概分这几种: CoreAnimation动画(基础)UIView动画(animateWithDuration开头的函数,带弹簧特效)UIDynamic动画(有物理引擎) 上次写弹跳动画,由于刚开始学,就用了最基础的CA动画,但是因为自己不会写KeyFrame,所以还引用了一个开源库来实现下坠的弹跳效果,这样固然是实现了需求,但是一点都不优雅--从iOS7开始,有了2.3两种动画,就不再需要用老的CA动画去一点

  • 利用swift实现卡片横向滑动动画效果的方法示例

    本文主要给大家介绍了关于利用swift实现卡片横向滑动动画效果的相关资料,分享出来供大家参考学习,下面来一起看看详细的介绍吧. 根据惯例,首先上效果图: 那天去面试,面试官突然拿出手机点开了一个app,自个在那点了一会,然后问我 这个效果怎么实现,当时一看可以滑动,肯定用scrollView 或者 collectionView实现,就大概的说了下.今天刚好闲下来,就敲一敲这个效果. 先来分析下这个效果: 卡片是横向滚动,并且每个卡片的位置都是保持在屏幕中间的,而且 左右相邻的卡片都露出来一点边

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

    自定义TabBarController 有时候默认的TabBarController不能满足我们的开发需求,比如你想用彩色的图标,系统却只调用图标的轮廓,所以我们需要自己定义一下TabBar. 方法一:修改TabBarController中的TabBar 新建 CustomTabBarController 类继承自 UITabBarController,并在Storyboard中设置: 首先自定义 tabBar 的背景,在 viewDidLoad() 方法中添加: 复制代码 代码如下: // 用

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

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

  • iOS 中Swift仿微信添加提示小红点功能(无数字)

    具体内容详情如下所示: 以分类的方式实现 代码 UITabBar+Extenstion.swift fileprivate let lxfFlag: Int = 666 extension UITabBar { // MARK:- 显示小红点 func showBadgOn(index itemIndex: Int, tabbarItemNums: CGFloat = 4.0) { // 移除之前的小红点 self.removeBadgeOn(index: itemIndex) // 创建小红点

  • iOS中关于Swift UICollectionView横向分页的问题

    下面通过图文并茂的形式给大家介绍UICollectionView横向分页的问题,具体内容详情如下所示: 情况 直接看图 滚前 滚后 已经设置collectionView的isPagingEnabled为true了,可是出现了这种情况,原因就是collectionView的contentSize不够. <UICollectionView: 0x7fc565076000; frame = (0 0; 375 197); clipsToBounds = YES; gestureRecognizers

  • IOS 中NSUserDefaults读取和写入自定义对象的实现方法

    IOS 中NSUserDefaults读取和写入自定义对象的实现方法 NSUserDefaults可以存取一些短小的信息. 比如存入再读出一个字符串到NSUserDefaults: NSString *string = [NSString stringWithString @"hahaha"]; NSUserDefaults *ud = [NSUserDefaults standardUserDefaults]; [ud setObject:string forKey:@"m

  • IOS中自定义类中限制使用原生实例化方法

    IOS中自定义类中限制使用原生实例化方法 在自定义的类中,除了有系统自带的实例化方法外,还可能会有开发者自定义的实例化方法.当不想使用系统自定义方法时,而仅使用自定义的实例化方法时,可以这样做下限制. 如下示例所示: #import <UIKit/UIKit.h> @interface MYView : UIView // 限制使用系统方法进行实例化 // 方法1 - (instancetype)init UNAVAILABLE_ATTRIBUTE; // 方法2 - (instancetyp

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

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

  • iOS中使用ZBar扫描二维码自定义扫描界面功能

    之前在Android中使用过ZXing识别二维码,ZXing也有对应的iOS版本,经过了解,ZBar也是一个常用的二维码识别软件,并分别提供了iOS和Android的SDK可供使用,最终我选择了ZBar进行二维码识别,它的注释清晰,便于使用. ZBar为我们提供了两种使用方式,一种是直接调用ZBar提供的ZBarReaderViewController打开一个扫描界面,另一种方式是使用ZBar提供的可以嵌在其他视图中的ZBarReaderView,实际项目中我们更可能会使用第二种方式,这可以让我

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

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

  • iOS中Swift指触即开集成Touch ID指纹识别功能的方法

    1.前言 随着移动支付时代的到来,Touch ID 指纹验证迅速被支付宝,微信钱包普及,相信各位朋友使用后也大呼方便.今天写一篇关于指纹解锁的文章. 关于3D Touch 感兴趣的朋友可以看我前篇blog *    iOS- 指压即达,如何集成iOS9里的3D Touch http://www.jb51.net/article/108922.htm 2.指纹验证Touch ID的介绍 相比3D Touch来说,指纹验证Touch ID 的使用比较简单 主要分成两步 1.第一步当然是检测你的手机是

随机推荐