亚洲香蕉成人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不能滿足我們的開發(fā)需求,比如你想用彩色的圖標,系統(tǒng)卻只調用圖標的輪廓,所以我們需要自己定義一下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() 方法中繼續(xù)添加:
復制代碼代碼如下:

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()

    // 根據(jù)子ViewController的個數(shù)計算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的狀態(tài)是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我們在上面已經講過,現(xiàn)在為自定義的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方法,動畫效果也在這里面實現(xiàn):

 

 

復制代碼代碼如下:

 

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教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
欧洲毛片在线视频免费观看| 亚洲成人一区在线观看| 欧美激情亚洲| 乱子伦一区二区三区| 国产精品久久福利| 福利网址在线观看| 日本精品国语自产拍在线观看| 97超级碰碰人国产在线观看| 国产亚洲精品高潮| 日本久久一二三四| 一区二区精品国产| 国产日韩欧美二区| 综合中文字幕亚洲| 国产主播精品在线| 亚洲精品久久久久久久蜜桃| 国产精品福利电影一区二区三区四区| 66m—66摸成人免费视频| 1024免费在线视频| 日本成人黄色片| 人妖精品videosex性欧美| 日韩av电影在线播放| 久久影院中文字幕| 欧美人妻精品一区二区免费看| 久久久极品av| 中文欧美日韩| free性欧美1819hd| 久久一区二区三区电影| 福利视频一二区| 黄色www在线观看| 在线性视频日韩欧美| 国产免费嫩草影院| 亚洲2区在线| 成人性做爰aaa片免费看不忠| 白丝美女让我捅| 欧美极品另类| 91香蕉国产在线观看软件| 青青草国产免费一区二区下载| 国产麻豆精品入口在线观看| 亚洲人午夜精品| 久草免费在线色站| 欧美区亚洲区| 中文字幕一区二区三区人妻不卡| 国产日韩中文字幕| 国产又粗又黄又猛| 国产寡妇亲子伦一区二区三区四区| www.亚洲在线| 成人黄色大片网站| 丰满少妇久久久| 奇米影视888狠狠狠| 亚洲精品视频99| 麻豆成人av| 国产卡1卡2卡三卡在线| 日韩免费观看av| 99久久久国产| 欧美日韩高清不卡| 精品国产一区二区三区四| 国产富婆一级全黄大片| 不卡的在线视频| a级国产乱理论片在线观看99| 亚洲午夜精品一区二区国产| 国产成人一区二区三区影院在线| 欧美一区二区三区久久综合| 亚洲一区二区三区乱码aⅴ蜜桃女| 国产精品色婷婷在线观看| 成人影院天天5g天天爽无毒影院| 91成人福利在线| 亚洲午夜视频在线观看| 激情久久久久久久久久久久久久久久| 国产原创视频在线观看| 婷婷伊人综合中文字幕| 精品无码久久久久久久久| 午夜精品久久99蜜桃的功能介绍| 蜜臀av午夜一区二区三区| 最近高清中文在线字幕在线观看| 亚洲国产精品t66y| aa在线观看视频| 男人的天堂一区| 国产专区在线播放| 狠狠躁夜夜躁久久躁别揉| 国产一区二区导航在线播放| 亚洲电影影音先锋| 国产又粗又猛又爽又黄的| 大香一本蕉伊线亚洲网| 欧美成人ⅴideosxxxxx| 国产精品入口| 日韩av免费播放| 美女久久久久久久久久久| 亚洲精品97久久中文字幕| 久久九九有精品国产23| 日本不卡在线播放| 粉嫩av一区二区三区粉嫩| 日韩精品一区二区三区在线观看| 99在线影院| 爱草在线视频| 国产精久久一区二区| 国产精品福利一区二区三区| 制服丝袜在线第一页| 亚洲欧美激情视频在线观看一区二区三区| 穿情趣内衣被c到高潮视频| 国产精品入口夜色视频大尺度| 国产女主播喷水高潮网红在线| 黑人巨大精品欧美一区二区| 一区二区久久久| 波多野结衣在线网址| 美女久久久久久久久| gogo亚洲高清大胆美女人体| 在线看一级片| 尤物网址在线观看| 久久久久网站| 欧美日本视频一区| 男生裸体视频网站| 欧美猛交xxxxx| 91亚洲视频| 亚洲国产综合久久| 亚洲av色香蕉一区二区三区| 国产成人午夜电影网| 日本vs亚洲vs韩国一区三区二区| 国产成人羞羞电影网站在线观看| 国产精品波多野结衣| 呦呦在线视频| 精品视频二区三区| 国产欧美综合一区| 国产精品高潮呻吟久久久| 91色视频在线导航| 亚洲调教欧美在线| 欧美做爰猛烈大尺度视频| 97视频在线| 可以免费观看av毛片| 欧美不卡在线观看| 国产视频一区二| 日本一区二区视频在线观看| 激情av中文字幕| 亚洲一区二区三区小说| 不卡视频一二三四| 神马午夜在线观看| 好吊妞www.84com只有这里才有精品| 久久99精品波多结衣一区| 成人黄色av免费在线观看| 一级二级黄色片| 2018日日夜夜| 日韩乱码人妻无码中文字幕久久| 无码人妻一区二区三区精品视频| 亚洲深夜激情| 免费日韩在线视频| 精品国产午夜肉伦伦影院| 久久精品99久久无色码中文字幕| 99亚洲男女激情在线观看| 色哟哟亚洲精品一区二区| 国产美女精品| 好操啊在线观看免费视频| 国产jizzjizz一区二区| 国产精品麻豆va在线播放| 亚洲伊人av| 精品国产91久久久久久久妲己| 亚洲国产精品一| 嗯~啊~轻一点视频日本在线观看| 在线观看欧美精品| 欧美尤物一区| 欧美性xxxx巨大黑人猛| 国产51人人成人人人人爽色哟哟| 欧美日韩1区2区| 亚洲精品福利在线| 亚洲理论电影| 日韩一区二区三区精品| gogogo影视剧免费观看在线观看| 亚洲丶国产丶欧美一区二区三区| 丁香花在线高清完整版视频| 激情综合五月网| 亚洲人在线观看视频| 欧美影视一区| 婷婷激情五月综合| 亚洲黄色a级片| 免费涩涩18网站入口| aaa国产一区| 狠狠鲁狠狠操| 超碰成人在线免费观看| 欧美日韩国产精品| 亚洲色图27p| 中文字幕一区二区三三| 国产乱子伦视频一区二区三区| 亚洲精华液一区二区三区| 亚洲九九爱视频| 久久精品一偷一偷国产| 自拍视频一区二区三区| 北条麻妃国产九九九精品小说| 国产专区在线| 国产午夜亚洲精品理论片色戒| 直接在线观看的三级网址| 久久99精品国产91久久来源| japanesexxxxfree在线观看| 性鲍视频在线观看| 激情国产在线| 成年人在线观看视频| 国产同性人妖ts口直男| www一区二区三区| aa级大片欧美| 最新在线中文字幕| 亚洲 国产 欧美 日韩| 亚洲视频在线一区二区| 亚洲女人天堂色在线7777| 欧美日韩美女| 国产精品扒开腿爽爽爽视频| 在线日韩一区| 国产黄色免费看| 国产不卡精品视频| 91人成网站www| 三上悠亚在线观看| 亚洲第一区第二区第三区| 9l国产精品久久久久麻豆| 国产绳艺sm调教室论坛| 北岛玲精品视频在线观看| 日韩av一级片| 亚洲精品中文字幕99999| 中文在线免费二区三区| 欧美高清另类hdvideosexjaⅴ| 777午夜精品电影免费看| 91精品国产福利在线观看麻豆| 懂色中文一区二区三区在线视频| 日韩在线一二三| 久久久久久av无码免费网站下载| jizzjizzjizzjizz| 亚洲综合在线免费观看| 亚洲网站视频福利| 91丨porny丨探花| 久久精品亚洲精品| 日韩视频在线观看| 日韩美女在线视频| 欧美1级日本1级| 国产精品亚洲四区在线观看| 欧美日韩精品一区二区在线播放| 图片区小说区区亚洲影院| 国产专区一区二区三区| 老牛影视精品| 欧洲成人免费视频| 欧美成人性色生活仑片| 亚洲一区日韩在线| 2222www色视频在线观看| 色吊丝一区二区| 在线看片福利| 日韩在线欧美在线国产在线| 黄页网站在线看| 中文在线日韩| 国产激情片在线观看| 免费看a级黄色片| 色综合一区二区| 国产又色又爽又黄的| 找av导航入口| 四虎国产精品成人永久免费影视| eeuss国产一区二区三区四区| 91理论电影在线观看| 白白色亚洲国产精品| 成人18免费入口| 精品久久久在线观看| 精品国产免费久久| 国产精品欧美久久久久无广告| 欧美男人的天堂一二区| 香蕉免费毛片视频| 色噜噜日韩精品欧美一区二区| h视频在线看| 伦伦影院午夜日韩欧美限制| 精品黑人一区二区三区国语馆| xxxx一级片| 91精品久久久久久久| 国产精品刘玥久久一区| 国产人与禽zoz0性伦| 国产精品嫩草av| 深夜福利av你懂的| www.91av.cn| 老司机亚洲精品| 欧美人与性禽动交精品| 午夜免费一区二区| 亚洲成人黄色在线观看| 天堂在线观看| 91精品国产成人观看| 欧美日韩免费一区二区三区| 欧美videos巨大粗暴| 亚洲精品动态| 伊人电影在线观看| 狠狠色丁香久久综合频道| 国产精品69页| 香蕉视频网站在线播放| 成人在线视频网站| 欧美日韩综合在线| 日本午夜精品久久久久| 亚洲第一天堂在线观看| 国产极品人妖在线观看| 杨幂一区二区三区免费看视频| 欧美日韩国产综合在线| 日韩有码av| 国产精品美女久久久久av爽李琼| 在线免费观看黄色片| 成人午夜视频一区二区播放| 国产在线一区不卡| 18video性欧美19sex高清| 国产精品久久久久av免费| 中文字幕第31页| 日韩黄色三级在线观看| 羞羞网www| 中文字幕免费高清电视剧网站在线观看| 成人公开免费视频| 亚洲国产91精品在线观看| 亚洲人成免费| 国产精品高潮久久| 椎名由奈jux491在线播放| 婷婷综合激情网| 深夜福利日韩在线看| 日本调教视频在线观看| 99鲁鲁精品一区二区三区| 在线看的片片片免费| 亚洲精品v日韩精品| 国产精品久久久999| 久久国产免费看| 亚洲精品国精品久久99热| 蜜臀av在线观看| 欧美va亚洲va| 精品国产91乱高清在线观看| 国新精品乱码一区二区三区18| 久久99久久精品| 日本中文字幕精品| 自拍偷拍欧美亚洲| 亚洲影院免费观看| 亚洲性线免费观看视频成熟| 成人性生交大片免费看网站| 黄色录像免费观看| 亚洲一级网站| 天堂8在线天堂资源bt| 国产成人精品电影| 久久久久久久久久久久久久久久久久久久|