iOS11適配工作及導航欄影藏返回文字的解決方法
前言
本文主要介紹了關于iOS11適配及導航欄影藏返回文字的解決方法,分享出來供大家參考學習,下面話不多說了,來一起看看詳細的介紹吧。
一、iOS11適配工作
這是一篇 WWDC Session 204 "Updating Your App for iOS 11" 的總結,里面的內容涉及到了產品、設計以及開發(fā)需要了解的內容。
在 "iPad" 以及 "iPhone 的 Landscape" 下, UITabBarItem 圖片和文字并排排列了,并且長按 UITabBarItem 會有一個大的 HUD 顯示在中間
通過設置 UIBarItem.largeContentSizeImage 可以設置 Tabbar 長按之后顯示在中間的圖片
(這個功能我在 Beta 2 中沒有試出來,只能截取官方的圖片)
iOS 11 為我們帶來了 "Large Title",效果如下,當 "ScrollView" 向上滑動時,"Large Title" 會跟著改變, 效果如下:
"SearchBar" 被移植到了 "NavigationBar" 上面, 提供兩種模式,一種是滾動后隱藏 searchBar(如上圖), 另外一種就是保留 searchBar 在 Navigation 上。通過以下代碼控制
navigationItem.hidesSearchBarWhenScrolling = false
UIToolbar, UINavigationBar 支持 Auto Layout
UIView.layoutMargins
被擴展到了 UIView.directionalLayoutMargins
, 支持 Right to Left 語言(和我們關系不大,除非某天我們進軍中東的某些國家了)。并且,這兩個屬性會互相同步
UIViewController 添加 systemMinimumLayoutMargins 屬性(說實話,我們布局真的很少用到這個東西,不過可以作為了解)
新增 UIView.safeAreaLayoutGuide
,同時廢棄 UIViewController.topLayoutGuide
和 UIViewController.bottomLayoutGuide
。如果你之前處理過 UINavigationBar 的translucent,你就會發(fā)現(xiàn) topLayoutGuide 的表現(xiàn)只能用差強人意來形容,希望這次新增的 safAreaLayoutGuide 能夠徹底改變這個現(xiàn)狀
///safeAreaLayoutGuide 取代 topLayoutGuide 的代碼 //subview.topAnchor.constraint(equalTo: self.topLayoutGuide.bottomAnchor).isActive = true subview.topAnchor.constraint(equalTo: view.safeAreaLayoutGuide.topAnchor).isActive = true
藍色區(qū)域即:UIView.safAreaLayoutGuide
UIScrollView 新增 adjustedContentInset
UIScrollView 新增 frameLayoutGuide 和 contentLayoutGuide, 目的是為了降低 ScrollView Auto Layout 的難度
UITabelViewCell 的 rowHeight 默認變成 UITableViewAutomaticDimension, 意味著自動算高會更普及了
UITableView 開放了 "Full Swipe", 就像刪除郵件的操作一樣
func tableView(_ tableView: UITableView, leadingSwipeActionsConfigurationForRowAt indexPath: IndexPath) -> UISwipeActionsConfiguration? { return nil } func tableView(_ tableView: UITableView, trailingSwipeActionsConfigurationForRowAt indexPath: IndexPath) -> UISwipeActionsConfiguration? { let action = UIContextualAction(style: UIContextualAction.Style.destructive, title: "Delete") { (action, view, completionHandler) in self.tableView.beginUpdates() self.data.remove(at: indexPath.row) self.tableView.deleteRows(at: [indexPath], with: UITableViewRowAnimation.left) self.tableView.endUpdates() completionHandler(true) } let configuration = UISwipeActionsConfiguration(actions: [action]) return configuration }
二、導航欄影藏返回文字的解決方法
如果要只保留返回按鈕的文字,不需要"返回"文字
iOS11之前,在 全局函數(shù)執(zhí)行的地方使用一下代碼:
// barBtn.setBackButtonTitlePositionAdjustment( UIOffset(horizontal:0 , vertical: -70), for: .default) //設置取消返回按鈕的字體
iOS11之后,我的解決辦法為,在push的父頁面將title設為空
例如:
self.title = "" self.navigationController?.pushViewController(workDetail, animated: true)
這樣的話就需要在viewWillAppear方法中每次都設置控制器的title,不然就會導致返回這個頁面的時候title不見的。
綜合的解決辦法,手動添加一個只含返回圖標的button,然后在push到目的頁面的時候添加。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關文章
iOS 仿微博客戶端紅包加載界面 XLDotLoading效果
這篇文章主要介紹了iOS 仿微博客戶端紅包加載界面 XLDotLoading,需要的朋友可以參考下2017-02-02iOS App開發(fā)中導航欄的創(chuàng)建及基本屬性設置教程
這篇文章主要介紹了iOS App開發(fā)中導航欄的創(chuàng)建及基本屬性設置教程,即用UINavigationController來編寫navigation,示例代碼為Objective-C語言,需要的朋友可以參考下2016-02-02iOS開發(fā)教程之APP內部切換語言的實現(xiàn)方法
這篇文章主要給大家介紹了關于iOS開發(fā)教程之APP內部切換語言的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧2019-02-02iOS overFullScreen與fullScreen區(qū)別分析
這篇文章主要介紹了iOS overFullScreen與fullScreen區(qū)別分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-11-11