• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >swift > Swift自定义iOS中的TabBarController并为其添加动画

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

作者:老初 字体:[增加 减小] 来源:互联网 时间:2017-05-28

老初 通过本文主要向大家介绍了tabbarcontroller,rdvtabbarcontroller,ios swift,ios swift教程,swift ios开发教程等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

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

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

2016418142526480.png (258×105)

首先自定义 tabBar 的背景,在 viewDidLoad() 方法中添加:
// 用图片
self.tabBar.backgroundImage = UIImage(named: "TabBarBG")
// 或
// 直接用颜色
self.tabBar.barTintColor = UIColor.blackColor()
</div>
然后修改每个子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
}
</div>
完成!效果如下所示:

2016418142552635.jpg (320×480)

方法二:自定义TabBar
上述方法唯一的问题是,当你想设置item的选定背景时:
self.tabBar.selectionIndicatorImage = UIImage(named: "TabBarBGSel")
</div>
背景图不能铺满整个item,两边会有空隙(如果大家有更好的方法解决可以留言,谢谢),如图:

2016418142610861.jpg (375×667)

这个时候需要自定义TabBar,首先声明一个UIButton用来记录当前选中的Button:
var selectButton: UIButton!
</div>
在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
    }
</div>
最终效果如下:

2016418142810213.jpg (375×668)

给自定义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.removeF

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • Swift自定义iOS中的TabBarController并为其添加动画
  • Swift之UITabBarController 导航控制器的自定义

相关文章

  • 2017-05-28Swift教程之类的析构详解
  • 2017-05-28Swift3.0剪切板代码拷贝及跨应用粘贴实现代码
  • 2017-05-28Swift算法实现逐字翻转字符串的方法示例
  • 2017-05-28Struts2的输入校验实例代码
  • 2017-05-28Swift中实现点击、双击、捏、旋转、拖动、划动、长按手势的类和方法介绍
  • 2017-05-22Swift 函数
  • 2017-05-28初步理解Swift中的泛型
  • 2017-05-28深入解析Swift代理模式
  • 2017-05-28Swift使用Cocoa中的数据类型教程
  • 2017-05-28window下安装和配置maven环境

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • Swift 字符(Character)
    • 深入讲解C语言编程中volatile修饰符的作用
    • Swift算法之二叉树实现的方法示例
    • Swift教程之类的析构详解
    • Swift 访问控制
    • HttpServletRequest对象方法的用法小结
    • Swift 属性
    • Swift学习笔记之元组(tuples)
    • Swift心得笔记之函数
    • 浅谈Timer和TimerTask与线程的关系

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有