iOS11 安全區(qū)域 iPhone X

在寫App的引導(dǎo)界面的時(shí)候遇到了這個(gè)問題,其實(shí)很早以前就遇到了這個(gè)問題,當(dāng)時(shí)就是只是用一句代碼就可以去搞定怠噪。

if #available(iOS 11.0, *) {
     scrollView.contentInsetAdjustmentBehavior = .never
}

在UIViewController中有一個(gè)屬性

@available(iOS, introduced: 7.0, deprecated: 11.0, message: "Use UIScrollView's contentInsetAdjustmentBehavior instead")
    open var automaticallyAdjustsScrollViewInsets: Bool // Defaults to YES

此屬性的默認(rèn)值為true,這使得當(dāng)有滾動(dòng)視圖插入,UIViewController會(huì)去考慮狀態(tài)欄晤柄、搜索欄、導(dǎo)航欄妖胀、工具欄或標(biāo)簽欄所消耗的屏幕區(qū)域芥颈。如果UIViewController自己管理滾動(dòng)視圖的插入調(diào)整,則將此屬性設(shè)置為false赚抡。
而在iOS11中UIViewController的這個(gè)屬性已經(jīng)被廢除爬坑,轉(zhuǎn)而代替它的是的ScrollView的兩個(gè)屬性:

open var adjustedContentInset: UIEdgeInsets { get }

open var contentInsetAdjustmentBehavior: UIScrollViewContentInsetAdjustmentBehavior

首先來看看安全區(qū)域safeAreaInsets,官方文檔解釋如下:



安全區(qū)域就是不被狀態(tài)欄怕品、搜索欄妇垢、導(dǎo)航欄、工具欄或標(biāo)簽欄所消耗的屏幕區(qū)域所覆蓋肉康。safeAreaInsets這個(gè)屬性其實(shí)指的就是一個(gè)view距離該view的安全區(qū)域的邊距闯估。如果一個(gè)view全部在它父視圖的安全區(qū)域內(nèi),則SafeAreaInsets值為(0,0,0,0)吼和。如果多了一個(gè)信號(hào)欄涨薪,那SafeAreaInset值為(20,0,0,0)。

var adjustedContentInset: UIEdgeInsets { get }

這是我們前面提到過的ScrollView的一個(gè)屬性炫乓,使用此屬性獲得在其中繪制內(nèi)容的調(diào)整區(qū)域刚夺。簡(jiǎn)單來說就是我們ScrollerView中呈現(xiàn)的內(nèi)容需要上下左右調(diào)整多少會(huì)由這個(gè)屬性來進(jìn)行控制。iOS11以前ScrollView內(nèi)容與View邊緣距離是由contentInset來決定的而在iOS11后使用的是adjustedContentInset(內(nèi)容偏移量)末捣。那緊接著我們來說一下這個(gè)屬性是如何進(jìn)行計(jì)算的侠姑,這個(gè)時(shí)候就需要用到contentInsetAdjustmentBehavior這個(gè)枚舉屬性了。

@available(iOS 11.0, *)
public enum UIScrollViewContentInsetAdjustmentBehavior : Int {

    case automatic // Similar to .scrollableAxes, but for backward compatibility will also adjust the top & bottom contentInset when the scroll view is owned by a view controller with automaticallyAdjustsScrollViewInsets = YES inside a navigation controller, regardless of whether the scroll view is scrollable

    case scrollableAxes // Edges for scrollable axes are adjusted (i.e., contentSize.width/height > frame.size.width/height or alwaysBounceHorizontal/Vertical = YES)

    case never // contentInset is not adjusted

    case always // contentInset is always adjusted by the scroll view's safeAreaInsets
}

automatic和scrollableAxes屬性依賴于controller 的automaticallyAdjustsScrollViewContentInset屬性為true
(1)automatic
adjustedContentInset = safeAreaInset + contentInset
(2)scrollableAxes
在可以滾動(dòng)的方向上 adjustedContentInset = safeAreaInset + contentInset
在不可以滾動(dòng)的方向上 adjustedContentInset = contentInset
(3)never
adjustedContentInset = contentInset
(4)always
adjustedContentInset = safeAreaInset + contentInset
iPhone X由于是劉海屏幕箩做,安全區(qū)域的問題官方的文檔也說明的很詳細(xì)了莽红,可以戳鏈接:https://developer.apple.com/design/human-interface-guidelines/ios/overview/iphone-x/

