iOS11 自定義導航欄衍生的幾個問題(高度与斤、間距等)

本文討論的問題:

  1. 自定義導航欄,導航欄高度;
  2. items 與導航欄間的間距荚恶;
  3. 導航欄的層次結(jié)構(gòu)撩穿;
  4. 自定義導航欄的一大好處!

正文:

有個項目中自定義導航欄谒撼,當然是繼承自 UINavigationBar 食寡,但是顯示效果與期望值不符,上移了一段距離(20px)廓潜。如下圖:


image.png

首先想到的是調(diào)整frame的高度冻河,運行之后仍沒有效果。
于是想到查看一下視圖的層次結(jié)構(gòu)茉帅。如下圖:

image.png

如圖所示的層次結(jié)構(gòu)叨叙,navbar 下面有兩個直接子視圖,background 和 contentView堪澎。
而navBar的高度時正確的擂错,只是background和contentView上移了。而且這倆家伙的高度也與期望的不相符樱蛤。

(background)


image.png

(contentView)


image.png

通過打印的內(nèi)容可以看出钮呀,background 和 contentView 的高度都是44,比預期的64減小了20昨凡,正好是一個狀態(tài)欄的高度爽醋。
有個思路是將它們下移 20 。

根據(jù)視圖層次便脊,我們知道background是負責渲染背景相關的蚂四,contentView負責顯示我們設置的控件、title等內(nèi)容。

所以遂赠,為了使導航欄與狀態(tài)欄的風格一致久妆,
決定將 background 的高度從 44 變?yōu)?64,與導航欄一致跷睦;
將 contentView 下移 20 筷弦。

怎么才能拿到這兩個視圖呢?方法是遍歷導航欄navBar的子視圖 subViews抑诸。
那么在什么時機遍歷子視圖-修改frame合適呢烂琴?
還是在 自定義navBar 的 layoutSubviews 方法中最合適。
注意在 自定義navBar 中重寫 layoutSubViews 方法時蜕乡,要先 super.layoutSubviews() 一下监右,否則會導致自定義導航欄中沒有東西,因為系統(tǒng)沒給layout异希。

解決思路:

  1. 在自定義navBar中重寫 layoutSubviews 方法健盒;
  2. 調(diào)用父類 super.layoutSubviews() 讓系統(tǒng)布局完畢;
  3. 遍歷 navBar 的 subViews 找到 視圖background 和 視圖contentView称簿;
  4. 分別設置它們的frame扣癣;
  5. 當然有個前提,那就是要先判斷當前系統(tǒng)版本憨降,如果 versionCode > 11.0 才需要自己處理父虑。
  6. 還要注意一個問題,那就是 iPhone X 設備授药,需要為此單獨設置frame士嚎。

為了清晰明了,直接上代碼:


image.png

設置完畢悔叽,運行莱衩,效果如下:


image.png

有沒有發(fā)現(xiàn)上面這張圖的 Left 按鈕跟第一張圖的 Left 按鈕的區(qū)別?
是的娇澎,這就是要繼續(xù)討論的【2. items 與導航欄間的間距 】這個問題笨蚁。

我們都有過這樣的感覺,設置完 leftBarButtonItem 或者 rightBarButtonItem 的時候趟庄,總感覺它距離屏幕的邊距有點遠括细。

在iOS10之前,要使邊距近一點戚啥,是在它倆之間添加一個 "占位" 奋单,并設置占位item的寬度width = -15; 對是負的,如下:

UIBarButtonItem *leftFixed = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemFixedSpace target:nil action:nil];
leftFixed.width = -15;


image.png

而在 iOS11 之后猫十,這樣設置不起作用了览濒。
根據(jù)視圖層次結(jié)構(gòu)呆盖,之后設置 導航欄的 barContentView 的內(nèi)邊距小一點,于是就有了這行代碼:
【 view.layoutMargins = UIEdgeInsetsMake(0, 2, 0, 2) 】

OK匾七,雖然顯示在導航欄里的東西設置完了絮短,也顯示正常了江兢,但是還有一個問題沒有討論昨忆,那就是自定義導航欄的一大好處!
先來看效果:


