28-Swift之UITabBarController

一寸宵、UITabBarController 的介紹

UITabBarController 是App開發(fā)中一個(gè)重要的控制器。它可以同時(shí)管理多個(gè)控制器。管理著這些控制器間的切換。

二茅姜、UITabBarController 的屬性和方法介紹

1闪朱、創(chuàng)建需要管理的控制器&添加到管理器中

/**
 創(chuàng)建控制器
 */
let vcNameArray:NSArray  = ["FirstViewController","SecondViewController"]
/**
 獲取創(chuàng)建的控制器
 */
let VcsArray = self.createVcs(vcArray: vcNameArray)
/**
 添加到當(dāng)前控制器上
 */
self.viewControllers = (VcsArray as! [UIViewController])

createVcs 函數(shù)的實(shí)現(xiàn)

// TODO: 創(chuàng)建控制器
func createVcs(vcArray:NSArray) -> NSArray {
    let vcArrays = NSMutableArray.init(capacity: 0)
    for temp in vcArray {
        let tempStr  = temp as! String
        let NWClass  = NSClassFromString("UITabBarController."+tempStr ) as! UIViewController.Type
        let NwVCSwift = NWClass.init()
        let NavVc = UINavigationController.init(rootViewController: NwVCSwift)
        vcArrays.add(NavVc)
    }
    return vcArrays
}

2月匣、創(chuàng)建TabBar的Items

/**
 我們要?jiǎng)?chuàng)建items
 */
let titles:Array = ["首頁(yè)","分類"]
let images:Array<UIImage> = [UIImage.init(named: "1")!,UIImage.init(named: "2")!]
let imagesSelecd:Array<UIImage> = [UIImage.init(named: "btnlccp")!,UIImage.init(named: "x2")!,UIImage.init(named: "2")!]
self.ctreateItems(images:images, titles: titles,imageSelecd: imagesSelecd)

ctreateItems 函數(shù)的實(shí)現(xiàn)

// TODO: 創(chuàng)建Items
func ctreateItems(images:Array<UIImage>,titles:Array<String>,imageSelecd:Array<UIImage>) -> Void {
    for i in 0  ..< (self.tabBar.items?.count)!  {
        let nwItem = self.tabBar.items?[i];
        /**
         設(shè)置tabbar 選中和未選中的圖片
         */
        nwItem?.image = images[i].withRenderingMode(.alwaysOriginal)
        nwItem?.selectedImage = imageSelecd[i].withRenderingMode(.alwaysOriginal)
        /**
         設(shè)置選擇的文字顏色
         */
        nwItem?.title = titles[i]
        UITabBarItem.appearance().setTitleTextAttributes([NSFontAttributeName:UIFont.systemFont(ofSize: 14),NSForegroundColorAttributeName:UIColor.black], for: UIControlState.normal)
        UITabBarItem.appearance().setTitleTextAttributes([NSForegroundColorAttributeName:UIColor.red,NSFontAttributeName:UIFont.systemFont(ofSize: 14)], for: UIControlState.selected)
    }

}

3、 設(shè)置默認(rèn)選擇的控制器

/**
 設(shè)置默認(rèn)設(shè)置第幾個(gè)
 */
self.selectedIndex = 1

4奋姿、UITabBarController 的代理和代理事件

/**
 其代理事件
 */
self.delegate = (self as UITabBarControllerDelegate);

代理方法介紹

//DOTO: UITabBarControllerDelegate 的代理事件
/**
 tabbar 切換控制器的時(shí)候被調(diào)用
 */
func tabBarController(_ tabBarController: UITabBarController, didSelect viewController: UIViewController) {
    print(viewController)
}
/**
 這是控制tabbar 是否可以選擇控制器
 true 是可以選擇
 false 是不可以選擇
 */
func tabBarController(_ tabBarController: UITabBarController, shouldSelect viewController: UIViewController) -> Bool {
     /**
      先獲取當(dāng)前UITabBarController的子對(duì)象
      */
    let childsVc = tabBarController.viewControllers! as NSArray
    let selecdIndex : Int = childsVc.index(of: viewController)
    if selecdIndex == 1 {
         return false
    }
     return true
}

/**
 這是TabBar 的 items 個(gè)數(shù)大于五個(gè)的時(shí)候锄开,第五個(gè)就變成MORE ,
 這就是當(dāng)開始編輯tabbar的時(shí)候称诗,調(diào)整tabbar的位置時(shí)萍悴,調(diào)用次函數(shù)
 */
