android2d反转动画,UIView 常见翻转动画

2D动画

/**

* 平移

*

* @param transform 获取当前的形变 transform

* @param tx 沿着 x 水平方向的平移

* @param ty 沿着 y 垂直方向的平移

*

* @return 返回移动之后的结果

*/

CGAffineTransformTranslate(CGAffineTransform t, CGFloat tx, CGFloat ty)

/**

* 缩放

*

* @param transform 获取当前的形变 transform

* @param sx 水平方向缩放比例

* @param sy 垂直方向缩放比例

*

* @return 缩放后结果

*/

CGAffineTransformScale(CGAffineTransform t, CGFloat sx, CGFloat sy)

/**

* 旋转

*

* @param transform 获取当前的形变 transform

* @param angle 旋转角度

*

* @return 返回旋转后的结果

*/

CGAffineTransformRotate(CGAffineTransform t, CGFloat angle)

/**

* 还原

*/

CGAffineTransformIdentity

Dmoe

//旋转

self.imageView.transform = CGAffineTransformRotate(self.imageView.transform, M_PI_4);

//缩放

self.imageView.transform = CGAffineTransformScale(self.imageView.transform, 0.9, 0.9);

Y轴3D翻转

d5d40efc8dbd

3D翻转.gif

- (void) rotateViewAnimated:(UIView*)view

withDuration:(CFTimeInterval)duration

byAngle:(CGFloat)angle

{

[CATransaction begin];

CABasicAnimation *rotationAnimation;

rotationAnimation = [CABasicAnimation animationWithKeyPath:@"transform.rotation.y"];

rotationAnimation.byValue = [NSNumber numberWithFloat:angle];

rotationAnimation.duration = duration;

rotationAnimation.removedOnCompletion = YES;

[CATransaction setCompletionBlock:^{

//view.transform = CGAffineTransformRotate(view.transform, angle);

}];

[view.layer addAnimation:rotationAnimation forKey:@"rotationAnimation"];

[CATransaction commit];

}

水平2D 旋转

d5d40efc8dbd

2D 旋转.gif

- (void) rotateViewAnimated:(UIView*)view

withDuration:(CFTimeInterval)duration

byAngle:(CGFloat)angle

{

[CATransaction begin];

CABasicAnimation *rotationAnimation;

rotationAnimation = [CABasicAnimation animationWithKeyPath:@"transform.rotation.z"];

rotationAnimation.byValue = [NSNumber numberWithFloat:angle];

rotationAnimation.duration = duration;

rotationAnimation.removedOnCompletion = YES;

[CATransaction setCompletionBlock:^{

//view.transform = CGAffineTransformRotate(view.transform, angle);

}];

[view.layer addAnimation:rotationAnimation forKey:@"rotationAnimation"];

[CATransaction commit];

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值