ios 旋转缩放等动画

效果:视图从大--小缩放显示/小--大 (只是比例问题)
方法1.直接show出view的时候:
把下面的这段代码加到viewController或者view出现的时候就OK

self.view.transform = CGAffineTransformMakeScale(1.0f, 1.0f);//将要显示的view按照正常比例显示出来
[UIView beginAnimations:nil context:UIGraphicsGetCurrentContext()];
[UIView setAnimationCurve:UIViewAnimationCurveEaseInOut]; //InOut 表示进入和出去时都启动动画
[UIView setAnimationDuration:0.5f];//动画时间
self.view.transform=CGAffineTransformMakeScale(0.01f, 0.01f);//先让要显示的view最小直至消失
[UIView commitAnimations]; //启动动画
//相反如果想要从小到大的显示效果,则将比例调换
//UIGraphicsGetCurrentContext 里面东西很丰富。
——————————————————————————————————————————
方法2.push一个viewController时:
把下面的代码加到push的方法里面就OK
CATransition *myTranstiton = [CATransition animation];
myTranstiton.duration = 0.5;
myTranstiton.type = kCATransitionFade; 
//myTranstiton.subtype = kCATransitionFromTop; 
[self.view.superview.layer addAnimation:myTranstiton forKey:nil ]; 
MainViewController * _mainViewController=[[MainViewController alloc] init];
[self presentModalViewController:_mainViewController animated:NO];      


transform我们一般称为形变属性,其本质是通过矩阵变化改变控件的大小、位置、角度等,这里我们通过一个例子来看一下具体的操作,在下面的例子中我们也会看到UIImageView控件的常用操作。

  1. //旋转  
  2. - (IBAction)rotationButtonPressed:(id)sender  
  3. {  
  4.     self.imageView.transform = CGAffineTransformRotate(self.imageView.transform, M_PI_4);  
  5. }  
  6. //缩放  
  7. - (IBAction)scaleButtonPressed:(id)sender  
  8. {  
  9.     self.imageView.transform = CGAffineTransformScale(self.imageView.transform0.90.9);  
  10. }  
  11.   
  12. - (IBAction)moveButtonPressed:(id)sender  
  13. {  
  14.     _imageView.transform = CGAffineTransformTranslate(self.imageView.transform010);  
  • 获得CGAffineTransform有多种方法,例如使用CGAffineTransformMake,但是对于矩阵操作相对比较麻烦,事实上iOS已经为我们准备好了三个方法:CGAffineTransformMakeRotation(旋转)、CGAffineTransformMakeScale(缩放)、CGAffineTransformMakeTranslation(移动);
  • transform进行旋转、缩放、移动的时候不是在原来的基础上增量形变的,因此如果需要持续在原来的基础上旋转、缩放、移动那么每次需要在原来的基础上增加或减少。当然,我们可以定义一个全局变量进行累加,但是事实上iOS已经为我们提供好了三个对应的方法,分别用于在原来的角度、缩放、移动位置的基础上做出修改:CGAffineTransformRotate、CGAffineTransformScale、CGAffineTransformTranslate;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值