iOS View Controller 全屏布局

2023-10-26

iOS View Controller 全屏布局

2014-09-08

自 iOS 7 以后苹果开始默认对 View Controller 采用全屏布局,全屏布局的意思就是 View Controller 的 layout 是填满整个屏幕的,这在 View Controller 界面中有 Status Bar(20)、Navigation Bar(44)、Tab Bar(49)、Tool Bar(44) 的时候与以往的布局方式有着明显的差异。全屏布局的情况下,View Controller 的 layout(self.view) 会被盖在这些 Bar 下面。

image

伴随着全屏布局,iOS 7 以后 View Controller 添加了几个相关的属性来方便我们来做页面布局:

  
  
  1. @property (nonatomic,assign) UIRectEdge edgesForExtendedLayout NS_AVAILABLE_IOS(7_0); // Defaults to UIRectEdgeAll
  2. @property (nonatomic,assign) BOOL extendedLayoutIncludesOpaqueBars NS_AVAILABLE_IOS(7_0); // Defaults to NO, but bars are translucent by default on 7_0.
  3. @property (nonatomic,assign) BOOL automaticallyAdjustsScrollViewInsets NS_AVAILABLE_IOS(7_0); // Defaults to YES

通过 edgesForExtendedLayout 这个属性来设置你的 View Controller 页面的哪一侧会延伸至屏幕边缘。可选值有:UIRectEdgeNone、UIRectEdgeTop、UIRectEdgeLeft、UIRectEdgeBottom、UIRectEdgeRight、UIRectEdgeAll。默认值是 UIRectEdgeAll,即 View Controller 的布局是全屏填满。

在有 NavigationBar、TabBar、TooBar 等系统 Bar 的情况下,该属性设置为 UIRectEdgeAll 时,View Controller 的页面会被这些 Bar 盖住部分;而当该属性设为 UIRectEdgeNone 的时候,View Controller 的页面布局会限制在这些 Bar 之间。

我们可以在 View Controller 的 - (void)viewWillLayoutSubviews 方法中打印出 self.view 的 frame 来观察这个属性带来的影响。我们以 iPhone 4s 的 320*480 的屏幕尺寸为例:

  • 设置 edgesForExtendedLayout 为 UIRectEdgeAll,不管是有 NavigationBar、TabBar、TooBar 哪一种 Bar,self.view 的 frame 均为 (0, 0, 320, 480)。
  • 设置 edgesForExtendedLayout 为 UIRectEdgeAll:
    • 有 NavigationBar 和 TabBar,self.view 的 frame 为 (0, 64, 320, 367)。即 self.view 的布局的起点从 NavigationBar 下开始,高度去掉了 StatusBar、NavigationBar 和 TabBar 的高度:20、44、49。
    • 有 NavigationBar 和 ToolBar,self.view 的 frame 为 (0, 64, 320, 372)。即 self.view 的布局的起点从 NavigationBar 下开始,高度去掉了 StatusBar、NavigationBar 和 ToolBar 的高度:20、44、44。

需要注意的是:如果你在 - (void)viewDidLoad 方法中观察 self.view 的 frame 得到的结果始终是 (0, 0, 320, 480),可见这个值的不对的,所以当我们需要对页面进行布局时正确的方式是在 - (void)viewWillLayoutSubviews 中处理。

extendedLayoutIncludesOpaqueBars 这个属性是对 edgesForExtendedLayout 的补充。它的意思当 NavigationBar、TabBar、TooBar 这些 Bar 不是半透明时(Bar 的 translucent 属性值为 NO),如果设置 extendedLayoutIncludesOpaqueBars 为 NO,则不会将 View Controller 的页面布局延伸至全屏,如果设置为 YES,则坚持延伸至全屏。

从 iOS 7 开始,NavigationBar、TabBar、TooBar 这些 Bar 默认都是半透明的,这时这个属性不会起到效果。

