iOS自定義轉(zhuǎn)場動畫(3)——自定義模態(tài)跳轉(zhuǎn)之Present

Modal

modal轉(zhuǎn)場方式即使用 presentViewController() 方法推出的方式,默認情況下懂讯,第二個視圖從屏幕下方彈出刻获。下面就來介紹下 modal 方式轉(zhuǎn)場動畫的自定義坪创。

present

還是先來看一下完成的效果


準備

  1. 創(chuàng)建一個新的工程,刪掉Main侍瑟,在AppDelegate中創(chuàng)建自定義UIWindow唐片,設(shè)置rootVC為ViewController。
  2. 在ViewController中創(chuàng)建一個全屏的ImageView涨颜,并且指定一張圖片费韭;新建一個按鈕用于present。
  3. 新建一個SecondViewController庭瑰。同樣創(chuàng)建一個全屏的ImageView星持,指定一張和ViewController不同的圖片,新建一個同于dismiss的按鈕

開始

  1. 創(chuàng)建一個文件繼承自 NSObject弹灭,取名為PresentTransition并在.h中遵守 UIViewControllerAnimatedTransitioning協(xié)議督暂。
  2. 實現(xiàn)協(xié)議的兩個方法揪垄,并在其中編寫 Push 的動畫。 具體的動畫實現(xiàn)過程都在代碼的注釋里:
// 返回動畫的時間
- (NSTimeInterval)transitionDuration:(nullable id <UIViewControllerContextTransitioning>)transitionContext{
    return 0.8;
}
- (void)animateTransition:(id <UIViewControllerContextTransitioning>)transitionContext{
    ViewController * fromVC = [transitionContext viewControllerForKey:UITransitionContextFromViewControllerKey];
    SecondViewController * toVC = [transitionContext viewControllerForKey:UITransitionContextToViewControllerKey];
    UIView * container = [transitionContext containerView];
    
    [container addSubview:toVC.view];
    [container bringSubviewToFront:fromVC.view];
    
    // 改變m34
    CATransform3D transfrom = CATransform3DIdentity;
    transfrom.m34 = -0.002;
    container.layer.sublayerTransform = transfrom;
    
    // 設(shè)置archPoint和position
    CGRect initalFrame = [transitionContext initialFrameForViewController:fromVC];
    toVC.view.frame = initalFrame;
    fromVC.view.frame = initalFrame;
    fromVC.view.layer.anchorPoint = CGPointMake(0, 0.5);
    fromVC.view.layer.position = CGPointMake(0, initalFrame.size.height / 2.0);
    
    // 添加陰影效果
    CAGradientLayer * shadowLayer = [[CAGradientLayer alloc] init];
    shadowLayer.colors =@[
                         [UIColor colorWithWhite:0 alpha:1],
                         [UIColor colorWithWhite:0 alpha:0.5],
                         [UIColor colorWithWhite:1 alpha:0.5]
                         ];
    shadowLayer.startPoint = CGPointMake(0, 0.5);
    shadowLayer.endPoint = CGPointMake(1, 0.5);
    shadowLayer.frame = initalFrame;
    
    UIView * shadow = [[UIView alloc] initWithFrame:initalFrame];
    shadow.backgroundColor = [UIColor clearColor];
    [shadow.layer addSublayer:shadowLayer];
    [fromVC.view addSubview:shadow];
    shadow.alpha = 0;
    
    // 動畫
    [UIView animateKeyframesWithDuration:[self transitionDuration:transitionContext] delay:0 options:2 animations:^{
        fromVC.view.layer.transform = CATransform3DMakeRotation(-M_PI_2, 0, 1, 0);
        shadow.alpha = 1.0;
    } completion:^(BOOL finished) {
        fromVC.view.layer.anchorPoint = CGPointMake(0.5, 0.5);
        fromVC.view.layer.position = CGPointMake(CGRectGetMidX(initalFrame), CGRectGetMidY(initalFrame));
        fromVC.view.layer.transform = CATransform3DIdentity;
        [shadow removeFromSuperview];
        
        [transitionContext completeTransition:YES];
    }];
}

