詳解iOS App中UiTabBarController組件的基本用法
UiTabBarController這個(gè)控制器絕對是項(xiàng)目架構(gòu)時(shí)做常用的一個(gè)控件。
我們大致看下控件的效果,我們就知道為什么說他常見了。
這就是最簡單的一個(gè)雛形,想必現(xiàn)在基本70%的應(yīng)用界面結(jié)構(gòu)都會是這樣的。
在Android中我們以ActivityGroup或是現(xiàn)在的fragment來實(shí)現(xiàn),一個(gè)容器中包含多個(gè)子控制器。
下面我們還是以建立xib文件的形式來實(shí)現(xiàn)一個(gè)這樣的整體布局的例子。
當(dāng)然在 xcode中我們會發(fā)現(xiàn)其實(shí)直接有這么一個(gè)模板了
但是直接使用模板后會發(fā)現(xiàn)是直接在代碼里實(shí)現(xiàn)了子布局得添加,由于我們不熟練,對于item,tabbar什么的圖片文字自定義,一下子找不到代碼里的api,
可能說用xib來實(shí)現(xiàn)可以看得比較明了。
據(jù)說以前直接有base_window模板,不過沒關(guān)系,模板只是為了給我快速建立一個(gè)應(yīng)用而已,我們這邊手動的從最基礎(chǔ)得開始
1.首先建立一個(gè)Empty Application
2.建立完后我們自定頂一個(gè)MainWindow.xib(當(dāng)然,這個(gè)名字可以隨意取,但是按照規(guī)范以及一種默認(rèn)留下來的習(xí)慣),作為應(yīng)用啟動時(shí)加載的首個(gè)nib文件,
在新建xib文件你可以選擇window也可以是empt什么,其實(shí)都差不多,我們這邊選window模板得xib文件
3.然后我們其實(shí)是要把XXXAppdelegate和這個(gè)xib文件連接起來。因此把.h文件定義成這樣:
#import <UIKit/UIKit.h>
@interface NonoAppDelegate : UIResponder <UIApplicationDelegate>
{
UIWindow *window;
UITabBarController *tabTarController;
}
@property (retain, nonatomic) IBOutlet UIWindow *window;//該控件模板生成是不帶IBOutlet的,但是我們?yōu)榱藊ib文件布局得統(tǒng)一性,將其也作為一個(gè)輸出口和在Mainxib中連接起來可以
@property (retain, nonatomic) IBOutlet UITabBarController *tabTarController;
@end
4.然后我們來大致設(shè)計(jì)我們的xib文件,打開MainWindow.xib文件,我們大致看到視圖元素,一個(gè)是文件擁有者Filesowner,然后是reponder(這個(gè)一直沒
怎么用到,具體干嗎使的還不是明確),然后最主要得是Object這個(gè)標(biāo)簽下得元素,此時(shí)就一個(gè)window。
首先我們要將文件擁有者這個(gè)類改成UIApplication,點(diǎn)擊File'sOwner標(biāo)簽后在右側(cè)的屬性欄選擇Indentity inspector,看到此時(shí)customclass是NSobject,
我們改成UIApplication,改完后會發(fā)現(xiàn)File'sOwner得Outlets用了一個(gè)delegate的輸出口東東,看過上一篇關(guān)于outlets和reference outlet我們就知道,
這個(gè)東東等會可以指向一個(gè)實(shí)例對象什么的。
5.好了,那么我們在object下的添加一個(gè)delegate的對象,操作很簡單,在右側(cè)控件組中
拖一個(gè)這樣得對象到xib下得Object標(biāo)簽下,
然后我們來自定這個(gè)對象,根據(jù)上面所知,我們大致可以知道我們需要一個(gè)類似于delegate類得對象,對了
我們的AppDelegate不就剛好是這么一個(gè)東西么。于是很自然的,選中這個(gè)object然后在右側(cè)屬性欄將custom class設(shè)置成NonoAppDelagate。
然后點(diǎn)擊File's Owner將其輸出口delegate和我們剛放上去的NonoAppdelagate鏈接起來。
6.設(shè)置完以上后,我們可以點(diǎn)擊Object下得XXXAppDelegate,然后看右邊屬性欄的 Outlets,對了,我們剛在該文件得.h中申明過兩個(gè)輸出口,此刻我們是
要創(chuàng)建兩個(gè)這樣的對象然后將其連接起來。window這時(shí)已經(jīng)有了,還少個(gè)UITabBarController。那么我們從右邊拖個(gè)過來咯
然后輸出口和對象鏈接起來。
此刻,最基本的tabbarcontroller布局框架就ok了,此刻的xib文件如下圖
然后我們打開AppDelegate.m進(jìn)行實(shí)現(xiàn)和修改
#import "NonoAppDelegate.h"
@implementation NonoAppDelegate
@synthesize window ;
@synthesize tabTarController ;
- (void)dealloc
{
[self.window release];
[self.tabTarController release];
[super dealloc];
}
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
// self.window = [[[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]] autorelease];
// Override point for customization after application launch.
self.window.backgroundColor = [UIColor whiteColor];
self.window.rootViewController = self.tabTarController;
[self.window makeKeyAndVisible];
return YES;
}
恩,就是這么簡單。
理論上我們現(xiàn)在啟動模擬器后程序可以啟動了。
但是卻發(fā)現(xiàn)起來后是空白的。
我們從應(yīng)用的main.m中看
int main(int argc, char *argv[])
{
@autoreleasepool {
return UIApplicationMain(argc, argv, nil, NSStringFromClass([NonoAppDelegate class]));
}
}
然后應(yīng)用到了我們自定義得delegate類了,然后發(fā)現(xiàn)一個(gè)問題,按照這個(gè)流程,我們MainWindow.xib文件貌似沒加載進(jìn)來啊.
這就對了,以前我們定義個(gè)controller的xib文件后都會有initWithNibName,而對于UIApplication類型的xib文件(其實(shí)局勢整個(gè)應(yīng)用最先要啟動的一個(gè)類),
據(jù)說是這樣的加載
這個(gè)具體你可以去看上一篇中提到過ios應(yīng)用啟動內(nèi)容,有個(gè)不錯(cuò)得博文給了很好得一個(gè)解釋。
此刻我們可以將main.h代碼稍微修改下
#import <UIKit/UIKit.h>
#import "NonoAppDelegate.h"
int main(int argc, char *argv[])
{
@autoreleasepool {
return UIApplicationMain(argc, argv, nil, nil);
}
}
原本第四個(gè)參數(shù)是指定AppDelegate,但是我們知道,在加載MainWindow.xib實(shí)例化里面一個(gè)delegate對象時(shí),我們已經(jīng)鏈接了AppDelegate類了,
感覺如果第四個(gè)參數(shù)指定后,這個(gè)類像是被實(shí)例化了2次,更多具體內(nèi)容還是參考上面提到那個(gè)博客去看吧。
7.好了。最基本得tabbar界面完成,接下來是往里面添加子控制器。
首先我們來熟悉下UITabBarController這個(gè)控件:
從界面我們可以推測出,該控件里面大致上有什么東西:
1>.應(yīng)該有個(gè)類似于管理一組子控件的東西吧。
2>界面下面切換得切換條吧 tabBar
3>當(dāng)然還回發(fā)現(xiàn)有個(gè)delegate這樣得東西,就是代理對象么。
當(dāng)然上面是在代碼中,我們得到這些屬性,做相應(yīng)得操作。
在xib文件里可能說看上去會比較直觀
1>Tab bar里面放的是由一個(gè)或是多個(gè)TabbarItem組成的數(shù)組,每個(gè)itm對應(yīng)一個(gè)ViewController。
2>下面的 First,Second等等就是每個(gè)Item對應(yīng) 的Controller,這里也要注意一點(diǎn),默認(rèn)的我們我們拖進(jìn)去一個(gè)
TabBarItem,一般我們會設(shè)置對應(yīng)得XXXcontroller.xib文件
之后還需將Custom class改成對應(yīng)XXXXController類,因?yàn)槟J(rèn)的類是UIViewController。這會在應(yīng)用啟動后報(bào)錯(cuò)的。
3>tabbarItem中可以設(shè)置title ,系統(tǒng)默認(rèn)的幾種圖標(biāo),還有是自定義圖標(biāo),以及badgeValue,就是上面標(biāo)簽上每個(gè)紅色的值,
這個(gè)比Android上先見之明多了呵呵。
4> 當(dāng)?shù)撞康陌粹o超過5個(gè)時(shí),系統(tǒng)會自動增加一個(gè)more按鈕,點(diǎn)擊more后,剩余的按鈕會被顯示出來。
8.UITabbarController左右滑動切換標(biāo)簽頁
每個(gè)Tabbar ViewController都要添加如下代碼,建議在基類中添加:
ViewDidLoad
UISwipeGestureRecognizer *swipeLeft = [[UISwipeGestureRecognizer alloc] initWithTarget:self action:@selector(tappedRightButton:)];
[swipeLeft setDirection:UISwipeGestureRecognizerDirectionLeft];
[self.view addGestureRecognizer:swipeLeft];
UISwipeGestureRecognizer *swipeRight = [[UISwipeGestureRecognizer alloc] initWithTarget:self action:@selector(tappedLeftButton:)];
[swipeRight setDirection:UISwipeGestureRecognizerDirectionRight];
[self.view addGestureRecognizer:swipeRight];
再添加2個(gè)函數(shù),包含切換動畫效果:
- (IBAction) tappedRightButton:(id)sender
{
NSUInteger selectedIndex = [self.tabBarController selectedIndex];
NSArray *aryViewController = self.tabBarController.viewControllers;
if (selectedIndex < aryViewController.count - 1) {
UIView *fromView = [self.tabBarController.selectedViewController view];
UIView *toView = [[self.tabBarController.viewControllers objectAtIndex:selectedIndex + 1] view];
[UIView transitionFromView:fromView toView:toView duration:0.5f options:UIViewAnimationOptionTransitionFlipFromRight completion:^(BOOL finished) {
if (finished) {
[self.tabBarController setSelectedIndex:selectedIndex + 1];
}
}];
}
}
- (IBAction) tappedLeftButton:(id)sender
{
NSUInteger selectedIndex = [self.tabBarController selectedIndex];
if (selectedIndex > 0) {
UIView *fromView = [self.tabBarController.selectedViewController view];
UIView *toView = [[self.tabBarController.viewControllers objectAtIndex:selectedIndex - 1] view];
[UIView transitionFromView:fromView toView:toView duration:0.5f options:UIViewAnimationOptionTransitionFlipFromLeft completion:^(BOOL finished) {
if (finished) {
[self.tabBarController setSelectedIndex:selectedIndex - 1];
}
}];
}
}
相關(guān)文章
iOS開發(fā)中UIDatePicker控件的使用方法簡介
這篇文章主要介紹了iOS開發(fā)中UIDatePicker控件的使用方法簡介,用來處理各種時(shí)間日期的選擇,需要的朋友可以參考下2015-11-11iOS實(shí)現(xiàn)圖片壓縮的兩種方法及圖片壓縮上傳功能
ios 圖片壓縮有兩種方法,分別是,壓縮圖片質(zhì)量(Quality),壓縮圖片尺寸(Size),非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下2017-01-01實(shí)例講解iOS音樂播放器DOUAudioStreamer用法
本篇文章給大家通過實(shí)例講解了iOS音樂播放器DOUAudioStreamer用法以及分享了實(shí)例代碼,一起學(xué)習(xí)參考下吧。2017-12-12Xcode中iOS應(yīng)用開發(fā)的一般項(xiàng)目目錄結(jié)構(gòu)和流程簡介
這篇文章主要介紹了Xcode中iOS應(yīng)用開發(fā)的一般項(xiàng)目目錄結(jié)構(gòu)和流程簡介,包括項(xiàng)目所需的一些平臺路徑如模擬器路徑等的介紹,需要的朋友可以參考下2016-02-02