關(guān)于UINavigationBar的背景和分割線設(shè)置

我們可以通過兩個(gè)系統(tǒng)提供的方法很方便的修改導(dǎo)航欄的顏色碰纬,直接設(shè)置一個(gè)顏色:

[self.navigationController.navigationBar setBarTintColor:[UIColor greenColor]];

也可以設(shè)置一張背景圖片:

UIImage *image = [UIImage imageFromColor:[UIColor greenColor] withSize:CGSizeMake(kWidth, kStatus_h + 44.f)];

[self.navigationController.navigationBar setBackgroundImage:image forBarMetrics:UIBarMetricsDefault];

這里用到一個(gè)自己添加的方法和兩個(gè)宏伙判。

+ (UIImage *)imageFromColor:(UIColor *)color withSize:(CGSize)size

{

CGRect rect=CGRectMake(0.0f, 0.0f, size.width, size.height);

UIGraphicsBeginImageContext(rect.size);

CGContextRef context = UIGraphicsGetCurrentContext();

CGContextSetFillColorWithColor(context, [color CGColor]);

CGContextFillRect(context, rect);

UIImage *theImage = UIGraphicsGetImageFromCurrentImageContext();

UIGraphicsEndImageContext();

return theImage;

}

這是干啥的看方法名就能明白了吧猿妈,你可以新建UIImage的Category倔幼,把這個(gè)方法加進(jìn)去监氢,說(shuō)不定以后還能用到~

還有這兩個(gè)宏

//獲取屏幕高度

#define kWidth [UIScreen mainScreen].bounds.size.width

//獲取狀態(tài)欄高度

#define kStatus_h? [[UIApplication sharedApplication] statusBarFrame].size.height

在iPhone X出來(lái)之前绎谦,狀態(tài)欄高度都是固定20,現(xiàn)在要添加一個(gè)宏來(lái)動(dòng)態(tài)獲取了竭钝。

這兩個(gè)方法目前的效果是一樣的梨撞,如下圖雹洗。





這時(shí)候如果有需求想要修改導(dǎo)航欄分割線的顏色呢香罐? 通常我們通過修改UINavigationBar的?shadowImage屬性來(lái)設(shè)置分割線。

下面是頭文件里對(duì)shadowImage屬性的描述

/* Default is nil. When non-nil, a custom shadow image to show instead of the default shadow image. For a custom shadow to be shown, a custom background image must also be set with -setBackgroundImage:forBarMetrics: (if the default background image is used, the default shadow image will be used). */ @property(nullable, nonatomic,strong) UIImage *shadowImage NS_AVAILABLE_IOS(6_0) UI_APPEARANCE_SELECTOR;

@property(nullable, nonatomic,strong) UIImage *shadowImage?

大致意思时肿,你如果要通過設(shè)置這個(gè)屬性來(lái)修改分割線庇茫,那么你要同時(shí)通過setBackgroundImage:forBarMetrics:為UINavigationBar設(shè)置一個(gè)背景圖片,這樣你設(shè)置的分割線樣式才能生效螃成。一開始我是不信的旦签,那我們來(lái)試一下。

//通過設(shè)置BarTintColor為 navigationBar設(shè)置白色背景顏色寸宏,不通過setBackgroundImage:forBarMetrics:為UINavigationBar設(shè)置背景圖片

[self.navigationController.navigationBar setBarTintColor:[UIColor whiteColor]];


//通過設(shè)置shadowImage為 navigationBar設(shè)置紅色分割線

UIImage *lineImage = [UIImage imageFromColor:[UIColor redColor] withSize:CGSizeMake(kWidth, 0.5f)];

[self.navigationController.navigationBar setShadowImage:lineImage];





我們?cè)O(shè)置的紅色分割線并沒有生效宁炫,而是默認(rèn)的黑色。

還是乖乖聽話氮凝,同時(shí)用-setBackgroundImage:forBarMetrics:方法設(shè)置背景顏色羔巢。

//通過設(shè)置-setBackgroundImage:forBarMetrics:方法設(shè)置白色背景顏色

//通過設(shè)置-setBackgroundImage:forBarMetrics:方法設(shè)置白色背景顏色

UIImage *bgimage = [UIImage imageFromColor:[UIColor whiteColor] withSize:CGSizeMake(kWidth, kStatus_h + 44.f)];

[self.navigationController.navigationBar setBackgroundImage:bgimage forBarMetrics:UIBarMetricsDefault];

//通過設(shè)置shadowImage為 navigationBar設(shè)置紅色分割線

UIImage *lineImage = [UIImage imageFromColor:[UIColor redColor] withSize:CGSizeMake(kWidth, 0.5f)];

[self.navigationController.navigationBar setShadowImage:lineImage];





果然分割線變成了紅色。

總結(jié):

