iOS UIView非常用方法及属性详解

run.jpg
1.在调用视图的drawRect:方法之前,UIKit 会自动对描画环境进行配置,使左上角成为坐标系统的原点,在这个环境中发生的 Quartz 调用都可以正确地在视图中描画。

2.视图对象通过 frame、 bounds、和 center 属 性声明来跟踪自己的大小和位置。frame 属性包含一个矩形,即边框矩形,用于指定视图相对于其父视图坐标系统的位置和大小。bounds 属性也包含一个矩形,即边界矩形,负责定义视图相对于本地坐标系统的位置和大小。虽然边界矩形的原点通常被设置为(0, 0),但这并不是必须的。center 属性包含边框矩形的中心点。

3.当您在代码中通过** initWithFrame:方法创建一个视图对象时,其frame** 属性就会被设置。该方法同时也将bounds 矩形的原点初始化为(0.0, 0.0),大小则和视图的边框相同。然后center 属性会被设置为边框的中心点。缺省情况下,视图的边框并不会被父视图的边框裁剪。如果您希望让一个视图裁剪其子视图,需要将其** clipsToBounds** 属性设置为YES。

4 .**UIView 类中包含一个 transform 属性声明,您可以通过它来对整个视图实行各种类型的平移、比例缩放、和变焦缩放效果。缺省情况下,这个属性的值是一个恒等变换,不会改变视图的外观。在加入变换之前,首先要得到该属性中存储的 CGAffineTransform 结构,用相应的Core Graphics 函数实行变换,然后再将修改后的变换结构重新赋值给视图的transform **属性。

5.视图的 contentMode 属性决定了边界变化和缩放操作作用到视图上产生的效果。缺省情况下,这个属性的值被设置为 UIViewContentModeScaleToFill,意味着视图内容总是被缩放,以适应新的边框尺寸。

6.不同的** UIViewContentMode** 常量(比如** UIViewContentModeTop** 和
UIViewContentModeBottomRight)可以使当前的内容在视图的不同角落或沿着视图的不同边界显示,还有一种模式可以将内容显示在视图的中心。

7.当您希望在应用程序中实现尺寸可调整的控件时,请务必考虑使用 内容模式。
内容模式通常有助于避免视图内容的描画,但是当您希望对缩放和尺寸调整过程中的视图外观进行特别的控制时,也可以使用 UIViewContentModeRedraw 模式

7.如果视图的** autoresizesSubviews** 属性声明被设置为YES,则其子视图会根据
autoresizingMask 属性的值自动进行尺寸调整。否则,应用程序就必须通过重载 layoutSubviews 方法来提供自己的实现。

8.如果要使一个视图和其父视图左下角的相对位置保持不变,可以加入 UIViewAutoresizingFlexibleRightMargin和
UIViewAutoresizingFlexibleTopMargin
常量,并将结果赋值给 autoresizingMask 属性。当同一个轴向有多个部分被设置为可变时,尺寸调整的裕量会被平均分配到各个部分上。

  • UIViewAutoresizingNone
    这个常量如果被设置,视图将不进行自动尺寸调整。
  • UIViewAutoresizingFlexibleHeight
    这个常量如果被设置,视图的高度将和父视图的高度一起成比例变化。否则,视图的高度将保持不变。
  • UIViewAutoresizingFlexibleWidth
    这个常量如果被设置,视图的宽度将和父视图的宽度一起成比例变化。否则,视图的宽度将保持不变。
  • UIViewAutoresizingFlexibleLeftMargin
    这个常量如果被设置,视图的左边界将随着父视图宽度的变化
    而按比例进行调整。否则,视图和其父视图的左边界的相对位
    置将保持不变。
  • UIViewAutoresizingFlexibleRightMargin
    这个常量如果被设置,视图的右边界将随着父视图宽度的变化
    而按比例进行调整。否则,视图和其父视图的右边界的相对位
    置将保持不变。
  • UIViewAutoresizingFlexibleBottomMargin
    这个常量如果被设置,视图的底边界将随着父视图高度的变化
    而按比例进行调整。否则,视图和其父视图的底边界的相对位
    置将保持不变。
  • UIViewAutoresizingFlexibleTopMargin
    这个常量如果被设置,视图的上边界将随着父视图高度的变化
    而按比例进行调整。否则,视图和其父视图的上边界的相对位
    置将保持不变。

9.如果您通过 Interface Builder 配置视图,则可以用Size 查看器的 Autosizing 控 制来设置每个视图的自动尺寸调整行为。上图中的灵活宽度及高度常量和Interface Builder 中位于同样位置的弹簧具有同样的行为,但是空白常量的行为则是正好相反。换句话说,如果要将灵活右空白的自动尺寸调整行为应用到Interface Builder 的某个视图,必须使相应方向空间的 **Autosizing **控制为空,而不是放置一个支柱。

