UIView基础控件

Framework:
Framework是一种打包方式,将编译后的二进制文件以及头文件和相关的资源打包放在一个头目录下,方便分发给其他开发者进行使用

ios主要框架介绍:
Cocoa Touch 框架:
是一个框架的集合,包含了很多子框架。苹果根据功能将子框架分为四层:

Cocoa Touch Layer
Media Layer
Core Services Layer
Core Os Layer

UIKit Framework:
隶属于Cocoa Touch Layer层中。

UILabel/UIImage介绍:
UIImage用来显示图片,UILabel用来显示文本。都继承于UIView。

UIButton:
包含UILabel和UIImageView两个属性,继承于UIControl,然而UIControl继承于UIView。可以对点击事件进行处理。

UIViewController:
继承自UIResponder。

UIView布局(一):

布局就是告诉系统每个元素的位置以及元素高与宽的信息。

iPhone设备屏幕信息:


Point:
iPhone 3GS:1point=1pixels
iPhone4(s)/5(s)/6(s)/7(s)/SE:1point=2pixels
iPhone6(s)/7(s)plus:1point=3pixels

想更深入了解屏幕物理尺寸及屏幕分辨率对显示效果的影响,可以了解下以下几个概念:

  1. 屏幕的物理长度:使用英寸作为单位, 是指手机屏幕对角线的物理长度(diagonal)

  2. 屏幕像素:这里的像素可以想象成屏幕上真正用来显示颜色的发光小点。

  3. PPI(Pixel Per Inch by diagonal):表示沿着对角线,每英寸所拥有的像素(Pixel)数目。

PPI 计算方式:

屏幕像素: width -- 320px, height -- 480px

屏幕物理长度:length -- 3.5英寸

Apple对 iPhone 6 Plus、iPhone 6s Plus、iPhone 7s Plus 的屏幕分辨率做了特殊处理,物理尺寸与屏幕像素比例实际上只有2.46倍,并没有达到3倍,但是仍然使用了3x模式进行屏幕适配。这是因为 Apple 并没有像当年说服康宁那样说服LCD生产商生产@3x的2208x1242分辨率的屏幕。

UIView坐标系:
原点在屏幕左上角。

与UIView布局相关的几个属性 frame/bounds/center:


修改父View的frame.origin的值,移动了父view的位置,子view在父view中的位置没有修改,只能影响当前view的位置。
view.center表示当前view在父view中的位置。
修改父view的bounds.origin的值,父view的位置没有修改,影响了子view在父view中的位置,但是相应的位置信息没有修改。修改子view的bounds.origin,没有影响父view的位置。
修改父view的frame.size值,只影响当前view相对于左上角的高宽大小。
修改父view的bounds.size值,父view的位置进行了移动。中心位置不变,向四周扩大或缩小。影响了子view在父view的位置,但是相应的位置信息没有修改。修改子view的bounds.size没有影响父view的位置信息,但是影响了子view的位置信息。

frame 和 bounds
在学习iOS界面基础的时候,bounds把我整的云里雾里的,但是查了相关资料后,总算弄懂了。

frame:该view在父view坐标系统中的位置和大小。(参照点是父坐标系统)
bounds:该view在本地坐标系统中的位置和大小。(参照点是自身的坐标系统)
frame(CGRect)origin 在父视图中距离原点的位置size 距离当前视图左上角的大小
center(CGPoint)当前视图的中心点在父视图中的位置
bounds(CGRect)origin 当前视图的左上角距离自身坐标系的原点的位置。移动时,移动的是自身的坐标系统,视图本身不移动size 当前视图在自身坐标系的高和宽。改变大小时,center相对于父坐标系统的位置不变,而图像跟自身坐标系一起改变。此时,由于自身坐标系统的改变,会导致子视图位置发生移动。

frame的绝对定位布局:


frame + autoresizing相对布局:
取消file inspector中use auto layout勾选


autoresizing只能设置两个父子视图之间的相对位置关系。

AutoLayout布局:
通过添加约束对象,可以设置任何控件之间的关系。约束对象指的是同一层级控件之间的关系。

UIView布局方式总结:
frame绝对定位布局
frame+autoresizing相对布局
autolayout布局

基础控件实战:

视觉稿及需求分析:
点击登录,显示loading,验证登录信息
验证成功,进入我的主页
输入文字,点击发布,在当前页面显示。

界面的实现方式:
纯代码
Interface Builder

Interface Builder介绍:
nib(NeXT Interface Builder) //采用二进制格式,不方便进行版本控制。
xib(XML Interface Builder) //工程编译的时候将xib文件转换为nib。[UINib class];
storyboard //ios5之后推出的。[UIStoryboard class];

界面跳转:
storyboard中vc跳转优先级高于代码中的跳转vc。
Button Action

  • (void)presentViewController:(UIViewController *)viewControllerToPresent animated: (BOOL)flag completion:(void (^ __nullable)(void))completion