使用動畫

  1. 讓 FirstViewController 遵守 UIViewControllerTransitioningDelegate 協(xié)議逻翁,并將 self.transitioningDelegate 設(shè)置為 self饥努。
self.transitioningDelegate = self;
  1. 實現(xiàn) UIViewControllerTransitioningDelegate 協(xié)議的兩個方法,用來指定動畫類八回。
// present動畫
-(id<UIViewControllerAnimatedTransitioning>)animationControllerForPresentedController:(UIViewController *)presented presentingController:(UIViewController *)presenting sourceController:(UIViewController *)source{
    return [[PresentTransition alloc] init];
}
  1. 在present按鈕的點擊方法中酷愧,必須把SecondViewController的transitioningDelegate也設(shè)置為self,讓ViewController管理SecondViewController的動畫
-(void)presentClick{
    SecondViewController * secondVC = [[SecondViewController alloc] init];
    secondVC.transitioningDelegate = self; // 必須second同樣設(shè)置delegate才有動畫
    [self presentViewController:secondVC animated:YES completion:^{
    }];
}

自定義Present動畫完成

點擊此處下載源碼

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末缠诅,一起剝皮案震驚了整個濱河市溶浴,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌管引,老刑警劉巖士败,帶你破解...
    沈念sama閱讀 206,602評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異汉匙,居然都是意外死亡拱烁,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評論 2 382
  • 文/潘曉璐 我一進店門噩翠,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人邦投,你說我怎么就攤上這事伤锚。” “怎么了志衣?”我有些...
    開封第一講書人閱讀 152,878評論 0 344
  • 文/不壞的土叔 我叫張陵屯援,是天一觀的道長。 經(jīng)常有香客問我念脯,道長狞洋,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,306評論 1 279
  • 正文 為了忘掉前任绿店,我火速辦了婚禮吉懊,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘假勿。我一直安慰自己借嗽,他們只是感情好,可當我...
    茶點故事閱讀 64,330評論 5 373
  • 文/花漫 我一把揭開白布转培。 她就那樣靜靜地躺著恶导,像睡著了一般。 火紅的嫁衣襯著肌膚如雪浸须。 梳的紋絲不亂的頭發(fā)上惨寿,一...
    開封第一講書人閱讀 49,071評論 1 285
  • 那天邦泄,我揣著相機與錄音,去河邊找鬼裂垦。 笑死虎韵,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的缸废。 我是一名探鬼主播包蓝,決...
    沈念sama閱讀 38,382評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼企量!你這毒婦竟也來了测萎?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,006評論 0 259
  • 序言:老撾萬榮一對情侶失蹤届巩,失蹤者是張志新(化名)和其女友劉穎硅瞧,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體恕汇,經(jīng)...
    沈念sama閱讀 43,512評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡腕唧,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,965評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了瘾英。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片枣接。...
    茶點故事閱讀 38,094評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖缺谴,靈堂內(nèi)的尸體忽然破棺而出但惶,到底是詐尸還是另有隱情,我是刑警寧澤湿蛔,帶...
    沈念sama閱讀 33,732評論 4 323
  • 正文 年R本政府宣布膀曾,位于F島的核電站,受9級特大地震影響阳啥,放射性物質(zhì)發(fā)生泄漏添谊。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,283評論 3 307
  • 文/蒙蒙 一察迟、第九天 我趴在偏房一處隱蔽的房頂上張望斩狱。 院中可真熱鬧,春花似錦卷拘、人聲如沸喊废。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,286評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽污筷。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間瓣蛀,已是汗流浹背陆蟆。 一陣腳步聲響...
    開封第一講書人閱讀 31,512評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留惋增,地道東北人叠殷。 一個月前我還...
    沈念sama閱讀 45,536評論 2 354
  • 正文 我出身青樓,卻偏偏與公主長得像诈皿,于是被迫代替她去往敵國和親林束。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,828評論 2 345

推薦閱讀更多精彩內(nèi)容