亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Swift > 正文

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

2020-03-09 17:48:46
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了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



注:相關教程知識閱讀請移步到swift教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩欧美成人网| 性欧美视频videos6一9| 亚洲国产精品字幕| 91欧美精品午夜性色福利在线| 最近2019好看的中文字幕免费| 奇米成人av国产一区二区三区| 国产美女被下药99| 国产精品99免视看9| 国产成人精品免费视频| 亚洲人成在线观看| 日韩综合中文字幕| 色噜噜狠狠色综合网图区| 欧美激情中文网| 欧美精品在线视频观看| 久久九九全国免费精品观看| 91精品国产色综合| 8090理伦午夜在线电影| 日韩精品久久久久久久玫瑰园| 亚洲久久久久久久久久久| 欧美午夜激情小视频| 九九视频这里只有精品| 亚洲区中文字幕| 国产成人久久久精品一区| 欧美大成色www永久网站婷| 热久久视久久精品18亚洲精品| 亚洲电影中文字幕| 日韩av三级在线观看| 日韩精品高清视频| 日日骚av一区| 精品国内亚洲在观看18黄| 日本欧美一级片| 欧亚精品中文字幕| 欧美人与物videos| 亚洲欧美精品一区| 日韩av电影免费观看高清| 亚洲一区二区少妇| 欧美专区在线视频| 97热在线精品视频在线观看| 成人亚洲综合色就1024| 成人激情视频小说免费下载| 黑人欧美xxxx| 日韩美女毛茸茸| 国产一区二区三区视频| 久久久久久伊人| 亚洲sss综合天堂久久| 欧美刺激性大交免费视频| 亚洲国产精品国自产拍av秋霞| 欧美诱惑福利视频| 中日韩午夜理伦电影免费| 欧美日韩中文字幕在线视频| 久久亚洲综合国产精品99麻豆精品福利| 亚洲肉体裸体xxxx137| 91理论片午午论夜理片久久| 国产精品免费一区豆花| 久久国产精彩视频| 91久久在线视频| 欧美日韩精品在线观看| 欧美国产日韩一区| 欧美性猛交丰臀xxxxx网站| 亚洲香蕉伊综合在人在线视看| 日韩国产在线看| 亚洲精品一区二区三区婷婷月| 992tv在线成人免费观看| 欧美午夜精品久久久久久人妖| 日本精品视频网站| 亚洲欧美精品中文字幕在线| 97国产成人精品视频| 一本大道久久加勒比香蕉| 在线观看亚洲区| 亚洲精品xxx| 日韩av男人的天堂| 最好看的2019的中文字幕视频| 日韩电影中文字幕在线观看| 欧美老肥婆性猛交视频| 国产一区二区动漫| 中文国产亚洲喷潮| 亚洲成人久久久| 国产日韩欧美电影在线观看| www.日韩免费| 亚洲色图欧美制服丝袜另类第一页| 久久久久久香蕉网| 久久精品视频在线| 日韩大片免费观看视频播放| 欧美噜噜久久久xxx| 国产成人精品在线观看| 91超碰中文字幕久久精品| 国产99久久精品一区二区| 98精品国产高清在线xxxx天堂| 亚洲综合在线播放| 国产97人人超碰caoprom| 亚洲经典中文字幕| 精品亚洲精品福利线在观看| 国产精品久久久久久久久久久新郎| 亚洲国产精品视频在线观看| 成人国产精品一区| 亚洲视频在线免费观看| 久久视频免费在线播放| 搡老女人一区二区三区视频tv| 亚洲福利影片在线| 亚洲乱码国产乱码精品精天堂| 日本成人精品在线| 国产欧美精品xxxx另类| 亚洲人成伊人成综合网久久久| 亚洲成人网久久久| 欧美放荡办公室videos4k| 精品露脸国产偷人在视频| 91亚洲精品久久久久久久久久久久| 91色视频在线导航| 欧美视频中文字幕在线| 欧美日韩国产中文精品字幕自在自线| 欧美日韩一区免费| 久久九九亚洲综合| 国外视频精品毛片| 国产精品极品美女粉嫩高清在线| 国产精品爽爽ⅴa在线观看| 国产最新精品视频| 日韩av电影手机在线观看| 成人午夜激情免费视频| 97在线视频免费播放| 第一福利永久视频精品| 亚洲欧美日韩天堂一区二区| 欧美精品做受xxx性少妇| 欧美成人午夜视频| 亚洲欧美日本另类| 在线视频中文亚洲| 最近2019年中文视频免费在线观看| 91系列在线观看| 亚洲国产91精品在线观看| 亚洲精品国产精品国自产观看浪潮| 日本中文字幕久久看| 久久精品99久久久香蕉| 成人黄色在线播放| 97在线看免费观看视频在线观看| 亚洲国产精品va在线看黑人| 九九热这里只有精品6| 欧美视频不卡中文| 国产日韩精品在线播放| 伊人久久男人天堂| 91精品国产91久久久久久久久| 庆余年2免费日韩剧观看大牛| 97久久精品人人澡人人爽缅北| 国产精品尤物福利片在线观看| 亚洲新中文字幕| 久久99热精品| 黄色一区二区在线| 欧美日韩国产综合视频在线观看中文| 日韩国产在线播放| 成人激情黄色网| 成人免费在线网址| 亚洲国产私拍精品国模在线观看| 亚洲一区二区中文| 91香蕉电影院| 一区二区三区国产在线观看| 97视频在线播放| 98视频在线噜噜噜国产| 91色琪琪电影亚洲精品久久| 亚洲精品福利视频| 欧美高清videos高潮hd| 热久久99这里有精品| 国产91精品高潮白浆喷水| 国产精品久久久久久久久久99| 成人在线视频网站| 国产精品啪视频| 中文字幕日韩精品有码视频|