欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Swift自定義iOS中的TabBarController并為其添加動(dòng)畫

 更新時(shí)間:2016年04月18日 14:31:53   作者:老初  
這篇文章主要介紹了Swift自定義iOS中的TabBarController并為其添加動(dòng)畫的方法,即自定義TabBarController中的的TabBar并為自定義的TabBar增加動(dòng)畫效果,需要的朋友可以參考下

自定義TabBarController
有時(shí)候默認(rèn)的TabBarController不能滿足我們的開發(fā)需求,比如你想用彩色的圖標(biāo),系統(tǒng)卻只調(diào)用圖標(biāo)的輪廓,所以我們需要自己定義一下TabBar。

方法一:修改TabBarController中的TabBar
新建 CustomTabBarController 類繼承自 UITabBarController,并在Storyboard中設(shè)置:

2016418142526480.png (258×105)

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

復(fù)制代碼 代碼如下:

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

然后修改每個(gè)子ViewController中的TabBarItem,在 viewDidLoad() 方法中繼續(xù)添加:
復(fù)制代碼 代碼如下:

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

    // 聲明新的無標(biāo)題TabBarItem    
    let tabBarItem = UITabBarItem(title: nil, image: image, selectedImage: selectedImage)
    // 設(shè)置 tabBarItem 的 imageInsets 可以使圖標(biāo)居中顯示
    tabBarItem.imageInsets = UIEdgeInsetsMake(6, 0, -6, 0)

    viewController.tabBarItem = tabBarItem
}


完成!效果如下所示:

2016418142552635.jpg (320×480)

方法二:自定義TabBar
上述方法唯一的問題是,當(dāng)你想設(shè)置item的選定背景時(shí):

復(fù)制代碼 代碼如下:

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

背景圖不能鋪滿整個(gè)item,兩邊會(huì)有空隙(如果大家有更好的方法解決可以留言,謝謝),如圖:

2016418142610861.jpg (375×667)

這個(gè)時(shí)候需要自定義TabBar,首先聲明一個(gè)UIButton用來記錄當(dāng)前選中的Button:

復(fù)制代碼 代碼如下:

var selectButton: UIButton!

在viewDidLoad()方法的底部加入以下代碼:
復(fù)制代碼 代碼如下:

// 先記錄下Controller自帶的tabBar的frame
let rect = self.tabBar.frame
// 移除Controller自帶的TabBar
self.tabBar.removeFromSuperview()

// 用記錄下的frame建立一個(gè)UIView
let myView = UIView(frame: rect)
// 設(shè)置這個(gè)View的背景色
myView.backgroundColor = UIColor(patternImage: UIImage(named: "TabBarBG")!)
self.view.addSubview(myView)

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

    let button = UIButton()

    // 根據(jù)子ViewController的個(gè)數(shù)計(jì)算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)

    // 設(shè)置Button未選中時(shí)候的圖標(biāo)
    let image = UIImage(named: "TabBar\(i)")?.imageWithRenderingMode(UIImageRenderingMode.AlwaysOriginal)
    button.setImage(image, forState: UIControlState.Normal)

    // 設(shè)置Button選中時(shí)候的圖標(biāo),注意這里Button的狀態(tài)是Selected,而不是Highlighted
    let selImage = UIImage(named: "TabBar\(i)Sel")?.imageWithRenderingMode(UIImageRenderingMode.AlwaysOriginal)
    button.setImage(selImage, forState: UIControlState.Selected)

    // 設(shè)置Button未選中和選中時(shí)候的背景圖
    button.setBackgroundImage(UIImage(named: "TabBarBG"), forState: UIControlState.Normal)
    button.setBackgroundImage(UIImage(named: "TabBarBGSel"), forState: UIControlState.Selected)

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

    myView.addSubview(button)

    // 設(shè)置UIButton的標(biāo)記
    button.tag = i

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

    // 設(shè)置默認(rèn)的選中項(xiàng)
    if i == 0 {
        button.selected = true
        self.selectButton = button
    }
}
    /**
    自定義Button的點(diǎn)擊事件

    :param: button
    */
    func onClick(button: UIButton) {
        // 將上個(gè)選中按鈕設(shè)置為未選中
        self.selectButton.selected = false
        // 當(dāng)前按鈕設(shè)置為選中
        button.selected = true
        // 記錄選中按鈕
        self.selectButton = button

        // 通過UITabBarController的selectedIndex屬性設(shè)置選中了哪個(gè)UIViewController
        self.selectedIndex = button.tag
    }


