真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

iOS狀態(tài)欄、導(dǎo)航欄的示例分析-創(chuàng)新互聯(lián)

小編給大家分享一下iOS狀態(tài)欄、導(dǎo)航欄的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

溫嶺ssl適用于網(wǎng)站、小程序/APP、API接口等需要進行數(shù)據(jù)傳輸應(yīng)用場景,ssl證書未來市場廣闊!成為成都創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:028-86922220(備注:SSL證書合作)期待與您的合作!

前言

IOS的界面分為狀態(tài)欄和導(dǎo)航欄,如下圖所示:

iOS狀態(tài)欄、導(dǎo)航欄的示例分析

狀態(tài)欄與導(dǎo)航欄的位置如上圖,我們可以通過[UIApplication sharedApplication].statusBarFrame.size獲取狀態(tài)欄的size(一般沒有劉海時的高度為20,有劉海時的高度為44)。

通過self.navigationController.navigationBar.frame.size獲取導(dǎo)航欄的size(一般高度為44,大標(biāo)題時高度為xyz,當(dāng)然也可以通過自定義來改變導(dǎo)航欄樣式)。

***ps:***在我們通過[nav.navigationBar setBarTintColor:[UIColor lightGrayColor]];來設(shè)置導(dǎo)航欄顏色時,將導(dǎo)致導(dǎo)航欄和狀態(tài)欄背景色均變?yōu)闇\灰色。

1. 狀態(tài)欄內(nèi)容是否高亮

狀態(tài)欄內(nèi)容包括信號、時間、電量等,只有兩種顏色樣式(黑或白)。iOS開發(fā)過程中提供修改狀態(tài)欄內(nèi)容顏色樣式的方法:

在代碼中設(shè)置狀態(tài)欄內(nèi)容顏色:info.plist文件中直接設(shè)置狀態(tài)欄內(nèi)容顏色:在info.plist中添加字段View controller-based status bar appearance, 當(dāng)其取值為YES時,表示以UIController對狀態(tài)欄的設(shè)置為準,UIApplication對狀態(tài)欄進行的設(shè)置將不起作用。

// 在controller中重寫該方法,并返回相應(yīng)值
- (UIStatusBarStyle)preferredStatusBarStyle {
 
 return UIStatusBarStyleLightContent;
}

// 注意:
// 當(dāng)controller嵌入UINavigationController中時,controller中的方法preferredStatusBarStyle是不會自動被調(diào)用的,而navController中的該方法會被調(diào)用;
// 當(dāng)有navController時,在重寫controller中的preferredStatusBarStyle方法同時,我們還應(yīng)重寫navController中的childViewControllerForStatusBarStyle方法。
- (UIViewController *)childViewControllerForStatusBarStyle {
 
 return self.topViewController;
}

當(dāng)字段View controller-based status bar appearance取值為NO時,則以UIApplication為準,控制器設(shè)置狀態(tài)欄的方法preferredStatusBarStyle則根本不會被調(diào)用。

