GeekBand-IOS实战第三周笔记(应用页面布局&系统UI组件)

页面布局

View的定位

View界面层次

  • UIScreen->UIWindow->rootViewController.view->我们设置的view
  • 左边的view是右边下一个view的父view,界面显示的总是最上面的view,也就是辈分最小的view

UIKit坐标系

  • 原点在屏幕左上角,如图:


    UIKit坐标系.png
  • 图中三个函数分别描述的是点、线、面,在描述面时,我们使用origin来表示该面的左上角的点坐标

View定位

  • frame={origin:{x,y},size:{w,h}},该属性描述的面是在父view的坐标系中
  • bounds={origin:{x,y},size:{w,h}},该属性描述的面是在当前view的坐标系中
    这么说可能不太好理解,bounds的点坐标一般是{0,0},无论该view在哪儿,它的左上角就是{0,0},但frame的左上角坐标需要参考父view.bounds的坐标,先在rootViewController.view上设置一个子view,看图:


    View定位-bounds.png

    假如我把rootViewController.view.bounds.origin修改为{40,160},大家猜会发生什么,


    bounds.gif

    这是为什么呢?原来子view根据父view的bounds确定自己的位置,子view.frame.origin为{40,160},结果他就去父view中寻找这个坐标,而父view中这个坐标在原点,它就自然而然跑到原点了。
  • center=CGPoint{x,y},这个坐标是相对于父view的
    如果修改子view.bounds.size,center不变。子view会根据center的坐标和size来确定自己在父view中的位置,也就是说从中心点放大或缩小,子view.frame自动变化。

View.transform

  • CGAffineTransform transform(平移、旋转、缩放)
  • 图形变换在当前view绘制代码执行之前添加到图形绘制环境里(不理解)
  • 子视图总是在上级视图变换过的环境里绘制自己

界面旋转

  • UIApplication先根据Info.plist的信息确定该不该旋转,怎么旋转
  • 顶层可视View Controller被询问支不支持旋转,然后做相应动作
  • 注意:所有的view Controller需要声明自己支持旋转的方向与现在应该旋转的方向保持一致

Autoresizing

界面布局过程

  • -layoutSubviews,在view重排之前会收到这个消息
  • -setNeedsLayout,一般不直接像view发送-layoutSubviews这个方法,而是通过-setNeedsLayout来实现,它在下次绘制之前重新推算布局,节省资源
  • -layoutIfNeeded,如有需要,立即重新推算布局

布局需求

主要是确定界面元素之间的间距

  • 固定间距:柱子(struts)
  • 按比例调整间距:弹簧(springs)

UIView.autoresizingMsak

  • flexible对应弹簧,没有指定的话,默认为fixed(固定)


    UIView.autoresizingMask.png

在xcode中尝试Autoresizing

先把view controller的autoLayout关掉:


准备工作.png

如图,几个属性试过之后就明白了,简单明了:


Autoresizing练习.png

控制Autoresizing

  • 从nib中加载的view都默认实现了Autoresizing
  • 代码创建的view却是空空如也


    Autoresizing.png

Autolayout

Autolayout基础

Autolayout基础.png

Autolayout开关

Autolayout开启关闭.png

Autolayout思想

其实关键的就是约束,与父视图或者其他控件的约束。

  • 有自己固定大小的控件,我们只需要确定其位置,例如Button
  • 还有一些,例如ImageView需要我们给定位置和大小
  • 当约束线为红色代表约束不够确定该控件位置,黄色代表与现有位置不匹配,蓝色说明正确约束了该控件,且现有位置在该控件被约束的位置

Autolayout优先级

在有些时候我们需要用到优先级,例如一个控件在5.5寸和3.5寸屏显示上,frame位置不应该固定,应该按比例调整。还有例如textfiled我们希望它在大的显示屏上更大,用优先级都是可以做到的,不过操作比较繁琐,优点是可以精确定位。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容