以前对转场的概念有点笼统,对 ViewController 层次的转场和 View 的转场(过渡)老是混淆,区分一下此处先对 View 转场 用 CATransition 实现动画,进行一个笔记。
对 CATransition 进行了解,它是CAAnimation的子类,用于做过渡动画或者转场动画,能够为层提供移出屏幕和移入屏幕的动画效果。 其中最主要的就是 type 和 subType 这两个属性。
@property(copy) NSString *type; // 动画的类型
@property(nullable, copy) NSString *subtype;// 动画类型的方向
- 公共Type(官方的SDK其实只提供了四种过渡效果)
CA_EXTERN NSString * const kCATransitionFade;
CA_EXTERN NSString * const kCATransitionMoveIn;
CA_EXTERN NSString * const kCATransitionPush;
CA_EXTERN NSString * const kCATransitionReveal;
- 私有的Type (私有API提供了其他很多非常炫的过渡动画),需要自己额外写的
NSString *const kCATransitionCube = @"cube";
NSString *const kCATransitionSuckEffect = @"suckEffect";
NSString *const kCATransitionOglFlip = @"oglFlip";
NSString *const kCATransitionRippleEffect = @"rippleEffect";
NSString *const kCATransitionPageCurl = @"pageCurl";
NSString *const kCATransitionPageUnCurl = @"pageUnCurl";
NSString *const kCATransitionCameraIrisHollowOpen = @"cameraIrisHollowOpen";
NSString *const kCATransitionCameraIrisHollowClose = @"cameraIrisHollowClose";
- SubType: 动画类型的方向
CA_EXTERN NSString * const kCATransitionFromRight;
CA_EXTERN NSString * const kCATransitionFromLeft;
CA_EXTERN NSString * const kCATransitionFromTop;
CA_EXTERN NSString * const kCATransitionFromBottom;
为了加深印象,对 Type 的类型一一进行尝试, 只是将 type 的方式替换而已。
CATransition *animation = [CATransition animation];
animation.type = kCATransitionPush;//设置动画的类型
animation.subtype = kCATransitionFromRight; //设置动画的方向
animation.duration = 1.0f;
[testView.layer addAnimation:animation forKey:@"pushAnimation"];
样式
-
kCATransitionFade
-
kCATransitionMoveIn
-
kCATransitionPush
-
kCATransitionReveal
[图片上传中...(kCATransitionSuckEffect.gif-9e0810-1651137269522-0)]
-
kCATransitionCube
-
kCATransitionSuckEffect
-
kCATransitionOglFlip
-
kCATransitionRippleEffect
-
kCATransitionPageCurl
-
kCATransitionPageUnCurl
-
kCATransitionCameraIrisHollowOpen
-
kCATransitionCameraIrisHollowClose