// 狀態(tài)欄內(nèi)容-黑色
[UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleDefault;
// 狀態(tài)欄內(nèi)容-白色
[UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleLightContent;

在info.plist文件中直接設(shè)置狀態(tài)欄內(nèi)容顏色:字段View controller-based status bar appearance取值為NO,且Status bar style取值為UIStatusBarStyleLightContent(可選),則不寫代碼,也可控制應(yīng)用中的狀態(tài)欄內(nèi)容顏色。

2. 隱藏狀態(tài)欄

整個項目隱藏在Targets -> General -> 勾選 Hide status bar 即可。

iOS狀態(tài)欄、導(dǎo)航欄的示例分析

在單個界面中隱藏

// iOS 9.0 之前
// 隱藏=YES,顯示=NO; Animation:動畫效果
[[UIApplication sharedApplication] setStatusBarHidden:YES withAnimation:UIStatusBarAnimationNone];

// iOS 9.0 之后推薦使用這個
// 注意:該方法可以通過UIController中的方法setNeedsStatusBarAppearanceUpdate來間接調(diào)用
- (BOOL)prefersStatusBarHidden {
 
 return YES;
}

注意:上面兩個操作狀態(tài)方法依然受到Info.plist中字段View controller-based status bar appearance取值得影響,該字段取值為YES時,進入controller會自動調(diào)用prefersStatusBarHidden方法。當(dāng)controller嵌入UINavigationController中時,controller中的方法prefersStatusBarHidden是不會自動被調(diào)用的,而navController中的該方法會被調(diào)用;當(dāng)有navController時,在重寫controller中的prefersStatusBarHidden方法同時,我們還應(yīng)重寫navController中的childViewControllerForStatusBarHidden方法。

- (UIViewController *)childViewControllerForStatusBarHidden {
 
 return self.topViewController;
}

啟動頁隱藏狀態(tài)欄,進入程序后正常顯示狀態(tài)欄
首先,在Targets->General->勾選中Hide status bar或者在info.plist里面 Status bar is initially hidden 設(shè)置為 YES;
其次,在AppDelegate.m中添加代碼

-(BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
 [application setStatusBarHidden:NO withAnimation:UIStatusBarAnimationFade];
}

3. 導(dǎo)航欄

iOS狀態(tài)欄、導(dǎo)航欄的示例分析

UINavigationController的視圖層次結(jié)構(gòu)比較清晰,用戶可見的導(dǎo)航欄即為其中的***UINavigationBar***,通過它,我們就可以修改導(dǎo)航欄的樣式。下面我們就逐步介紹一些常用的關(guān)于導(dǎo)航欄的操作。

導(dǎo)航欄常用操作

// 隱藏導(dǎo)航欄
//[self.navigationController setNavigationBarHidden:YES];
[self.navigationController setNavigationBarHidden:YES animated:YES];

// 設(shè)置導(dǎo)航背景為紅色
[self.navigationController.navigationBar setBarTintColor:[UIColor redColor]];

// 設(shè)置navigationBar的透明效果
[self.navigationController.navigationBar setTranslucent:YES]; 
//設(shè)置導(dǎo)航欄的背景圖片
[self.navigationController.navigationBar setBackgroundImage:[UIImage imageNamed:@"imgName"] forBarMetrics:UIBarMetricsDefault];

// Attributes 屬性
NSDictionary *textAttributes = @{NSForegroundColorAttributeName:[UIColor whiteColor],NSFontAttributeName:[UIFont systemFontOfSize:30]};
// 設(shè)置導(dǎo)航欄標(biāo)題的字體大小、顏色
[self.navigationController.navigationBar setTitleTextAttributes:textAttributes];

4. 導(dǎo)航欄常用樣式

在日常開發(fā)中,我們經(jīng)常需要修改導(dǎo)航欄樣式,如使導(dǎo)航欄透明、導(dǎo)航欄尺寸等,在不同樣式導(dǎo)航欄之間的切換時還要注意是否平順...(隱藏,與正常導(dǎo)航欄的切換)

導(dǎo)航欄大標(biāo)題

if (@available(iOS 11.0, *)) {
  [self.navigationController.navigationBar setPrefersLargeTitles:YES];
}

自定義導(dǎo)航欄大標(biāo)題樣式

重寫UINavigationBar中的layoutSubviews方法,可通過發(fā)送通知的形式來監(jiān)聽導(dǎo)航欄高度變化,如下:

-(void)layoutSubviews {
 [super layoutSubviews];
 
 [[NSNotificationCenter defaultCenter] postNotificationName:KEY_UINavigationBar_Height_Changed object:self userInfo:nil];
}

使導(dǎo)航欄透明

當(dāng)需要設(shè)置導(dǎo)航欄透明且title等項正常顯示時,最好將設(shè)置過程置于viewWillAppear:方法中:

//// 需要導(dǎo)航欄透明的ViewController中
- (void)viewWillAppear:(BOOL)animated {
 
 [super viewWillAppear:animated];
 
 _navView.hidden = NO;
 self.edgesForExtendedLayout = UIRectEdgeTop;
 self.navigationController.navigationBar.translucent = YES;
 [self.navigationController.navigationBar setShadowImage:[UIImage new]];
 [self.navigationController.navigationBar setBackgroundImage:[UIImage new] forBarMetrics:UIBarMetricsDefault];
 [self.navigationController.navigationBar setTitleTextAttributes:@{NSForegroundColorAttributeName: [UIColor whiteColor]}];
}

//// 導(dǎo)航欄為非透明的ViewController中
- (void)viewWillAppear:(BOOL)animated {
 
 [super viewWillAppear:animated];
 
 self.edgesForExtendedLayout = UIRectEdgeNone;
 self.navigationController.navigationBar.translucent = NO;
 [self.navigationController.navigationBar setShadowImage:nil];
 [self.navigationController.navigationBar setTintColor:[UIColor blackColor]];
 [self.navigationController.navigationBar setBackgroundImage:nil forBarMetrics:UIBarMetricsDefault];
 [self.navigationController.navigationBar setTitleTextAttributes:@{NSForegroundColorAttributeName: [UIColor blackColor]}];
}

以上是“iOS狀態(tài)欄、導(dǎo)航欄的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司行業(yè)資訊頻道!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站www.cdcxhl.com,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。


網(wǎng)頁題目:iOS狀態(tài)欄、導(dǎo)航欄的示例分析-創(chuàng)新互聯(lián)
標(biāo)題網(wǎng)址:http://weahome.cn/article/dophih.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部