func tabBarController(_ tabBarController: UITabBarController, willBeginCustomizing viewControllers: [UIViewController]) {
    print(viewControllers)
}

/**
 這是 TabBar ,在MORE的時(shí)候寓免,編輯下癣诱,在編輯將要完成的時(shí)候會(huì)調(diào)用該函數(shù)
 */
func tabBarController(_ tabBarController: UITabBarController, willEndCustomizing viewControllers: [UIViewController], changed: Bool) {
     
}
/**
 這是 TabBar 結(jié)束編輯的時(shí)候調(diào)用該函數(shù)
 */
func tabBarController(_ tabBarController: UITabBarController, didEndCustomizing viewControllers: [UIViewController], changed: Bool) {
    print(changed)
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市袜香,隨后出現(xiàn)的幾起案子撕予,更是在濱河造成了極大的恐慌,老刑警劉巖蜈首,帶你破解...
    沈念sama閱讀 216,692評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件实抡,死亡現(xiàn)場(chǎng)離奇詭異欠母,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)吆寨,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,482評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門赏淌,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人啄清,你說我怎么就攤上這事六水。” “怎么了盒延?”我有些...
    開封第一講書人閱讀 162,995評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵缩擂,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我添寺,道長(zhǎng)胯盯,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,223評(píng)論 1 292
  • 正文 為了忘掉前任计露,我火速辦了婚禮博脑,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘票罐。我一直安慰自己叉趣,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,245評(píng)論 6 388
  • 文/花漫 我一把揭開白布该押。 她就那樣靜靜地躺著疗杉,像睡著了一般。 火紅的嫁衣襯著肌膚如雪蚕礼。 梳的紋絲不亂的頭發(fā)上烟具,一...
    開封第一講書人閱讀 51,208評(píng)論 1 299
  • 那天,我揣著相機(jī)與錄音奠蹬,去河邊找鬼朝聋。 笑死,一個(gè)胖子當(dāng)著我的面吹牛囤躁,可吹牛的內(nèi)容都是我干的冀痕。 我是一名探鬼主播,決...
    沈念sama閱讀 40,091評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼狸演,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼言蛇!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起宵距,我...
    開封第一講書人閱讀 38,929評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤腊尚,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后消玄,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體跟伏,經(jīng)...
    沈念sama閱讀 45,346評(píng)論 1 311
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡丢胚,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,570評(píng)論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了受扳。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片携龟。...
    茶點(diǎn)故事閱讀 39,739評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖勘高,靈堂內(nèi)的尸體忽然破棺而出峡蟋,到底是詐尸還是另有隱情,我是刑警寧澤华望,帶...
    沈念sama閱讀 35,437評(píng)論 5 344
  • 正文 年R本政府宣布蕊蝗,位于F島的核電站,受9級(jí)特大地震影響赖舟,放射性物質(zhì)發(fā)生泄漏蓬戚。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,037評(píng)論 3 326
  • 文/蒙蒙 一宾抓、第九天 我趴在偏房一處隱蔽的房頂上張望子漩。 院中可真熱鬧,春花似錦石洗、人聲如沸幢泼。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,677評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽缕棵。三九已至,卻和暖如春涉兽,著一層夾襖步出監(jiān)牢的瞬間招驴,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,833評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工花椭, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留忽匈,地道東北人房午。 一個(gè)月前我還...
    沈念sama閱讀 47,760評(píng)論 2 369
  • 正文 我出身青樓矿辽,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親郭厌。 傳聞我的和親對(duì)象是個(gè)殘疾皇子袋倔,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,647評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫(kù)、插件折柠、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,095評(píng)論 4 62
  • 2003出品的《金粉世家》被很多人堪稱是現(xiàn)代版的紅樓夢(mèng)宾娜,那個(gè)金碧輝煌的金家大府就如同賈府。 十四年前的這部戲當(dāng)初也...
    憶先生閱讀 1,140評(píng)論 3 8
  • 已經(jīng)有很長(zhǎng)時(shí)間嚣艇,沒有在簡(jiǎn)書上寫字了。這些時(shí)間华弓,我變成了一個(gè)只知道追劇的綜藝咖:上下班的地鐵里公交上食零,就算被擠來擠去...
    四代法尼亞閱讀 267評(píng)論 3 5
  • 人們理想的高配版生活是:一邊享受吃喝玩樂的喜悅,一邊還有入賬不斷的驚喜寂屏。而現(xiàn)實(shí)是赤裸裸的標(biāo)配版:兩頭皆空贰谣。 ...
    大流芒閱讀 350評(píng)論 2 1