当我们采用全屏布局设置了 edgesForExtendedLayout 为 UIRectEdgeAll,而此时 View Controller 的 self.view 的第一个 Subview 是 UIScrollView 类型或其子类型(如:UITableView 等)时,automaticallyAdjustsScrollViewInsets 这个属性就会被用来辅助我们对 UIScrollView 类的视图进行布局。automaticallyAdjustsScrollViewInsets 默认值即为 YES。

拿 UITableView 来举例,你希望你的 UITableView 的内容从 NavigationBar 底部开始展示(因为不这样的话就会被 NavigationBar 遮住一部分),同时还需要在滑动时,UITableView 的布局又能填满全屏。这时你只需要设置 automaticallyAdjustsScrollViewInsets 为 YES 即可,系统会帮你调整 UITableView 的 contentInset 来实现效果使其中的内容不会被 NavigationBar、TabBar、TooBar 挡住。你可以同样在 - (void)viewWillLayoutSubviews 观察 UITableView 的 contentInset 的值。

当你设置它为 NO 时,UITableView 的 contentInset 则不会被被设置。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

iOS View Controller 全屏布局 的相关文章

  • 做好自动化测试必备的5大技能,懂一个就超过了85%的人

    或许还有一些人认为软件测试的门槛很低 低到任何人都可以做 随便点点就可以了 这里需要澄清一下 不管哪一类测试岗位 如果做深做精都需要下功夫 只是精通的方向不同 试问一下如果让一个什么都不懂 一点业务基础都没有的人去做测试 能测出来问题吗 不
  • 深度学习相关资料总结

    近这两年里deep learning技术在图像识别和跟踪等方面有很大的突破 是一大研究热点 里面涉及的数学理论和应用技术很值得深入研究 这里总结一些在微博发布和转载的相关资料 以便查阅 一 winsty NIPS2013 Learning
  • BI可视化在线分析工具,推荐这2个BI工具!

    一 国外BI tableau BI平台Tableau帮助企业可视化和理解数据 它使组织能够通过PC或iPad连接 可视化和共享数据 用户可以轻松创建仪表板 发布甚至与同事 合作伙伴和客户共享 所有这些都无需编程知识 该软件可以连接到众多信息
  • Software--Spring Boot--Contact 项目初期

    Spring Boot 简介 提供了四个主要的特性 能够改变开发Spring应用程序的方式 Spring Boot Starter 将常用的依赖分组进行整合 将其合并到一个依赖中 可以以此行添加到项目的Maven或Gradle构建中 自动配
  • Web Service接口测试

    Web service 接口测试 一 web Service概念 Web service使用与平台和编程语言无关的方式进行通讯的一项技术 web service 是一个接口 他描述了一组可以在网络上通过标准的XML消息传递访问的操作 它基于
  • 刷个宇宙题:剑指 Offer II 008 和大于等于target的最短子数组、 009. 乘积小于 K 的子数组

    008 题目 解题 用的双指针 没有理解前缀法 二分法 009 乘积小于 K 的子数组 解题 滑动窗口
  • SQL增删改操作

    一 增加插入 第一种形式无需指定要插入数据的列名 只需提供被插入的值即可 INSERT INTO table name VALUES value1 value2 value3 第二种形式需要指定列名及被插入的值 INSERT INTO ta
  • 28_计算机网络(Computer Networks)基础

    本篇介绍计算机网络的基础知识 文章目录 1 计算机网络历史 2 以太网 Ethernet 2 1 以太网 Ethernet 的简单形式及概念 2 2 指数退避解决冲突问题 2 3 利用交换机减少同一载体中设备 2 4 互联网 The Int
  • 基于 SpringBoot + MyBatis 实现点餐系统

    点餐系统的实现页面详情 1 管理员登录页面 2 管理员菜品页 3 管理员查看订单页 4 订单详情页 5 普通用户页面 6 普通用户下单页面 7 普通用户订单页面 1 创建数据库和表 CREATE DATABASE IF NOT EXISTS
  • 安卓手机安装google套件的详细步骤

    前言 谷歌三件套大概就是google service framework 谷歌服务框架 google play service google play store 这里介绍一下如何安装这三个软件 对华为手机可能无效 请谨慎尝试 三个软件各自
  • SpringBoot——整合MyBatis

    前情回顾 在开始介绍SpringBoot整合MyBatis之前 我们先来复习一下在Spring中整合MyBaits是如何来做的 其中的核心思想是将MyBatis中的SqlSession对象交给Spring去管理 并且Spring提供了一个M
  • ICLR 2023

    PaperWeekly 原创 作者 叶振辉 单位 浙江大学博士生 研究方向 语音合成 说话人视频合成 语音驱动的说话人视频合成 Audio driven Talking Face Generation 是虚拟人领域的一个热门话题 它旨在根据
  • 67.二进制求和 C++

    给你两个二进制字符串 a 和 b 以二进制字符串的形式返回它们的和 示例 1 输入 a 11 b 1 输出 100 示例 2 输入 a 1010 b 1011 输出 10101 提示 1 lt a length b length lt 10
  • stable diffusion图片资源分享和模型推荐,好用的模型有哪些呢?

    前言 这篇文章主要是分享我的图片和推荐一些好用的模型 模型不在多在于精 基于几个好的大模型适当下载一下LORA模型 就能画出非常好的图片 多话不说 图片分享 简单展示 详情请看 https space bilibili com 109890
  • 编程艺术 - 第二章 、俩个字符串是否包含问题以及扩展

    1 题目 假设这有一个各种字母组成的字符串 假设这还有另外一个字符串 而且这个字符串里的字 母数相对少一些 从算法是讲 什么方法能最快的查出所有小字符串里的字母在大字符串里 都有 比如 如果是下面两个字符串 String 1 ABCDEFG
  • 串联型PID,并联型PID与标准型PID简要说明

    串联型PID 并联型PID与标准型PID简要说明1 PID广泛应用于工业生产各个环节 然而对于不同PID结构会有一些差异 导致在调参时若按照常规的经验调试 结果将会有非常大的不同 串联型PID Serial PID 串联型PID的三个环节由

