当前位置: 移动技术网 > IT编程>移动开发>IOS > iOS11适配工作及导航栏影藏返回文字的解决方法

iOS11适配工作及导航栏影藏返回文字的解决方法

2019年07月24日  | 移动技术网IT编程  | 我要评论

10118,魏斯婷,昏君养成计划

前言

本文主要介绍了关于ios11适配及导航栏影藏返回文字的解决方法,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。

一、ios11适配工作

这是一篇 wwdc session 204 "updating your app for ios 11" 的总结,里面的内容涉及到了产品、设计以及开发需要了解的内容。

在 "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,你就会发现 toplayoutguide 的表现只能用差强人意来形容,希望这次新增的 safarealayoutguide 能够彻底改变这个现状

///safearealayoutguide 取代 toplayoutguide 的代码
//subview.topanchor.constraint(equalto: self.toplayoutguide.bottomanchor).isactive = true
subview.topanchor.constraint(equalto: view.safearealayoutguide.topanchor).isactive = true

蓝色区域即: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之前,在 全局函数执行的地方使用一下代码:

// 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到目的页面的时候添加。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对移动技术网的支持。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网