iOS標題欄

狀態(tài)欄:


導(dǎo)論:

ios上狀態(tài)欄:顯示信號 旧乞、時間熊尉、電池狀態(tài)的20像素的位置

狀態(tài)欄分為前景和背景部分

前景部分:就是指的顯示電池、時間等部分擅这;

背景部分:就是顯示黑色或者圖片的背景部分;

(一)設(shè)置statusBar的【前景部分】

這里只有兩種顏色:

默認的黑色(UIStatusBarStyleDefault)

白色(UIStatusBarStyleLightContent)

可以設(shè)置的地方有兩個:plist設(shè)置里面 和 程序代碼里

1采章、plist

View controller-based status bar appearance (需要手動添加)

info.plist文件中运嗜,View controller-based status bar appearance 項的設(shè)置:

1,為YES悯舟,則ViewController對status bar的設(shè)置優(yōu)先級高于application的設(shè)置担租。則[UIApplication sharedApplication].statusBarStyle 無效。

2图谷,為NO翩活,則以application的設(shè)置為準,viewController的prefersStatusBarHidden方法無效便贵,是根本不會被調(diào)用的。

2冗荸、代碼設(shè)置

(1)承璃、[UIApplicationsharedApplication].statusBarStyle=UIStatusBarStyleLightContent;

(2)、重寫- (UIStatusBarStyle)preferredStatusBarStyle {

? ? ? ? ? ? ? ? ? ? ? ? ? ? return UIStatusBarStyleLightContent;//白色

? ? ? ? ? ? ? ? ? ? ? ? ? ?//returnUIStatusBarStyleDefault;//默認的黑色

? ? ? ? ? ? ? ? ? ? ? ? }


(二)設(shè)置statusBar的【背景部分】

(1)蚌本、系統(tǒng)提供的方法

navigationBar的setBarTintColor接口盔粹,用此接口可改變statusBar的背景色:

self.navigationController.navigationBar.barTintColor= [UIColor ?redColor];

將狀態(tài)欄和導(dǎo)航欄字體全變?yōu)榘咨?

self.navigationController.navigationBar.barStyle=UIBarStyleBlack;

此行代碼能將狀態(tài)欄和導(dǎo)航欄字體顏色全體改變,只能是黑色或白色.png

如果只想改變導(dǎo)航欄的字體顏色,可以這樣

[self.navigationController.navigationBarsetTitleTextAttributes:@{NSForegroundColorAttributeName:[UIColorredColor]}];

在默認顯示的標題中直接修改文件的大小和顏色也是可以的

改變字體大小:

[self.navigationController.navigationBarsetTitleTextAttributes:@{NSForegroundColorAttributeName:[UIColorredColor],NSFontAttributeName:[UIFontsystemFontOfSize:25]}];

或者可以設(shè)置背景圖片

[self.navigationController.navigationBar setBackgroundImage:[UIImage imageNamed:@"image01"] forBarMetrics:UIBarMetricsDefault];


改變狀態(tài)欄的方法

方法一:

1、如果plist中設(shè)置如下:

View controller-based status bar appearance 設(shè)置為 NO

2程癌、代碼設(shè)置

[UIApplicationsharedApplication].statusBarStyle=UIStatusBarStyleLightContent;

方法二:

1舷嗡、如果plist中設(shè)置如下:

View controller-based status bar appearance 設(shè)置為 YES 或者默認(不設(shè)置)

注意:

如果View controller-based status bar appearance為YES。

則[UIApplication sharedApplication].statusBarStyle 無效嵌莉。

2进萄、代碼設(shè)置

self.navigationController.navigationBar.barStyle=UIBarStyleBlack;

或者在控制器中重寫preferredStatusBarStyle方法,修改狀態(tài)欄顏色

- (UIStatusBarStyle)preferredStatusBarStyle {

// ? return UIStatusBarStyleLightContent;

returnUIStatusBarStyleDefault;

}


隱藏狀態(tài)欄:


一、高版本iOS的處理方法:

(一)锐峭、如果View controller-based status bar appearance 設(shè)為YES中鼠。

這時 ViewController中對status bar的設(shè)置優(yōu)先級高于application的設(shè)置,用下面的方式隱藏status bar:

1沿癞、在ViewController中調(diào)用setNeedsStatusBarAppearanceUpdate援雇,更新status bar的顯示。

- (void)viewDidAppear:(BOOL)animated

