麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 系統 > iOS > 正文

iOS實現轉場動畫的3種方法示例

2019-10-21 18:21:59
字體:
來源:轉載
供稿:網友

什么是轉場動畫

在 NavigationController 里 push 或 pop 一個 View Controller,在 TabBarController 中切換到其他 View Controller,以 Modal 方式顯示另外一個 View Controller,這些都是 View Controller Transition。在 storyboard 里,每個 View Controller 是一個 Scene,View Controller Transition 便是從一個 Scene 轉換到另外一個 Scene, 中文稱呼其為「轉場」。 顧名思義,轉場動畫便是 View Controller Transition 過程中的動畫效果。

在 iOS 7 之前,我們只能使用系統提供的轉場效果,大部分時候夠用,但僅僅是夠用而已,總歸會有各種不如意的小地方,但我們卻無力改變;iOS 7 開放了相關 API 允許我們對轉場效果進行全面定制,這太棒了,自定義轉場動畫以及對交互手段的支持帶來了無限可能。

本文主要給大家介紹了關于iOS實現轉場動畫的3種方法,分享出來供大家參考學習,下面話不多說了,來一起看看詳細的介紹吧

1.CATransition

CATransition是CAAnimation的子類,用于過渡動畫或轉場動畫。為視圖層移入移除屏幕提供轉場動畫。首先來看一下簡單的Demo:

 CATransition *animation = [CATransition animation]; animation.type = kCATransitionFade; animation.subtype = kCATransitionFromRight; animation.duration = 1.0; // 在window上執行CATransition, 即可在ViewController轉場時執行動畫 [self.view.window.layer addAnimation:animation forKey:@"kTransitionAnimation"];  AViewController *vc = [[AViewController alloc] init]; [self presentViewController:vc animated:NO completion:nil];

將該動畫添加到window.layer上,則會present或push時使用指定的轉場動畫。

其中最主要的兩個屬性就是type和subtype。

  • type:轉場動畫的類型。

官方SDK只提供了四種轉場動畫的類型,即:

CA_EXTERN NSString * const kCATransitionFade;CA_EXTERN NSString * const kCATransitionMoveIn;CA_EXTERN NSString * const kCATransitionPush;CA_EXTERN NSString * const kCATransitionReveal;

私有的type:

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;

上面講的是給window.layer添加transition,這樣使得在present或push時使用指定的轉場動畫。

既然講到這里了,就看一下把transition加在layer上。

看一下示例代碼:

- (void)viewDidLoad { [super viewDidLoad];  UIButton *button = [[UIButton alloc] initWithFrame:CGRectMake(100, 100, 100, 50)];  [button setTitle:@"進入" forState:UIControlStateNormal];  button.backgroundColor = [UIColor redColor];  [button addTarget:self action:@selector(buttonClicked) forControlEvents:UIControlEventTouchUpInside];  [self.view addSubview:button];  _imageView = [[UIImageView alloc] initWithFrame:CGRectMake(100, 300, 150, 150)]; [self.view addSubview:_imageView]; _imageView.backgroundColor = [UIColor redColor]; _imageArray = @[[UIImage imageNamed:@"成果秀1"],[UIImage imageNamed:@"點贊他人1"],[UIImage imageNamed:@"偷師學藝1"],[UIImage imageNamed:@"學會欣賞3"]];  _imageView.image = [UIImage imageNamed:@"成果秀1"];}- (void)buttonClicked{  CATransition *animation = [CATransition animation]; animation.type = @"cube"; animation.subtype = kCATransitionFromRight; animation.duration = 1.0; //換圖片的時候使用轉場動畫 [self.imageView.layer addAnimation:animation forKey:nil]; //cycle to next image UIImage *currentImage = self.imageView.image; NSUInteger index = [self.imageArray indexOfObject:currentImage]; index = (index + 1) % [self.imageArray count]; self.imageView.image = self.imageArray[index]; }

2.transitionFromViewController

UIViewController自帶的方法:
transitionFromViewController:toViewController:duration:options:animations:completion:這個轉場動畫是用在當一個父視圖控制器中有幾個childViewController,當要在這幾個子視圖控制器之間切換時就可以用這個方法。

AViewController *a = self.childViewControllers[0];BViewController *b = self.childViewControllers[1];CViewController *c = self.childViewControllers[2];// Curl 翻頁效果// UIViewAnimationOptionTransitionCurlUp, UIViewAnimationOptionTransitionCurlDown// Flip 翻轉效果// UIViewAnimationOptionTransitionFlipFromLeft, UIViewAnimationOptionTransitionFlipFromRight// UIViewAnimationOptionTransitionFlipFromTop, UIViewAnimationOptionTransitionFlipFromDown[self transitionFromViewController:_currentViewController   toViewController:b    duration:0.5    options:UIViewAnimationOptionTransitionFlipFromRight   animations:^{} completion:^(BOOL finished) {}];

3.Transition Animation

1 UINavigationControllerDelegate + UIViewControllerAnimatedTransitioning

在UINavigationController的轉場動畫中,要指定UINavigationControllerDelegate對象:

self.navigationController.delegate = self;[self.navigationController pushViewController:itemVC animated:YES];

UINavigationControllerDelegate主要有以下兩個協議方法:

//pop- (nullable id <UIViewControllerInteractiveTransitioning>)navigationController:(UINavigationController *)navigationController       interactionControllerForAnimationController:(id <UIViewControllerAnimatedTransitioning>) animationController NS_AVAILABLE_IOS(7_0);//push- (nullable id <UIViewControllerAnimatedTransitioning>)navigationController:(UINavigationController *)navigationController         animationControllerForOperation:(UINavigationControllerOperation)operation            fromViewController:(UIViewController *)fromVC             toViewController:(UIViewController *)toVC NS_AVAILABLE_IOS(7_0);

首先創建一個基類PDAnimatorBaseTransition實現UIViewControllerAnimatedTransitioning協議的方法。

UIViewControllerAnimatedTransitioning協議的方法有:

//動畫持續時間- (NSTimeInterval)transitionDuration:(nullable id <UIViewControllerContextTransitioning>)transitionContext;//轉場動畫實現細節- (void)animateTransition:(id <UIViewControllerContextTransitioning>)transitionContext;動畫結束時調用- (void)animationEnded:(BOOL) transitionCompleted;

PDAnimatorBaseTransition.h

#import <Foundation/Foundation.h>#import <UIKit/UIKit.h>typedef NS_ENUM(NSInteger, PDAnimationType){  animationTypePresent = 0, animationTypeDismiss , animationTypePush , animationTypePop,};@interface PDAnimatorBaseTransition : NSObject <UIViewControllerAnimatedTransitioning>@property (nonatomic, assign)PDAnimationType animationType;@property (nonatomic, strong)UIView *containerView;@property (nonatomic, strong)UIViewController *from;@property (nonatomic, strong)UIViewController *to;@property (nonatomic, strong)UIView *fromView;@property (nonatomic, strong)UIView *toView;@property (nonatomic, weak)id <UIViewControllerContextTransitioning> transitionContext;@end

PDAnimatorBaseTransition.m

#import "PDAnimatorBaseTransition.h"@interface PDAnimatorBaseTransition() @end@implementation PDAnimatorBaseTransition#pragma mark -required- (NSTimeInterval)transitionDuration:(nullable id <UIViewControllerContextTransitioning>)transitionContext{  return 1.f;}- (void)animateTransition:(id <UIViewControllerContextTransitioning>)transitionContext{  _transitionContext = transitionContext;  _containerView = [transitionContext containerView];  _from = [transitionContext viewControllerForKey:UITransitionContextFromViewControllerKey];  _to = [transitionContext viewControllerForKey:UITransitionContextToViewControllerKey];  if([transitionContext respondsToSelector:@selector(viewForKey:)]){    _fromView = [transitionContext viewForKey:UITransitionContextFromViewKey];  _toView = [transitionContext viewForKey:UITransitionContextToViewKey]; }else{    _fromView = _from.view;  _toView = _to.view; }  if(self.animationType == animationTypePresent){    [self animationPresent]; }else if (self.animationType == animationTypeDismiss){    [self animationDismiss]; }else if (self.animationType == animationTypePop){    [self animationPop]; }else{    [self animationPush]; } }#pragma mark -optional//動畫結束時回調- (void)animationEnded:(BOOL) transitionCompleted{ }- (void)animationPresent{ }- (void)animationDismiss{}- (void)animationPop{ }- (void)animationPush{ }

然后創建子類PDAnimatorPUshPopTransition繼承自PDAnimatorBaseTransition,實現- (void)animationPush,- (void)animationPop方法。

PDAnimatorPUshPopTransition.h

#import "PDAnimatorBaseTransition.h"#import <UIKit/UIKit.h>@interface PDAnimatorPUshPopTransition : PDAnimatorBaseTransition@property (nonatomic, assign)CGPoint itemCenter;@property (nonatomic, assign)CGSize itemSize;@property (nonatomic, strong)NSString *imageName;@end

PDAnimatorPUshPopTransition.m

#import "PDAnimatorPUshPopTransition.h"@implementation PDAnimatorPUshPopTransition- (instancetype)init{  self = [super init]; if(self){     }  return self;}- (NSTimeInterval)transitionDuration:(nullable id <UIViewControllerContextTransitioning>)transitionContext{  return 5.f;}- (void)animateTransition:(id <UIViewControllerContextTransitioning>)transitionContext{  [super animateTransition:transitionContext];}- (void)animationPush{  NSTimeInterval duration = [self transitionDuration:self.transitionContext]; __weak typeof(self) weakSelf = self;  self.containerView.backgroundColor = [UIColor lightGrayColor];  UIImageView *imageView = [[UIImageView alloc] initWithFrame:CGRectMake(0, 0, 100, 160)]; imageView.image = [UIImage imageNamed:self.imageName]; imageView.center = _itemCenter;  CGFloat initialScale = _itemSize.width / CGRectGetWidth(imageView.frame);  CGAffineTransform transform = CGAffineTransformIdentity;  transform = CGAffineTransformScale(transform, initialScale, initialScale); transform = CGAffineTransformRotate(transform, M_PI);  imageView.layer.affineTransform = transform;  // imageView.transform = CGAffineTransformMakeScale(initialScale, initialScale);  [self.containerView addSubview:imageView];   self.toView.frame = [self.transitionContext finalFrameForViewController:self.to]; CGPoint finalCenter = self.toView.center; self.toView.center = finalCenter; self.toView.alpha = 0.0; //這一句一定要 [self.containerView addSubview:self.toView];  [UIView animateWithDuration:duration delay:0 usingSpringWithDamping:0.5 initialSpringVelocity:0 options:UIViewAnimationOptionCurveLinear animations:^{    imageView.layer.affineTransform = CGAffineTransformIdentity;    imageView.center = finalCenter;    self.fromView.alpha = 0.0;  self.containerView.backgroundColor = [UIColor redColor]; } completion:^(BOOL finished){    [imageView removeFromSuperview];    weakSelf.toView.alpha = 1.0f;  weakSelf.fromView.alpha = 1.0f;    [weakSelf.transitionContext completeTransition:![weakSelf.transitionContext transitionWasCancelled]]; }]; }- (void)animationPop{  NSTimeInterval duration = [self transitionDuration:self.transitionContext]; __weak typeof(self) weakSelf = self;  self.toView.frame = [self.transitionContext finalFrameForViewController:self.to];  [self.containerView insertSubview:self.toView belowSubview:self.fromView];  self.fromView.alpha = 0.0;  self.fromView.backgroundColor = [UIColor clearColor];  [UIView animateWithDuration:duration delay:0 usingSpringWithDamping:0.5 initialSpringVelocity:0 options:UIViewAnimationOptionCurveLinear animations:^{    CGFloat initialScale = _itemSize.width / 200;  weakSelf.fromView.transform = CGAffineTransformMakeScale(initialScale, initialScale);  weakSelf.fromView.center = weakSelf.itemCenter;    weakSelf.toView.alpha = 1.0f; } completion:^(BOOL finished){    weakSelf.fromView.alpha = 0.0f;    [weakSelf.transitionContext completeTransition:![weakSelf.transitionContext transitionWasCancelled]]; }];}@end

然后我們在需要push的地方實現UINavigationControllerDelegate的協議方法:

- (nullable id <UIViewControllerAnimatedTransitioning>)navigationController:(UINavigationController *)navigationController           animationControllerForOperation:(UINavigationControllerOperation)operation               fromViewController:(UIViewController *)fromVC               toViewController:(UIViewController *)toVC NS_AVAILABLE_IOS(7_0){  PDAnimatorPUshPopTransition *animationTransition = [[PDAnimatorPUshPopTransition alloc] init]; if(operation == UINavigationControllerOperationPush){    animationTransition.animationType = animationTypePush; }else if (operation == UINavigationControllerOperationPop){    animationTransition.animationType = animationTypePop; }  NSArray *indexPaths = [self.collectionView indexPathsForSelectedItems]; if (indexPaths.count == 0) {  return nil; }  NSIndexPath *selectedIndexPath = indexPaths[0]; UICollectionViewCell *cell = [self.collectionView cellForItemAtIndexPath:selectedIndexPath];  // 一定要加上convertPoint:toView:操作 animationTransition.itemCenter = [self.collectionView convertPoint:cell.center toView:self.view]; animationTransition.itemSize = cell.frame.size; animationTransition.imageName = [NSString stringWithFormat:@"%ld", (long)selectedIndexPath.item];  return animationTransition;}

2 UIViewControllerTransitioningDelegate+UIViewControllerAnimatedTransitioning

首先需要設置被present的Controller的transitionDelegate

DemoViewControllerTransitionPresentedViewController *presentedVC = [[DemoViewControllerTransitionPresentedViewController alloc] init];presentedVC.transitionDelegate = self;[self presentViewController:presentedVC animated:YES completion:nil];

UIViewControllerTransitioningDelegate的代理的協議方法有:

//  prenent  - (id )animationControllerForPresentedController:(UIViewController *)presented presentingController:(UIViewController *)presenting sourceController:(UIViewController *)source;//  pop  - (id )animationControllerForDismissedController:(UIViewController *)dismissed;//  prenent  - (id )interactionControllerForPresentation:(id )animator;//  pop  - (nullable id )interactionControllerForDismissal:(id )animator;

創建子類PDAnimationPresentTransitio繼承自基類PDAnimatorBaseTransition,實現- (void)animationPresent,- (void)animationDismiss方法。

PDAnimationPresentTransition.h

#import "PDAnimatorBaseTransition.h"@interface PDAnimationPresentTransition : PDAnimatorBaseTransition@end

PDAnimationPresentTransition.m

#import "PDAnimationPresentTransition.h"@implementation PDAnimationPresentTransition- (NSTimeInterval)transitionDuration:(nullable id <UIViewControllerContextTransitioning>)transitionContext{  return 1.f;}- (void)animateTransition:(id <UIViewControllerContextTransitioning>)transitionContext{ [super animateTransition:transitionContext];}- (void)animationPresent{  NSTimeInterval duration = [self transitionDuration:self.transitionContext]; __weak typeof(self) weakSelf = self;  self.toView.frame = [self.transitionContext initialFrameForViewController:self.to];  self.fromView.frame = [self.transitionContext initialFrameForViewController:self.from];  CGAffineTransform transform = CGAffineTransformIdentity; transform = CGAffineTransformScale(transform, 0.001, 0.001); self.toView.layer.affineTransform = transform;  [self.containerView addSubview:self.toView];  self.toView.alpha = 0.0;  [UIView animateWithDuration:duration delay:0 usingSpringWithDamping:0.6 initialSpringVelocity:0 options:UIViewAnimationOptionCurveEaseInOut animations:^{    self.toView.layer.affineTransform = CGAffineTransformIdentity;  self.toView.frame = [self.transitionContext finalFrameForViewController:self.to];  self.toView.alpha = 1.0; } completion:^(BOOL finished){    BOOL wasCancelled = [weakSelf.transitionContext transitionWasCancelled];  [weakSelf.transitionContext completeTransition:!wasCancelled]; }]; }

然后我們在需要present的地方實現UIViewControllerTransitioningDelegate的代理方法。

- (nullable id <UIViewControllerAnimatedTransitioning>)animationControllerForPresentedController:(UIViewController *)presented presentingController:(UIViewController *)presenting sourceController:(UIViewController *)source{  PDAnimationPresentTransition *animationTransition = [[PDAnimationPresentTransition alloc] init]; animationTransition.animationType = animationTypePresent; return animationTransition;}- (nullable id <UIViewControllerAnimatedTransitioning>)animationControllerForDismissedController:(UIViewController *)dismissed{  PDAnimationPresentTransition *animationTransition = [[PDAnimationPresentTransition alloc] init]; animationTransition.animationType = animationTypePresent; return animationTransition;}

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。


注:相關教程知識閱讀請移步到IOS開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 一区二区三区在线观看国产 | 成年性羞羞视频免费观看 | 欧美日韩高清一区二区三区 | 亚洲码无人客一区二区三区 | 黄网站在线观 | 97zyz成人免费视频 | 一本一本久久a久久精品综合小说 | 88xx成人精品视频 | 欧美亚洲综合在线 | 一区二区三区视频在线观看 | 日韩不卡一区二区 | 毛片福利 | 黄色片观看 | 久久亚洲精品久久国产一区二区 | 中文字幕在线观看网址 | 网站激情 | 久草在线视频网 | 国产精品一区在线观看 | 青青国产在线视频 | 欧美激情精品久久久久久久久久 | 日本爽快片100色毛片视频 | 最新av网址在线观看 | 韩国美女一区 | 国产69精品久久久久久 | 91短视频在线播放 | 黄色av网| av在线更新 | 国产91中文字幕 | 国产一区二区三区四区五区加勒比 | 草久免费| 国产91成人 | 日韩视频一二三 | 欧美 videos粗暴 | 一级毛片大片 | 亚洲成人自拍电影 | 久久亚洲精品久久国产一区二区 | 久久国产精品久久久久 | h色视频网站 | 一级黄片毛片免费看 | 日韩激情在线视频 | 嗯~啊~弄嗯~啊h高潮视频 |