服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - IOS - iOS11新特性之在你的APP中使用LargeTitle

iOS11新特性之在你的APP中使用LargeTitle

2021-04-08 17:35程序员先生 IOS

本篇文章主要介绍了iOS11新特性之在你的APP中使用LargeTitle,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

随着wwdc17以及apple 2017秋季新品发布会的召开,apple也在9月20日正式推送了ios 11的正式版。在ios 11中,apple也推出了全新的ui风格。

iOS11新特性之在你的APP中使用LargeTitle

ui风格

在ios 11中,系统app使用了这种ui风格。这种风格最明显的变化就是使用了ios 11的新特性--large title和新的searchcontroller。

demo

github: largertitledemo

iOS11新特性之在你的APP中使用LargeTitle

large title & table view

设置lager title

app全局使用large title

?
1
2
3
4
5
6
7
8
9
10
- (bool)application:(uiapplication *)application didfinishlaunchingwithoptions:(nsdictionary *)launchoptions {
 // override point for customization after application launch.
 // 设置large title偏好为true。
 if (@available(ios 11.0, *)) {
  [[uinavigationbar appearance] setpreferslargetitles:true];
 } else {
  // fallback on earlier versions
 }
 return yes;
}

单个viewcontroller使用larger title

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
- (void)viewwillappear:(bool)animated {
 [super viewwillappear:animated];
 // 设置large title偏好为yes。
 if (@available(ios 11.0, *)) {
  [self.navigationcontroller.navigationbar setpreferslargetitles:yes];
 } else {
  // fallback on earlier versions
 }
}
 
- (void)viewwilldisappear:(bool)animated {
 [super viewwilldisappear:animated];
 // 设置large title偏好为no。
 if (@available(ios 11.0, *)) {
  [self.navigationcontroller.navigationbar setpreferslargetitles:no];
 } else {
  // fallback on earlier versions
 }
}

使用上述代码设置后,即可开启large title的显示。

添加table view

iOS11新特性之在你的APP中使用LargeTitle

在storyboard添加tableview

在xcode 9中,xib和storyboard默认会添加 safe area(安全区) ,而添加在controller的view上控件的约束也不再以supview为准,而是以safe area为准。

safe area是在ios 9中添加的特性。如果你不需要使用safe area,或需要在旧版本的app中添加safe area,可以在xib或storyboard的右侧边栏中“show the file inspector”标签下对“use safe area layout guides”选项下进行勾选,以添加或删除safe area。

iOS11新特性之在你的APP中使用LargeTitle

添加refresh control

refresh control是系统的下拉刷新控件,配合table view使用,以实现系统的下拉刷新效果。

?
1
2
3
4
5
6
7
uirefreshcontrol *refreshcontrol = [[uirefreshcontrol alloc]init];
[refreshcontrol addtarget:self action:@selector(beginrefresh:) forcontrolevents:uicontroleventvaluechanged];
if (@available(ios 10.0, *)) {
 [self.tableview setrefreshcontrol:refreshcontrol];
} else {
 // fallback on earlier versions
}

刷新完成调用 - (void)endrefreshing ns_available_ios(6_0); 结束刷新状态。

search controller

添加搜索栏

?
1
2
3
4
5
6
if (@available(ios 11.0, *)) {
 uisearchcontroller *searchcontroller = [[uisearchcontroller alloc]initwithsearchresultscontroller:nil];
 self.navigationitem.searchcontroller = searchcontroller;
} else {
 // fallback on earlier versions
}

关于 search controller 的使用在此不再赘述。可参考官方sample code table search with uisearchcontroller

再说几句

由于large title及一些api仅在ios 11提供,所以在调用前均添加了判断,以防止低版本系统调用高版本api造成应用崩溃

?
1
2
3
4
5
if (@available(ios 10.0, *)) {
 // code...
} else {
 // fallback on earlier versions
}

在实际开发中,在viewcontroller上添加tableview实现效果不够理想,在滑动过程中有明显卡顿。而直接使用tableviewcontroller实现效果最为理想,滑动无卡顿现象。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:https://www.zlucy.com/archives/258/

延伸 · 阅读

精彩推荐
  • IOSIOS 屏幕适配方案实现缩放window的示例代码

    IOS 屏幕适配方案实现缩放window的示例代码

    这篇文章主要介绍了IOS 屏幕适配方案实现缩放window的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要...

    xiari5772021-06-01
  • IOSiOS 雷达效果实例详解

    iOS 雷达效果实例详解

    这篇文章主要介绍了iOS 雷达效果实例详解的相关资料,需要的朋友可以参考下...

    SimpleWorld11022021-01-28
  • IOS解析iOS开发中的FirstResponder第一响应对象

    解析iOS开发中的FirstResponder第一响应对象

    这篇文章主要介绍了解析iOS开发中的FirstResponder第一响应对象,包括View的FirstResponder的释放问题,需要的朋友可以参考下...

    一片枫叶4662020-12-25
  • IOSIOS开发之字典转字符串的实例详解

    IOS开发之字典转字符串的实例详解

    这篇文章主要介绍了IOS开发之字典转字符串的实例详解的相关资料,希望通过本文能帮助到大家,让大家掌握这样的方法,需要的朋友可以参考下...

    苦练内功5832021-04-01
  • IOSiOS布局渲染之UIView方法的调用时机详解

    iOS布局渲染之UIView方法的调用时机详解

    在你刚开始开发 iOS 应用时,最难避免或者是调试的就是和布局相关的问题,下面这篇文章主要给大家介绍了关于iOS布局渲染之UIView方法调用时机的相关资料...

    windtersharp7642021-05-04
  • IOSiOS中tableview 两级cell的展开与收回的示例代码

    iOS中tableview 两级cell的展开与收回的示例代码

    本篇文章主要介绍了iOS中tableview 两级cell的展开与收回的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    J_Kang3862021-04-22
  • IOSiOS通过逆向理解Block的内存模型

    iOS通过逆向理解Block的内存模型

    自从对 iOS 的逆向初窥门径后,我也经常通过它来分析一些比较大的应用,参考一下这些应用中某些功能的实现。这个探索的过程乐趣多多,不仅能满足自...

    Swiftyper12832021-03-03
  • IOS关于iOS自适应cell行高的那些事儿

    关于iOS自适应cell行高的那些事儿

    这篇文章主要给大家介绍了关于iOS自适应cell行高的那些事儿,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的...

    daisy6092021-05-17