你可以這樣設(shè)置微導(dǎo)航欄設(shè)置背景顏色罩阵,或者是各種圖案竿秆。

//通過設(shè)置BarTintColor為 navigationBar設(shè)置背景顏色

[self.navigationController.navigationBar setBarTintColor:[UIColor whiteColor]];

//通過-setBackgroundImage:forBarMetrics:方法設(shè)置白色背景顏色

UIImage *bgimage = [UIImage imageFromColor:[UIColor whiteColor] withSize:CGSizeMake(kWidth, kStatus_h + 44.f)];

[self.navigationController.navigationBar setBackgroundImage:bgimage forBarMetrics:UIBarMetricsDefault];

但是如果你想同時(shí)設(shè)置背景樣式和分割線顏色,你只能通過-setBackgroundImage:forBarMetrics:方法來(lái)設(shè)置你的背景稿壁,否則你通過設(shè)置shadowImage屬性修改分割線樣式就不會(huì)生效幽钢。

單是如果你是一個(gè)剛烈的孩子,一定要通過設(shè)置barTintColor修改背景顏色傅是,還想修改分割線顏色的話匪燕,方法是有的蕾羊。通過遍歷UINavigationBar找到那條分割線,并且直接修改帽驯《遣颍或者隱藏原來(lái)的分割線,自定義一條分割線界拦。

你問我具體怎么實(shí)現(xiàn)吸申??

https://www.baidu.com



以上代碼都是在iOS 10.3.1 上的模擬器運(yùn)行。后來(lái)我發(fā)現(xiàn)享甸,在iOS11和以上的設(shè)備上已經(jīng)不需要使用

-setBackgroundImage:forBarMetrics:方法設(shè)置背景圖片才能通過設(shè)置shadowImage修改分割線樣式了截碴。

不設(shè)置BackgroundImage,直接設(shè)置shadowImage也能修改分割線的樣式蛉威,大家可以自己試一試日丹。不過為了適配iOS11以下的設(shè)備,還是需要同時(shí)設(shè)置背景圖片~

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末蚯嫌,一起剝皮案震驚了整個(gè)濱河市哲虾,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌择示,老刑警劉巖束凑,帶你破解...
    沈念sama閱讀 206,968評(píng)論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異栅盲,居然都是意外死亡汪诉,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,601評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門谈秫,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)扒寄,“玉大人,你說(shuō)我怎么就攤上這事拟烫「帽啵” “怎么了?”我有些...
    開封第一講書人閱讀 153,220評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵硕淑,是天一觀的道長(zhǎng)课竣。 經(jīng)常有香客問我,道長(zhǎng)喜颁,這世上最難降的妖魔是什么稠氮? 我笑而不...
    開封第一講書人閱讀 55,416評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮半开,結(jié)果婚禮上隔披,老公的妹妹穿的比我還像新娘。我一直安慰自己寂拆,他們只是感情好奢米,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,425評(píng)論 5 374
  • 文/花漫 我一把揭開白布抓韩。 她就那樣靜靜地躺著,像睡著了一般鬓长。 火紅的嫁衣襯著肌膚如雪谒拴。 梳的紋絲不亂的頭發(fā)上翅帜,一...
    開封第一講書人閱讀 49,144評(píng)論 1 285
  • 那天苗踪,我揣著相機(jī)與錄音爱葵,去河邊找鬼朴艰。 笑死,一個(gè)胖子當(dāng)著我的面吹牛帐要,可吹牛的內(nèi)容都是我干的府喳。 我是一名探鬼主播针姿,決...
    沈念sama閱讀 38,432評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼窗声,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼相恃!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起笨觅,我...
    開封第一講書人閱讀 37,088評(píng)論 0 261
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤拦耐,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后见剩,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體杀糯,經(jīng)...
    沈念sama閱讀 43,586評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,028評(píng)論 2 325
  • 正文 我和宋清朗相戀三年炮温,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了火脉。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,137評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡柒啤,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出畸颅,到底是詐尸還是另有隱情担巩,我是刑警寧澤,帶...
    沈念sama閱讀 33,783評(píng)論 4 324
  • 正文 年R本政府宣布没炒,位于F島的核電站涛癌,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏送火。R本人自食惡果不足惜拳话,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,343評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望种吸。 院中可真熱鬧弃衍,春花似錦、人聲如沸坚俗。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,333評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至速缆,卻和暖如春降允,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背艺糜。 一陣腳步聲響...
    開封第一講書人閱讀 31,559評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工剧董, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人破停。 一個(gè)月前我還...
    沈念sama閱讀 45,595評(píng)論 2 355
  • 正文 我出身青樓送滞,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親辱挥。 傳聞我的和親對(duì)象是個(gè)殘疾皇子犁嗅,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,901評(píng)論 2 345

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