10.如果视图的 autoresizesSubviews 属性被设置为 NO,则该视图的直接子视图的所有自动尺寸调整行为将被忽略。类似地, 如果一个子视图的自动尺寸调整掩码被设置为UIViewAutoresizingNone,则该子视图的尺寸将不会被调整,因而其直接子视图的尺寸也不会被调整。

11.视图层次中的父-子关系可以帮助我们定义应用程序中负责处理触摸事件的对象链

12.创建一个新的视图对象时,需要为其分配内存,并向该对象发送一个 initWithFrame:消息,以对其进行初始化。举例来说,如果您要创建一个新的 UIView 类的实例作为其它视图的容器,则可以使用下面的代码:

CGRect viewRect = CGRectMake(0, 0, 100, 100);
UIView* myView = [[UIView alloc]  initWithFrame:viewRect];

13.在iPhone 程序中,有两个地方最常用于创建视图和子视图, 它们是应用程序委托对象的 applicationDidFinishLaunching:方法和视图控制器的** loadView** 方法。

  • 调用父视图的 addSubview:方法来添加视图,该方法将一个视图添加到子视图列表的最后。
  • 调用父视图的 insertSubview:方法可以在父视图的子视图列表中间插入视图。
  • 调用父视图的** bringSubviewToFront: 、 sendSubviewToBack: 、或
    exchangeSubviewAtIndex:withSubviewAtIndex:**方法可以对父视图的子视图进行重新排序。使用这些方法比从父视图中移除子视图并再次插入要快一些。
    调用子视图(而不是父视图)的 removeFromSuperview 方法可以将子视图从父视图中移除。

创建一个带有视图的窗口

- (void) applicationDidFinishLaunching:(UIApplication *)application {
// Create the window object and assign it to the
// window instance variable of the application delegate.
window = [[UIWindow alloc] initWithFrame:[[ UIScreen mainScreen]  bounds]];
window. backgroundColor = [UIColor whiteColor];
// Create a simple red square
CGRect redFrame = CGRectMake(10, 10, 100, 100);
UIView *redView = [[UIView alloc] initWithFrame:redFrame];
redView.backgroundColor = [UIColor redColor];
// Create a simple blue square
CGRect blueFrame = CGRectMake(10, 150, 100, 100);
UIView *blueView = [[UIView alloc] initWithFrame:blueFrame];
blueView.backgroundColor = [UIColor blueColor];
// Add the square views to the window
[window addSubview:redView];
[window addSubview:blueView];
// Once added to the window, release the views to avoid the
// extra retain count on each of them.
[redView release];
[blueView release];
// Show the window.
[window makeKeyAndVisible];
}

14.当您为某个视图添加子视图时,UIKit 会向相应的父子视图发送几个消息,通知它们当前发生的状态变化。您可以在自己的定制视图中对诸如willMoveToSuperview: 、willMoveToWindow: 、 willRemoveSubview: 、 didAddSubview: 、didMoveToSuperview 和 didMoveToWindow这样的方法进行重载,以便在事件发生的前后进行必要的处理,并根据发生的变化更新视图的状态信息。

15.在视图层次建立之后,您可以通过视图的 superview 属性来取得其父视图,或者通过 subviews属性取得视图的子视图。您也可以通过 isDescendantOfView:方法来判定一个视图是否在其父视图的视图层中。一个视图层次的根视图没有父视图,因此其superview 属性被设置为nil。对于当前被显示在屏幕上的视图,窗口对象通常是整个视图层次的根视图。

UIView 类定义了下面这些方法,用于在不同的视图本地坐标系统之间进行坐标转换:

convertPoint:fromView:
convertRect:fromView:
convertPoint:toView:
convertRect:toView:

UIWindow 的版本则使用窗口坐标系统。

convertPoint:fromWindow:
convertRect:fromWindow:
convertPoint:toWindow:
convertRect:toWindow:

16.UIView 类中包含一个 tag 属性。借助这个属性,您可以通过一个整数值来标识一个视图对象。您可以通过这个属性来唯一标识视图层次中的视图,以及在运行时进行视图的检索(基于 tag 标识的检索比您自行遍历视图层次要快)。 tag 属性的缺省值为0。您可以通过UIView 的 viewWithTag:方法来检索标识过的视图

17.动画块从调用UIView 的 beginAnimations:context:类方法开始,而以调用 commitAnimations类 方法作为结束。在这两个调用之间,您可以配置动画的参数和改变希望实行动画的属性值。一旦调用commitAnimations 方法,UIKit 就会开始执行动画,即把给定属性从当前值到新值的变化过程用动画表现出来。动画块可以被嵌套,但是在最外层的动画块提交之前,被嵌套的动画不会被执行。