最終效果如下:

2016418142810213.jpg (375×668)

給自定義TabBarController添加動(dòng)畫
如何自定義TabBarController我們?cè)谏厦嬉呀?jīng)講過,現(xiàn)在為自定義的TabBar增加動(dòng)畫效果。

直接上代碼:

復(fù)制代碼 代碼如下:

// 用來記錄當(dāng)前選中按鈕
private var currentSelectedButton = UIButton()
// 用來指示選中的背景
private var selectionIndicatorImageView: UIImageView!
// 單個(gè)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方法,動(dòng)畫效果也在這里面實(shí)現(xiàn):

復(fù)制代碼 代碼如下:

func onClick(button: UIButton) {
    // 將上個(gè)選中俺就設(shè)置為為選中
    self.currentSelectedButton.selected = false
    // 當(dāng)前按鈕設(shè)置為選中
    button.selected = true

    self.currentSelectedButton = button

    let x = CGFloat(button.tag) + 0.5

    // 為TabBarItem的背景添加動(dòng)畫
    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
}


最終效果如下:

2016418142939381.gif (372×663)

相關(guān)文章

  • Swift4使用GCD實(shí)現(xiàn)計(jì)時(shí)器

    Swift4使用GCD實(shí)現(xiàn)計(jì)時(shí)器

    這篇文章主要為大家詳細(xì)介紹了Swift4使用GCD實(shí)現(xiàn)計(jì)時(shí)器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • 在Swift中使用Cocoa的現(xiàn)有設(shè)計(jì)模式介紹

    在Swift中使用Cocoa的現(xiàn)有設(shè)計(jì)模式介紹

    這篇文章主要介紹了在Swift中使用Cocoa的現(xiàn)有設(shè)計(jì)模式介紹,Cocoa是蘋果公司為Mac OS X所創(chuàng)建的原生面向?qū)ο蟮腁PI,是Mac OS X上五大API之一,需要的朋友可以參考下
    2014-07-07
  • 簡(jiǎn)陋的swift carthage copy-frameworks 輔助腳本代碼

    簡(jiǎn)陋的swift carthage copy-frameworks 輔助腳本代碼

    下面小編就為大家分享一篇簡(jiǎn)陋的swift carthage copy-frameworks 輔助腳本代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-01-01
  • 深入理解Swift中的訪問控制關(guān)鍵字

    深入理解Swift中的訪問控制關(guān)鍵字

    這篇文章主要給大家介紹了Swift中訪問控制關(guān)鍵字的相關(guān)資料,文中介紹的非常詳細(xì),對(duì)大家具有一定的參考價(jià)值,需要的朋友們下面來一起看看吧。
    2017-03-03
  • Swift5中fileprivate與private的差別淺析

    Swift5中fileprivate與private的差別淺析

    這篇文章主要給大家介紹了關(guān)于Swift5中fileprivate與private的差別的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Swift5具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • Swift語言中的一些訪問控制設(shè)置詳解

    Swift語言中的一些訪問控制設(shè)置詳解

    這篇文章主要介紹了Swift語言中的一些訪問控制設(shè)置詳解,是Swift入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-11-11
  • Swift Access Control訪問控制與斷言詳細(xì)介紹

    Swift Access Control訪問控制與斷言詳細(xì)介紹

    這篇文章主要介紹了Swift Access Control訪問控制與斷言,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-09-09
  • 深入理解Swift語言中的閉包機(jī)制

    深入理解Swift語言中的閉包機(jī)制

    這篇文章主要介紹了Swift語言中的閉包機(jī)制,是Swift入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-11-11
  • Swift實(shí)現(xiàn)簡(jiǎn)單計(jì)算器

    Swift實(shí)現(xiàn)簡(jiǎn)單計(jì)算器

    這篇文章主要為大家詳細(xì)介紹了Swift實(shí)現(xiàn)簡(jiǎn)單計(jì)算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • Swift自定義iOS中的TabBarController并為其添加動(dòng)畫

    Swift自定義iOS中的TabBarController并為其添加動(dòng)畫

    這篇文章主要介紹了Swift自定義iOS中的TabBarController并為其添加動(dòng)畫的方法,即自定義TabBarController中的的TabBar并為自定義的TabBar增加動(dòng)畫效果,需要的朋友可以參考下
    2016-04-04

最新評(píng)論