Storyboard

  • (void)performSegueWithIdentifier:(NSString *)identifier sender:(nullable id)sender

  • (BOOL)shouldPerformSegueWithIdentifier:(NSString *)identifier sender:(nullable id)sender NS_AVAILABLE_IOS(6_0);

xib文件与Class关联:
File’s Owner->Custom Class
xib—————————————>类文件
UIView->Custom Class

File’s Owner:关联View与ViewController root view的关系
CustomView *newView = [ [ [NSBundle mainBundle] loadNibNamed:[nibName] owner:[newView instance] options:nil] firstObject];

UIView Class:自定义UIView对象
CustomView *newView = [ [ [NSBundle mainBundle] loadNibNamed:[nibName] owner:nil options:nil] firstObject];

用代码加载指定的xib文件:
[ [ NSBundle mainBundle ] loadNibNamed:[ nibName ]
owner:nil options:nil ];

加载 xib 文件有两种方式:
[[NSBundle mainBundle] loadNibNamed: owner: options:];
[UINib nibWithNibName: bundle:];

xib 文件在iOS中做为资源文件存在,因此可以使用NSBundle的方式进行加载。

在iOS4.0以后新增了[UINib class] 用于加载nib资源文件。

UILable高度计算:
方法一:
[ UIView Class ]

  • (CGSize)sizeThatFits: (CGSize) size
    当宽度固定,高度不限时自动换行。代码如下:
    CGSize labelSize = CGSizeMake(labelA.width, CGFLOAT_MAX);
    [ labelA sizeThatFits:labelSize ];
    方法二:
    [ NSString Class ]
  • (CGRect)boundingRectWithSize:(CGSize)size
    options:(NSStringDrawingOptions)options
    attributes:(nullable NSDictionary<NSString * , id>*)attributes
    context:(nullable NSStringDrawingContext * )context
    代码如下:
    CGSize labelSize = CGSizeMake(labelA.width, CGFLOAT_MAX);
    [ labelA.text boundingRectWithSize:labelSize
    options:NSStringDrawingUsesLineFragmentOrigin
    attributes:@{NSFontAttributeName:labelA.font}
    context:nil ]
    方法三:

在给视图添加边界约束时,可以选择是否勾选Constrain to margins。

在图1中,当勾选Constrain to margins时,添加右侧边界约束时,实际约束对象建立的是NSLayoutAttributeTrailingMargin 边界约束(如图2);

当不勾选Constrain to margins时,添加右侧边界约束,实际约束对象建立的是NSLayoutAttributeTrailing 边界约束 (如图3)。

在NSLayoutAttribute 枚举中,各条边都有对应的Margin边界枚举值

NSLayoutAttributeLeft / NSLayoutAttributeLeftMargin

NSLayoutAttributeRight / NSLayoutAttributeRightMargin

NSLayoutAttributeTop / NSLayoutAttributeTopMargin

NSLayoutAttributeBottom / NSLayoutAttributeBottomMargin。

......

在iOS8中,约束对象的内容区域其实是一个盒模型,包含了内边缘与外边缘。如下图。

通常情况下我们都是使用内容区域的内边缘设置内容的大小。

在可视化界面中 建立约束,取消勾选Constrain to margins时,表示创建的约束对象边界为内边缘(即内容边界),对应的约束边界属性为NSLayoutAttributeLeft/Right/Top/Bottom。

但是勾选Constrain to margins时,创建的约束对象边界为外边缘(即内容边界+系统定义的内容边缘间距),会默认增加内外边缘的间距,对应的约束边界属性为NSLayoutAttributeLeftMargin/RightMargin/TopMargin/BottomMargin。

可以用 layoutMargins 或者 layoutMarginsGuide 属性 获取视图的内外边缘间的 margin 值。

每一个视图UIView的默认 margin 值是8,可以根据需要进行修改。

但是系统给 ViewController的rootView 根视图设置的margin,上下margin为0,左右margin为20(Xcode8中为 16),根视图的 margin值不能修改。

绘制我的主页界面

UIView动画

+ (void)animateWithDuration:(NSTimeInterval)duration animations:(void (^)(void))animations NS_AVAILABLE_IOS(4_0); // delay = 0.0, options = 0, completion = NULL
NSLayoutAttributeLeft :内容左侧
NSLayoutAttributeRight:内容右侧
NSLayoutAttributeLeading:内容头部
NSLayoutAttributeTrailing:内容尾部

通常情况下,在大部分语言体系中都是从左往右进行阅读:
    NSLayoutAttributeLeft 与 NSLayoutAttributeLeading 都表示内容左侧
    NSLayoutAttributeRight 与 NSLayoutAttributeTrailing 都表示内容右侧

但是在部分特殊语系中 (比如阿拉伯语),从右往左进行阅读,这时内容的的头部在右侧,尾部在左侧
     NSLayoutAttributeLeft 与 NSLayoutAttributeTrailing 都表示内容左侧
    NSLayoutAttributeRight 与 NSLayoutAttributeLeading 都表示内容右侧

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

推荐阅读更多精彩内容