frame 视图的边框矩形,位于父视图的坐标系中。
bounds 视图的边界矩形,位于视图的坐标系中。
center 边框的中心,位于父视图的坐标系中。
transform 视图上的转换矩阵,相对于视图边界的中心。
alpha 视图的alpha 值,用于确定视图的透明度。
  • setAnimationStartDate:方法来设置动画在commitAnimations 方法返回之后的发生日期。缺省行为是使动画立即在动画线程中执行。
  • setAnimationDelay:方法来设置实际发生动画和commitAnimations 方法返回的时间点之间的间隔。
  • setAnimationDuration:方法来设置动画持续的秒数。
  • setAnimationCurve:方法来设置动画过程的相对速度,比如动画可能在启示阶段逐渐加速,而在结束阶段逐渐减速,或者整个过程都保持相同的速度。
  • setAnimationRepeatCount:方法来设置动画的重复次数。
  • 用** setAnimationRepeatAutoreverses:**方法来指定动画在到达目标值时是否自动反向播放。您可以结合使用这个方法和 setAnimationRepeatCount:方法,使各个属性在初始值和目标值之间平滑切换一段时间。

18.您可以通过UIViewsetAnimationDelegate: 类方法来设置委托, 并通过 setAnimationWillStartSelector: 和
setAnimationDidStopSelector:
方法来指定接收消息的选择器方法。

消息处理方法的形式如下:

- (void)animationWillStart:(NSString *)animationID context:(void *)context;

- (void)animationDidStop:(NSString *)animationID finished:(NSNumber*)finished context:(void*)context;

上面两个方法的animationID 和context 参数和动画块开始时传 beginAnimations:context:方法的参数相同:
animationID - 应用程序提供的字符串,用于标识一个动画块中的动画。
context - 也是应用程序提供的对象,用于向委托对象传递额外的信息。
setAnimationDidStopSelector:选择器方法还有一个参数—即一个布尔值。如果动画顺利完成,没有被其它动画取消或停止,则该值为YES

19.任何时候,当视图的布局发生改变时,UIKit 会激活每个视图的自动尺寸调整行为,然后调用各自的 layoutSubviews 方法,使您有机会进一步调整子视图的几何尺寸。

  • 您的应用程序调用视图的** setNeedsLayout 或 layoutIfNeeded** 方法来强制进行布局。
  • 您的应用程序调用视图背后的层对象的 setNeedsLayout 方法来强制进行布局。
  • 您也可以用 layoutSubviews 方法来调整作为子层链接到视图层的定制 CALayer 对象;

20.有些时候,应用程序数据模型的变化会影响到相应的用户界面。为了反映这些变化,您可以将相应的视图标识为需要刷新(通过调用 setNeedsDisplay 或 setNeedsDisplayInRect:方法
您可以通过改变视图的 hidden 属性声明来隐藏或显示视图

初始化一个视图的子类

- (id) initWithFrame:(CGRect)aRect {
self = [super initWithFrame:aRect];
if (self) {
// setup the initial properties of
the view
...
}
return self;
}

21.在iPhone OS 中,装载nib 的代码并不通过 initWithFrame:方法来实例化新的视图对象,而是通过NSCoding 协议定义的 initWithCoder:方法来进行。
drawRect:方法的一个简单实现,即在视图边界描画一个10像素宽的红色边界。由于UIKit 描画操作的实现也是基于Quartz,所以您可以像下面这样混合使用不同的描画调用来得到期望的结果。

- (void)drawRect:(CGRect)rect {
CGContextRef context =  UIGraphicsGetCurrentContext();
CGRect myFrame = self.bounds;
CGContextSetLineWidth(context, 10);
[[UIColor redColor] set];
UIRectFrame(myFrame); 
// 捣鼓来捣鼓去,搞得复杂!!!
}

处理触摸事件的视图通常需要实现下面的所有方法

touchesBegan:withEvent:
touchesMoved:withEvent:
touchesEnded:withEvent:
touchesCancelled:withEvent:

22.激活多点触摸事件:** multipleTouchEnabled** 属性声明设置为YES
您可以通过改变视图的 userInteractionEnabled 属性值来控制视图是否可以对事件进行处理。还可以使用UIApplication 对象的 beginIgnoringInteractionEvents 和 endIgnoringInteractionEvents 方法

23.UIKit 会通过UIView 的 hitTest:withEvent:和 pointInside:withEvent:方法来确定触摸事件是否发生在指定的视图上。


随手点个喜欢 吧 ~

关注我

QQ -- iOS 交流群 :107548668

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

推荐阅读更多精彩内容