UI控件之UIView与动画

UIView:用来展示用户的界面,响应用户的操作(继承自UIResponder)

UIView的作用:绘图、动画、处理事件

UIView可以包含和管理子视图,并且决定子视图的位置大小

 

获取所有的子视图(数组)

NSArray *subViews= self.window.subviews;

 

将子视图放在某个子视图上面

[self.window insertSubview:greenView aboveSubview:yellowView];

 

将子视图放在某个子视图下面

[self.window insertSubview:greenView belowSubview:blueView];

 

将子视图放在某个下标位置处

[self.window insertSubview:greenView atIndex:2];

 

将某个子视图移到最上层

[self.window bringSubviewToFront:redView];

 

将某个子视图移到最底层

[self.window sendSubviewToBack:blueView];

 

设置是否允许父视图裁剪子视图(子视图比父视图大时)

blackView.clipsToBounds=YES;

 

设置是否允许在父视图尺寸变化时自动调整子视图的尺寸

blackView.autoresizesSubviews=YES;

 

设置子视图的调整模式,自动调整子视图的高度和宽度

topView.autoresizingMask=

UIViewAutoresizingFlexibleHeight|UIViewAutoresizingFlexibleWidth;

 

获取父视图

UIView *parentView= subView.superview;

 

将topView从父视图中移除(删除视图topView)

[topView removeFromSuperview];

 

UIView动画有2种:

 属性动画:frame、bounds、center、backgroundColor、alpha、transform

 翻转动画:实现方式2种:iOS4.0之前:采用[]设置;iOS4.0之后:采用block实现

 

1.iOS4.0之前:采用[]设置

 

开始设置动画,第一个参数是动画名字,第二个参数是对象,一般为nil

[UIView beginAnimations:@"animation" context:nil];

 

设置动画的持续时间

[UIView setAnimationDuration:1];

 

设置动画开始的延迟时间

[UIView setAnimationDelay:0];

 

设置动画重复次数

[UIView setAnimationRepeatCount:1];

 

设置动画模式

[UIView setAnimationCurve:UIViewAnimationCurveLinear];

    UIViewAnimationCurveEaseIn:动画开始时效果缓慢

    UIViewAnimationCurveEaseOut:动画结束时效果缓慢

    UIViewAnimationCurveEaseInOut:动画开始和结束时效果缓慢

    UIViewAnimationCurveLinear:动画的平滑效果

    

设置代理,采用执行下面2个方法

[UIView setAnimationDelegate:self];

 

设置动画结束后执行的选择器方法

[UIView setAnimationDidStopSelector:@selector(buttonClick:)];

 

设置动画开始之前执行的选择器方法

[UIView setAnimationWillStartSelector:@selector(buttonClick:)];

 

设置图片视图的中心点

imageView.center=CGPointMake(300, 600);

 

设置图片视图的透明度

imageView.alpha=0.1;

 

设置缩放比例值

imageView.transform=CGAffineTransformMakeScale(1.5, 1.5);

 

在imageview原来的transform值基础上宽度高度放大为1.5被再赋给imageview,连续放大

imageView.transform=CGAffineTransformScale(imageView.transform, 1.5, 1.5);

 

设置旋转动画,每次旋转90度

imageView.transform=CGAffineTransformRotate(imageView.transform, M_PI_2);

 

动画开始

[UIView commitAnimations];

 

2.iOS4.0后用block实现属性动画

 

可以设置动画的持续时间和动画内容

[UIView animateWithDuration:1 animations:^{ }];

 

设置动画的持续时间、动画内容和动画结束后执行的语句

[UIView animateWithDuration:2 animations:^{} completion:^(BOOL finished) {}];

 

设置动画持续时间、开始之前的延迟时间、动画效果、动画内容、动画结束后执行的block

[UIView animateWithDuration:2 delay:1 options:UIViewAnimationOptionCurveLinear animations:^{} completion:^(BOOL finished) {}];

 

设置翻转效果,第一个参数是翻转方向,第二个参数是操作的对象,

[UIView setAnimationTransition:UIViewAnimationTransitionFlipFromRight forView:self.window cache:YES];

 

设置翻转动画:第1个参数是操作的对象,第2个参数是持续时间,第3个参数是翻转的方向,第4个参数是动画结束后执行的语句

[UIView transitionWithView:self.window duration:2 options:UIViewAnimationOptionTransitionCurlDown animations:^{

        [self.window exchangeSubviewAtIndex:1 withSubviewAtIndex:2];

    } completion:^(BOOL finished) {}];

 

CALayer:层,可以用来渲染图片、制作动画,每创建一个view时,自动创建一个layer,不能重新创建和赋值,但是可以修改某些属性

 

设置阴影颜色

imageView.layer.shadowColor=[UIColor redColor].CGColor;

 

设置阴影的偏移量

imageView.layer.shadowOffset=CGSizeMake(10, 10);

 

设置阴影的透明度,1不透明,0完全透明

imageView.layer.shadowOpacity=0.8;

 

设置边框的颜色

imageView.layer.borderColor=[UIColor blueColor].CGColor;

 

设置边框的宽度

imageView.layer.borderWidth=5;

 

设置圆角半径

imageView.layer.cornerRadius=50;

 

设置是否允许子视图被裁剪

imageView.clipsToBounds=YES;

posted @ 2015-09-12 22:12  BuddyLiu  阅读(192)  评论(0编辑  收藏  举报