随机推荐

  • JMeter安装配置

    JMeter安装配置 安装小记 1 JMeter下载 2 环境变量配置 安装小记 1 JMeter下载 直接下载的链接 https download csdn net download weixin 43554548 80965649 官网
  • 一份简短又全面的数学建模技能图谱:常用模型&算法总结

    声明一下 下述内容的多数链接出自一本教材 司守奎 数学建模算法与应用 第二版的PDF版本 改成转载需要给出原创链接 实属无意冒犯 pdf版教材链接 百度网盘 https pan baidu com s 1TEYSW5ZImQU4Sy7Om2
  • 利用 Python 结合 UI 来模拟实现多人聊天

    一 界面功能展示 1 设置一个通信 用户1 2 设置通信 用户2 3 进入聊天功能界面 4 发送信息来实现实时通信 二 代码实现 1 服务器端 服务器需要能够与客户机进行直接通信 客户机之间不需要能够通信 服务器需要配置监听的IP 0 0
  • Qt5开发工具---常用Qt5开发工具(附下载地址)

    文章目录 一 简述 二 Qt界面开发工具 1 QT设计师 三 Qss控件美化工具 1 QSS Editor 2 Qss Stylesheet Editor 3 qtawesome icon broswer 四 官方文档 1 Qt官方文档 2
  • react如何实现数据渲染

    React数据渲染是指将组件中的数据映射到页面上 以展示出来 在React中 数据渲染通常是通过JSX和组件的state或props完成的 JSX是一个类似HTML的语法 可以在其中嵌入JavaScript表达式 在JSX中 可以使用 包裹
  • 关于数据库意向锁与封锁粒度若干问

    我们所说的加锁是谁对谁加锁 是事务T对某个封锁对象加锁 封锁对象的大小被称为封锁的粒度 这个对象可以是数据库 关系 也可以是元组 为什么要引入多粒度锁协议 封锁粒度大 系统被封锁的对象越少 并发度越小 系统开销越小 封锁粒度越小 系统被封锁
  • DB2:”因为未能分配专用虚拟内存,所以请求失败“错误的解决方法

    是在创建数据库的时候遇到的这个问题 解决方法作个记录 SQL1219N 因为未能分配专用虚拟内存 所以请求失败 SQLSTATE 57011 解决方法 1 DOS命令行中执行 db2set DB2 EXTSECURITY NO 2 重启DB
  • feign在DTO传参时GET请求自动转成POST请求

    文章目录 场景 解决 场景 1 网关请求发送到后端从GET变成了POST 2 代码如下 使用openfeign发请求时 发现GET请求转成了POST FeignClient name pd auth server fallback Reso
  • Java 程序员必须了解的 7 个性能指标

    来源 王韵菲 www evget com article 2015 11 16 22990 html 本文中 小编搜集了7个最有影响的衡量标注 让你可以不依赖日志文件来了解应用程序 现在 让我们看看这些性能指标 并了解如何查看并收集它们 1
  • linux 服务器搭建 elasticsearch(一)

    1 安装java jdk 环境 查看可安装版本 yum y list java 选择一个java版本进行安装 这里我们希望安装java1 8 因为我们的机器是64位的 所以选择安装java 1 8 0 openjdk devel x86 6
  • Linux编程复习(3)——信号与中断

    信号是响应某些状况而产生的事件 进程在接收到信号时会采取相应的行动 某些状况就是指某些条件错误 如内存段冲突 浮点处理器错误或者非法指令等 信号是在软件层次上对中断的一种模拟 所以信号也称为是软中断 信号与中断的相似点 1 都采用相同的额异
  • OpencvX.X中Mat与IplImage类型的相互转换

    1 Opencv4 x中Mat与IplImage的转换 1 Mat转IPLImage IplImage img cvIplImage mat 2 IplImage转Mat Mat cvarrToMat const CvArr arr boo
  • 从异步调用返回响应:多语言指南

    Asynchronous调用是现代编程的基础 可以有效地处理可能需要时间的任务 例如网络请求或文件操作 然而 response从这些asynchronous电话中获取信息可能会让新手感到困惑 在本指南中 我们将探讨如何从不同编程语言的异步调
  • 4款堪称神器的电脑黑科技软件,让人相见恨晚

    Syncthing 一款免费的开源跨平台文件同步客户端 服务器工具 支持Linux Windows OSX FreeBSD以及Solaris等系统 具有一个强大的响应式的网页管理界面 能够帮助用户简便地添加 删除和管理通过网络进行同步的文件
  • TX2上如何查看cuda版本

    如果知道安装的路径 一般都是在local下 可以直接查看 nvidia tegra ubuntu cat usr local cuda version txt CUDA Version 9 0 252 能看到机器上的CUDA版本是9 0 2
  • 国家级、省、市专精特新申报条件汇总

    国家级专精特新硬性条件 1 企业成立3年及以上 2 企业从业人员1000人以下或营业收入40000万元以下 3 已认定为省级专精特新 不硬性规定 有优先推荐权 4 截至上年末的近2 年主营业务收入或净利润的平均增长率达到5 以上 企业资产负
  • 构建方便安全的HttpClient工具类

    构建方便安全的HttpClient工具类 前言 开始 引入核心依赖 其它依赖 封装工具类 1 UrlEntity 2 HttpClientException 3 IoUtil 4 UrlUtil 5 SingletonUtil 开始构建 6
  • C语言—随机种子的设定

    计算是CPU和内存进行交互 运算是很快的 打印时CPU 内存和显示器进行交互 运算较慢 计算机在访问输入输出设备的时候 运算速度会大大降低 1 计算 n 的阶乘 int factor int n int result 1 for int i
  • 从gitHub当中更新项目synchronize Update fetch pull 项目的区别

    从gitHub更新项目 马克 to win 马克 java社区 防盗版实名手机尾号 73203 马克 to win 方法一 右击你的项目 team synchronize workspace 这样他就会去gitHub那fetch回最新的版本
  • iOS View Controller 全屏布局

    iOS View Controller 全屏布局 2014 09 08 自 iOS 7 以后苹果开始默认对 View Controller 采用全屏布局 全屏布局的意思就是 View Controller 的 layout 是填满整个屏幕的