{

[super viewDidAppear:animated];

if ([self respondsToSelector:@selector(setNeedsStatusBarAppearanceUpdate)])?

{

[self prefersStatusBarHidden];

[self performSelector:@selector(setNeedsStatusBarAppearanceUpdate)];

}

}

2椎扬、覆蓋view controller的prefersStatusBarHidden的實現(xiàn)惫搏,返回YES。

- (BOOL)prefersStatusBarHidden

{

return YES;

}

(二)蚕涤、如果View controller-based status bar appearance 設(shè)為NO,這時application的設(shè)置優(yōu)先級最高筐赔,用下面的方式隱藏status bar:

[[UIApplication sharedApplication] setStatusBarHidden:YES withAnimation:NO];



二、低版本的處理方法:

綜合上面的結(jié)論钻趋,如果iOS6和iOS7都支持川陆,則處理方式如下:

(一)、如果View controller-based status bar appearance 設(shè)為NO。

則在iOS6和iOS7都是用下面的方法隱藏status bar较沪。

[[UIApplication sharedApplication] setStatusBarHidden:YES withAnimation:NO];

(二)鳞绕、如果View controller-based status bar appearance 設(shè)為YES。

則需要判斷當(dāng)前是iOS6還是iOS7尸曼。如果是iOS6们何,則還通過[UIApplication sharedApplication]隱藏。

如果是iOS7控轿,則用setNeedsStatusBarAppearanceUpdate加prefersStatusBarHidden的方式來隱藏 status bar冤竹。

取info.plist中 View controller-based status bar appearance中的設(shè)置:

NSNumber *vcBasedStatusBarAppearance = [[NSBundle mainBundle]objectForInfoDictionaryKey:@"UIViewControllerBasedStatusBarAppearance"];

if (vcBasedStatusBarAppearance) {

_isVCBasedStatusBarAppearance = vcBasedStatusBarAppearance.boolValue;

} else {

_isVCBasedStatusBarAppearance = YES; // default

}

以上圖片均來自網(wǎng)絡(luò),如有侵權(quán)私信刪除茬射。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末鹦蠕,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子在抛,更是在濱河造成了極大的恐慌钟病,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,214評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件刚梭,死亡現(xiàn)場離奇詭異肠阱,居然都是意外死亡,警方通過查閱死者的電腦和手機朴读,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評論 2 382
  • 文/潘曉璐 我一進店門屹徘,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人衅金,你說我怎么就攤上這事噪伊。” “怎么了典挑?”我有些...
    開封第一講書人閱讀 152,543評論 0 341
  • 文/不壞的土叔 我叫張陵酥宴,是天一觀的道長。 經(jīng)常有香客問我您觉,道長拙寡,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,221評論 1 279
  • 正文 為了忘掉前任琳水,我火速辦了婚禮肆糕,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘在孝。我一直安慰自己诚啃,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 64,224評論 5 371
  • 文/花漫 我一把揭開白布私沮。 她就那樣靜靜地躺著始赎,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上造垛,一...
    開封第一講書人閱讀 49,007評論 1 284
  • 那天魔招,我揣著相機與錄音,去河邊找鬼五辽。 笑死办斑,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的杆逗。 我是一名探鬼主播乡翅,決...
    沈念sama閱讀 38,313評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼罪郊!你這毒婦竟也來了蠕蚜?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 36,956評論 0 259
  • 序言:老撾萬榮一對情侶失蹤悔橄,失蹤者是張志新(化名)和其女友劉穎波势,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體橄维,經(jīng)...
    沈念sama閱讀 43,441評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,925評論 2 323
  • 正文 我和宋清朗相戀三年拴曲,在試婚紗的時候發(fā)現(xiàn)自己被綠了争舞。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,018評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡澈灼,死狀恐怖竞川,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情叁熔,我是刑警寧澤委乌,帶...
    沈念sama閱讀 33,685評論 4 322
  • 正文 年R本政府宣布,位于F島的核電站荣回,受9級特大地震影響遭贸,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜心软,卻給世界環(huán)境...
    茶點故事閱讀 39,234評論 3 307
  • 文/蒙蒙 一壕吹、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧删铃,春花似錦耳贬、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,240評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春腐魂,著一層夾襖步出監(jiān)牢的瞬間帐偎,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,464評論 1 261
  • 我被黑心中介騙來泰國打工挤渔, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留肮街,地道東北人。 一個月前我還...
    沈念sama閱讀 45,467評論 2 352
  • 正文 我出身青樓判导,卻偏偏與公主長得像嫉父,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子眼刃,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,762評論 2 345

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