国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Swift - Swift自定義iOS中的TabBarController并為其添加動畫

Swift自定義iOS中的TabBarController并為其添加動畫

2020-12-25 16:02老初 Swift

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

自定義TabBarController
有時候默認的TabBarController不能滿足我們的開發需求,比如你想用彩色的圖標,系統卻只調用圖標的輪廓,所以我們需要自己定義一下TabBar。

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

Swift自定義iOS中的TabBarController并為其添加動畫

首先自定義 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
}


完成!效果如下所示:

Swift自定義iOS中的TabBarController并為其添加動畫

 

方法二:自定義TabBar
上述方法唯一的問題是,當你想設置item的選定背景時:

復制代碼 代碼如下:

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


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

Swift自定義iOS中的TabBarController并為其添加動畫

這個時候需要自定義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
    }


最終效果如下:

Swift自定義iOS中的TabBarController并為其添加動畫

 

給自定義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
}

 


最終效果如下:

Swift自定義iOS中的TabBarController并為其添加動畫

延伸 · 閱讀

精彩推薦
  • SwiftSwift能代替Objective-C嗎?

    Swift能代替Objective-C嗎?

    這是我在網上上看到的答案,復制粘貼過來和大家分享一下,因為我和很多人一樣很關心Swift的出現對Mac開發的影響和對Objective-C的影響。...

    Swift教程網4412020-12-16
  • Swiftmac git xcrun error active developer path 錯誤

    mac git xcrun error active developer path 錯誤

    本文主要是講訴了如何解決在mac下使用git;xcode4.6的環境時,出現了錯誤(mac git xcrun error active developer path)的解決辦法,希望對大家有所幫助...

    Swift教程網2232020-12-16
  • SwiftSwift實現多個TableView側滑與切換效果

    Swift實現多個TableView側滑與切換效果

    這篇文章主要為大家詳細介紹了Swift實現多個TableView側滑與切換效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    乞力馬扎羅的雪雪5822021-01-08
  • SwiftSwift教程之基礎數據類型詳解

    Swift教程之基礎數據類型詳解

    這篇文章主要介紹了Swift教程之基礎數據類型詳解,本文詳細講解了Swift中的基本數據類型和基本語法,例如常量和變量、注釋、分號、整數、數值類型轉換等...

    Swift教程網5162020-12-18
  • SwiftSwift使用CollectionView實現廣告欄滑動效果

    Swift使用CollectionView實現廣告欄滑動效果

    這篇文章主要為大家詳細介紹了Swift使用CollectionView實現廣告欄滑動效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    Stevin的技術博客12372021-01-13
  • Swiftswift where與匹配模式的實例詳解

    swift where與匹配模式的實例詳解

    這篇文章主要介紹了swift where與匹配模式的實例詳解的相關資料,這里附有簡單的示例代碼,講的比較清楚,需要的朋友可以參考下...

    追到夢的魔術師14382021-01-06
  • SwiftSwift中轉義閉包示例詳解

    Swift中轉義閉包示例詳解

    在Swift 中的閉包類似于結構塊,并可以在任何地方調用,下面這篇文章主要給大家介紹了關于Swift中轉義閉包的相關資料,需要的朋友可以參考下...

    小小小_小朋友11412021-12-26
  • SwiftSwift的74個常用內置函數介紹

    Swift的74個常用內置函數介紹

    這篇文章主要介紹了Swift的74個常用內置函數介紹,這篇文章列舉出了所有的Swift庫函數,內置函數是指無需引入任何模塊即可以直接使用的函數,需要的朋友可...

    Swift教程網5802020-12-19
主站蜘蛛池模板: 龙珠z国语291集普通话 | 欧美激情一区二区 | 中文字幕一区在线 | 日韩视频在线观看一区 | 午夜精品久久久久久久久久久久 | 亚洲精品成人在线 | 日韩精品一区二区三区在线 | 日本在线视频一区二区三区 | 伊人五月 | 国产精品亚洲精品 | 色爱综合网 | 日韩av免费在线播放 | 黄色一区二区三区 | 狠狠综合| 黄色高清网站 | 一区视频 | 亚洲精品一区在线观看 | 一级毛片免费观看久 | 精品一区二区av | 免费三片在线观看网站 | 日韩午夜影院 | 美女久久久久 | 精品中文字幕一区 | 日韩成人免费av | 自拍视频在线观看 | 欧美影 | 亚洲福利一区二区 | 久久99精品久久久久久噜噜 | 午夜视频网 | 日本黄色免费大片 | 亚洲国产一区二区在线观看 | 日韩毛片免费在线观看 | 97国产精品视频 | 欧美国产精品一区二区三区 | 久久九九国产精品 | 亚洲精品91 | 亚洲视频在线观看网址 | 能看的av网站 | 午夜精品久久久久久久久久久久久 | 亚洲欧美日韩精品 | 欧美视频一区二区三区 |