push 动画    自定义动画

燕照
2023-12-01
- CATransition *transition = [CATransition animation];
- transition.duration = 1.0f;
- transition.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut];
- transition.type = @"cube";
- transition.subtype = kCATransitionFromRight;
- transition.delegate = self;
- [self.navigationController.view.layer addAnimation:transition forKey:nil];
-
- FirstViewController *firstViewController = [[DemoViewController alloc]init];
- [self.navigationController pushViewController: firstViewController animated:YES];


其中的动画类型有:

- animation.type = kCATransitionFade;
-
- animation.type = kCATransitionPush;
-
- animation.type = kCATransitionReveal;
-
- animation.type = kCATransitionMoveIn;
-
- animation.type = @"cube";
-
- animation.type = @"suckEffect";
-
- // 页面旋转
- animation.type = @"oglFlip";
-
- //水波纹
- animation.type = @"rippleEffect";
-
- animation.type = @"pageCurl";
-
- animation.type = @"pageUnCurl";
-
- animation.type = @"cameraIrisHollowOpen";
-
- animation.type = @"cameraIrisHollowClose"; 


返回按钮的动画实现事件

- // 修改导航栏的 左边的标题
- self.navigationItem.leftBarButtonItem=[[UIBarButtonItem alloc] initWithTitle:@"返回" style:UIButtonTypeRoundedRect target:self action:@selector(back)];

//返回button 事件
- (void)back {
    //    自定义动画
    CATransition *transition = [CATransition animation];
    transition.duration = 1.0f;
    transition.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut];
    transition.type = @"rippleEffect";
    transition.subtype = kCATransitionFromRight;
    transition.delegate = self;
    [self.navigationController.view.layer addAnimation:transition forKey:nil];

    [self.navigationController popViewControllerAnimated:YES];
}
 类似资料: