IOS界面开发基础——Frame与Bounds

2024-09-06 00:48

本文主要是介绍IOS界面开发基础——Frame与Bounds,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

参考资料:http://blog.csdn.net/hherima/article/details/39501857


在IOS的UI开发中,经常需要对view进行定位。比较常用的概念就是Frame和Bound,通过view这两个属性,就可以任意的“摆弄”我们的view了。

这两个属性都可以定义view的位置和大小,但这两个属性之间有什么区别和联系呢?经过资料查找,记录如下:

Frame与Bounds的基本概念

首先,Frame与Bounds都是一个CGRect结构:

struct CGRect {CGPoint origin;CGSize size;
};

origin可以设置view的位置(x,y), size可以设置view的大小(width, height)。

那么,Frame和Bounds的区别可以分别在origin和size上讨论。

Frame与Bounds的origin

1、其坐标系系统不同。

  • Frame的origin坐标系是其父视图,即其x,y坐标是在其父视图语境中的。
  • Bounds的origin坐标系是在自身语境中的。
这里引用一下图片说明


2、Frame与Bounds的origin的作用不同。
  • Frame设置origin的作用在于对其在父视图中进行定位,比如你设置子view的frame的origin为(10,10),那么当子view被添加到父view中时,子view的位置就在父view坐标系的(10,10)处。
  • Bounds的origin作用,体现在对设置Bounds的view添加子view的时候,设置bounds的origin,会致使view的原点移位,即会对view的左上角坐标进行改变(默认view的左上角坐标为view的原点坐标(0,0))。当你对某个view(假设叫viewA)设置了bounds的origin后(这里我们假设设置为了-20,-15),那么view的左上角坐标也就变成了(-20,-15)。当再向viewA添加subView的时候(假设叫viewB),若设置viewB的frame的origin为(0,0),本来应该显示在viewA的左上角的,但此时viewA的左上角坐标为(-20,-15),那么这时候的(0,0)坐标就不在是viewA的左上角,而是如下图所示的地方。同时,可以对比两幅图,viewB的frame.origin均为(0,0),但viewA的bounds.origin不同而引起viewB最终的位置不同。


Frame与Bounds的size

相比origin,Frame与Bounds的size区别并没有那么大,他们均是作用于view自身,用来设置view的size大小,即width与height。当view的frame和bounds属性的size设置为一样大小时,那么这两个属性没任何区别。 但当frame与bounds的size不一样时,问题就来了:在后面设置的那个size会替换之前设置的size。即你可能期初设置bounds.size = (100,200),之后又设置frame.size=(30,10),那么view的实际size以后设置的那个size为准,即size为(30,10)。
除了这个准则外,还有一个要注意的是,若在设置了frame之后,再设置bounds,那么之前设置的frame.origin会因为本身view大小的改变而改变。具体规则为,frame会在左右(上下)位置均匀的增大(减小)相应的数值。
例如如下代码:
    _viewA = [[UIView alloc] init];CGRect rectA = CGRectMake(10, 60, 100, 100);_viewA.frame = rectA;_viewA.bounds = CGRectMake(0, 0, 200, 20);CGRect temp = _viewA.frame;

这时候,temp的值为

origin=(x=-40, y=100) size=(width=200, height=20)

之所以x=-40, 是因为viewA的width由100变为了200,viewA在左右方向各增大了50(合计100),那么,在x方向上,其坐标就是10-50 = -40.height由100减小为20,viewA在上下方向上各减小40,那么y方向上,其坐标为60+40=100.

总结一下,frame属性可以帮助我们在父视图中定位子视图,而bounds属性则主要用来设置本视图的原点坐标。至于size的大小,个人感觉统一大小即可,若在bounds和frame中设置不同的size,那么会照成一定的混乱,个人感觉没什么意思。

这篇关于IOS界面开发基础——Frame与Bounds的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1140528

相关文章

SpringBoot开发中十大常见陷阱深度解析与避坑指南

《SpringBoot开发中十大常见陷阱深度解析与避坑指南》在SpringBoot的开发过程中,即使是经验丰富的开发者也难免会遇到各种棘手的问题,本文将针对SpringBoot开发中十大常见的“坑... 目录引言一、配置总出错?是不是同时用了.properties和.yml?二、换个位置配置就失效?搞清楚加

CSS3打造的现代交互式登录界面详细实现过程

《CSS3打造的现代交互式登录界面详细实现过程》本文介绍CSS3和jQuery在登录界面设计中的应用,涵盖动画、选择器、自定义字体及盒模型技术,提升界面美观与交互性,同时优化性能和可访问性,感兴趣的朋... 目录1. css3用户登录界面设计概述1.1 用户界面设计的重要性1.2 CSS3的新特性与优势1.

Python中对FFmpeg封装开发库FFmpy详解

《Python中对FFmpeg封装开发库FFmpy详解》:本文主要介绍Python中对FFmpeg封装开发库FFmpy,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、FFmpy简介与安装1.1 FFmpy概述1.2 安装方法二、FFmpy核心类与方法2.1 FF

基于Python开发Windows屏幕控制工具

《基于Python开发Windows屏幕控制工具》在数字化办公时代,屏幕管理已成为提升工作效率和保护眼睛健康的重要环节,本文将分享一个基于Python和PySide6开发的Windows屏幕控制工具,... 目录概述功能亮点界面展示实现步骤详解1. 环境准备2. 亮度控制模块3. 息屏功能实现4. 息屏时间

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

使用Python开发一个现代化屏幕取色器

《使用Python开发一个现代化屏幕取色器》在UI设计、网页开发等场景中,颜色拾取是高频需求,:本文主要介绍如何使用Python开发一个现代化屏幕取色器,有需要的小伙伴可以参考一下... 目录一、项目概述二、核心功能解析2.1 实时颜色追踪2.2 智能颜色显示三、效果展示四、实现步骤详解4.1 环境配置4.

从基础到进阶详解Pandas时间数据处理指南

《从基础到进阶详解Pandas时间数据处理指南》Pandas构建了完整的时间数据处理生态,核心由四个基础类构成,Timestamp,DatetimeIndex,Period和Timedelta,下面我... 目录1. 时间数据类型与基础操作1.1 核心时间对象体系1.2 时间数据生成技巧2. 时间索引与数据

Python使用smtplib库开发一个邮件自动发送工具

《Python使用smtplib库开发一个邮件自动发送工具》在现代软件开发中,自动化邮件发送是一个非常实用的功能,无论是系统通知、营销邮件、还是日常工作报告,Python的smtplib库都能帮助我们... 目录代码实现与知识点解析1. 导入必要的库2. 配置邮件服务器参数3. 创建邮件发送类4. 实现邮件

安装centos8设置基础软件仓库时出错的解决方案

《安装centos8设置基础软件仓库时出错的解决方案》:本文主要介绍安装centos8设置基础软件仓库时出错的解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录安装Centos8设置基础软件仓库时出错版本 8版本 8.2.200android4版本 javas

基于Python开发一个有趣的工作时长计算器

《基于Python开发一个有趣的工作时长计算器》随着远程办公和弹性工作制的兴起,个人及团队对于工作时长的准确统计需求日益增长,本文将使用Python和PyQt5打造一个工作时长计算器,感兴趣的小伙伴可... 目录概述功能介绍界面展示php软件使用步骤说明代码详解1.窗口初始化与布局2.工作时长计算核心逻辑3