文章的最后再拋出一個(gè)問題:現(xiàn)在再來看看我最近遇到的iOS10的一個(gè)問題,隱藏了導(dǎo)航欄,然后進(jìn)入頁面后讓W(xué)KWebView滿鋪整個(gè)屏幕安吁,進(jìn)入之后發(fā)現(xiàn)網(wǎng)頁的內(nèi)容整體下降了一個(gè)信號(hào)欄的高度醉蚁。
因?yàn)閃KWebView是繼承于ScrollView的,前面提到過在iOS11之前都是由UIViewController的automaticallyAdjustsScrollViewInsets(默認(rèn)是true)屬性來控制是否讓他自己去適應(yīng)滾動(dòng)視圖的插入鬼店,而我沒有對(duì)這個(gè)屬性進(jìn)行修改网棍,所以會(huì)自適應(yīng)讓整個(gè)網(wǎng)頁內(nèi)容往下移動(dòng)了一個(gè)信號(hào)欄的高度。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末妇智,一起剝皮案震驚了整個(gè)濱河市滥玷,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌俘陷,老刑警劉巖罗捎,帶你破解...
    沈念sama閱讀 211,884評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異拉盾,居然都是意外死亡桨菜,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,347評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門捉偏,熙熙樓的掌柜王于貴愁眉苦臉地迎上來倒得,“玉大人,你說我怎么就攤上這事夭禽∠疾簦” “怎么了?”我有些...
    開封第一講書人閱讀 157,435評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵讹躯,是天一觀的道長菩彬。 經(jīng)常有香客問我,道長潮梯,這世上最難降的妖魔是什么骗灶? 我笑而不...
    開封第一講書人閱讀 56,509評(píng)論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮秉馏,結(jié)果婚禮上耙旦,老公的妹妹穿的比我還像新娘。我一直安慰自己萝究,他們只是感情好免都,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,611評(píng)論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著帆竹,像睡著了一般绕娘。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上栽连,一...
    開封第一講書人閱讀 49,837評(píng)論 1 290
  • 那天业舍,我揣著相機(jī)與錄音,去河邊找鬼升酣。 笑死舷暮,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的噩茄。 我是一名探鬼主播下面,決...
    沈念sama閱讀 38,987評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼绩聘!你這毒婦竟也來了沥割?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,730評(píng)論 0 267
  • 序言:老撾萬榮一對(duì)情侶失蹤凿菩,失蹤者是張志新(化名)和其女友劉穎机杜,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體衅谷,經(jīng)...
    沈念sama閱讀 44,194評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡椒拗,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,525評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了获黔。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蚀苛。...
    茶點(diǎn)故事閱讀 38,664評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖玷氏,靈堂內(nèi)的尸體忽然破棺而出堵未,到底是詐尸還是另有隱情,我是刑警寧澤盏触,帶...
    沈念sama閱讀 34,334評(píng)論 4 330
  • 正文 年R本政府宣布渗蟹,位于F島的核電站,受9級(jí)特大地震影響赞辩,放射性物質(zhì)發(fā)生泄漏雌芽。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,944評(píng)論 3 313
  • 文/蒙蒙 一诗宣、第九天 我趴在偏房一處隱蔽的房頂上張望膘怕。 院中可真熱鬧,春花似錦召庞、人聲如沸岛心。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,764評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽忘古。三九已至,卻和暖如春诅诱,著一層夾襖步出監(jiān)牢的瞬間髓堪,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,997評(píng)論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留干旁,地道東北人驶沼。 一個(gè)月前我還...
    沈念sama閱讀 46,389評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像争群,于是被迫代替她去往敵國和親回怜。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,554評(píng)論 2 349

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

  • 1换薄、通過CocoaPods安裝項(xiàng)目名稱項(xiàng)目信息 AFNetworking網(wǎng)絡(luò)請(qǐng)求組件 FMDB本地?cái)?shù)據(jù)庫組件 SD...
    陽明先生_X自主閱讀 15,969評(píng)論 3 119
  • 在路上
    誠實(shí)_281f閱讀 234評(píng)論 0 0
  • 你笑起來有太陽底下草地的味道 你都不知道你笑起來多好看 為什么不笑呢 你笑起來啊 我的世界就好像充滿了星星 閃亮閃...
    哀慕熙榮閱讀 215評(píng)論 1 2
  • 星期日 晴 每日一我 睡到8點(diǎn)多起來玉雾,油拔+站墻+聽書。去旁邊小店吃早餐轻要,青菜粉复旬。 粉更像是西安涼粉。寬寬的那種冲泥,...
    sophietyl閱讀 139評(píng)論 0 0