image.png

這個效果避免了與大多數(shù)App那樣前后兩個頁面的導航欄融合在一起混亂的感覺杉允,這樣子多么清爽邑贴!

So,自定義導航欄的一大作用就是在push或者pop時前后兩個導航欄相互獨立叔磷,看起來清爽宜人拢驾!

附:導航欄結(jié)構(gòu)類名

UINavigationBar

** _UIBarBackground
****** UIImageView
****** UIImageView

** _UINavigationBarContentView

****** _UIButtonBarStackView(left)
********** _UITAMICAdaptorView(左側(cè)按鈕)
********** UIView(多個按鈕之間的間距)
********** _UIButtonBarButton

****** _UIButtonBarStackView(right)
********** _UITAMICAdaptorView
************** UIButton(右側(cè)按鈕)
********** UIView(多個按鈕之間的間距)
********** _UITAMICAdaptorView
********** UIView(多個按鈕之間的間距)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市改基,隨后出現(xiàn)的幾起案子繁疤,更是在濱河造成了極大的恐慌,老刑警劉巖秕狰,帶你破解...
    沈念sama閱讀 219,039評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件稠腊,死亡現(xiàn)場離奇詭異,居然都是意外死亡鸣哀,警方通過查閱死者的電腦和手機架忌,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來我衬,“玉大人叹放,你說我怎么就攤上這事∧痈幔” “怎么了井仰?”我有些...
    開封第一講書人閱讀 165,417評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長破加。 經(jīng)常有香客問我糕档,道長,這世上最難降的妖魔是什么拌喉? 我笑而不...
    開封第一講書人閱讀 58,868評論 1 295
  • 正文 為了忘掉前任速那,我火速辦了婚禮,結(jié)果婚禮上尿背,老公的妹妹穿的比我還像新娘端仰。我一直安慰自己,他們只是感情好田藐,可當我...
    茶點故事閱讀 67,892評論 6 392
  • 文/花漫 我一把揭開白布荔烧。 她就那樣靜靜地躺著吱七,像睡著了一般。 火紅的嫁衣襯著肌膚如雪鹤竭。 梳的紋絲不亂的頭發(fā)上踊餐,一...
    開封第一講書人閱讀 51,692評論 1 305
  • 那天,我揣著相機與錄音臀稚,去河邊找鬼吝岭。 笑死,一個胖子當著我的面吹牛吧寺,可吹牛的內(nèi)容都是我干的窜管。 我是一名探鬼主播,決...
    沈念sama閱讀 40,416評論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼稚机,長吁一口氣:“原來是場噩夢啊……” “哼幕帆!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起赖条,我...
    開封第一講書人閱讀 39,326評論 0 276
  • 序言:老撾萬榮一對情侶失蹤失乾,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后纬乍,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體碱茁,經(jīng)...
    沈念sama閱讀 45,782評論 1 316
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,957評論 3 337
  • 正文 我和宋清朗相戀三年蕾额,在試婚紗的時候發(fā)現(xiàn)自己被綠了早芭。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,102評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡诅蝶,死狀恐怖退个,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情调炬,我是刑警寧澤语盈,帶...
    沈念sama閱讀 35,790評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站缰泡,受9級特大地震影響刀荒,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜棘钞,卻給世界環(huán)境...
    茶點故事閱讀 41,442評論 3 331
  • 文/蒙蒙 一缠借、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧宜猜,春花似錦泼返、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,996評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽渠鸽。三九已至,卻和暖如春柴罐,著一層夾襖步出監(jiān)牢的瞬間徽缚,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,113評論 1 272
  • 我被黑心中介騙來泰國打工革屠, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留凿试,地道東北人。 一個月前我還...
    沈念sama閱讀 48,332評論 3 373
  • 正文 我出身青樓屠阻,卻偏偏與公主長得像红省,于是被迫代替她去往敵國和親额各。 傳聞我的和親對象是個殘疾皇子国觉,可洞房花燭夜當晚...
    茶點故事閱讀 45,044評論 2 355

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