iOS 仿小红书的 push pop转场动画

手机软件开发 2024-10-4 16:54:30 152 0 来自 中国
iOS 7之后,苹果提供了自界说转场动画的API,我们可以本身去界说恣意动画效果。本篇为笔者学习push、pop自界说转场效果的条记,如何有任何不精确大概有引导意见的,请在批评中留下您的宝贵意见!!!
本篇只讲此中的UIViewControllerAnimatedTransitioning协议,来实现push、pop动画效果。别的的几个,背面会继承学习总结!!!
我们要实现push、pop自界说转场效果,我们必须要有一个服从了UIViewControllerAnimatedTransitioning协议且实现其必须实现的署理方法的类。
下面我们先相识下协议:
@protocol UIViewControllerAnimatedTransitioning <NSObject>
// This is used for percent driven interactive transitions, as well as for container controllers that have companion animations that might need to
// synchronize with the main animation.
//
// 指定转场动画时长,必须实现,否则会Crash。
// 这个方法是为百分比驱动的交互转场和有对比动画效果的容器类控制器而定制的。

  • (NSTimeInterval)transitionDurationnullable id <UIViewControllerContextTransitioning>)transitionContext;
// This method can only  be a nop if the transition is interactive and not a percentDriven interactive transition.
// 若非百分比驱动的交互过渡效果,这个方法只能为空

  • (void)animateTransitionid <UIViewControllerContextTransitioning>)transitionContext;
@optional
// This is a convenience and if implemented will be invoked by the system when the transition context's completeTransition: method is invoked.

  • (void)animationEndedBOOL) transitionCompleted;
@end
下面是详细的实现,
---------自界说push动画-----------
//转场过渡的容器view
UIView *containerView = [transitionContext containerView];
//FromVCUIViewController *fromViewController = [transitionContext viewControllerForKey:UITransitionContextFromViewControllerKey];UIView *fromView = fromViewController.view;[containerView addSubview:fromView];//ToVCUIViewController *toViewController = [transitionContext viewControllerForKey:UITransitionContextToViewControllerKey];UIView *toView = toViewController.view;[containerView addSubview:toView];toView.alpha = 0;//过渡的图片UIImageView *transitionImgView = [[UIImageView alloc] initWithImage:self.transitionImgView.image];transitionImgView.frame = self.transitionBeforeImgFrame;[transitionContext.containerView addSubview:transitionImgView];[UIView animateWithDuration:[self transitionDuration:transitionContext] animations:^{    transitionImgView.frame = self.transitionAfterImgFrame;    toView.alpha = 1;} completion:^(BOOL finished) {    [transitionImgView removeFromSuperview];    BOOL wasCancelled = [transitionContext transitionWasCancelled];    //设置transitionContext关照体系动画实行完毕    [transitionContext completeTransition:!wasCancelled];}];------------自界说pop动画----------
//转场过渡的容器view
UIView *containerView = [transitionContext containerView];
//ToVCUIViewController *toViewController = [transitionContext viewControllerForKey:UITransitionContextToViewControllerKey];UIView *toView = toViewController.view;[containerView addSubview:toView];//图片背景的空缺view (设置和控制器的背景颜色一样,给人一种图片被调走的假象)UIView *imgBgWhiteView = [[UIView alloc] initWithFrame:self.transitionBeforeImgFrame];imgBgWhiteView.backgroundColor = [UIColor clearColor];[containerView addSubview:imgBgWhiteView];//有渐变的白色背景UIView *bgView = [[UIView alloc] initWithFrame:containerView.bounds];bgView.backgroundColor = [UIColor whiteColor];bgView.alpha = 1;[containerView addSubview:bgView];//过渡的图片UIImageView *transitionImgView = [[UIImageView alloc] initWithImage:self.transitionImgView.image];transitionImgView.frame = self.transitionAfterImgFrame;transitionImgView.layer.cornerRadius = 20;transitionImgView.alpha = 0.3;transitionImgView.layer.masksToBounds = YES;[transitionContext.containerView addSubview:transitionImgView];[UIView animateWithDuration:[self transitionDuration:transitionContext] animations:^{    transitionImgView.frame = self.transitionBeforeImgFrame;    bgView.alpha = 0;} completion:^(BOOL finished) {    BOOL wasCancelled = [transitionContext transitionWasCancelled];    [imgBgWhiteView removeFromSuperview];    [bgView removeFromSuperview];    [transitionImgView removeFromSuperview];        //设置transitionContext关照体系动画实行完毕    [transitionContext completeTransition:!wasCancelled];}];分析Push动画
我们暂不细说UIViewControllerContextTransitioning协议,我们这里只使用到了-containerView这个署理方法,我们可以通过苹果提供的键来获取对应的控制器:
ViewController *fromVC = [transitionContext viewControllerForKey:UITransitionContextFromViewControllerKey];
获取到了fromVC,也就是当前要从哪个控制器切换。
然后通过:
DetailController *toVC = [transitionContext viewControllerForKey:UITransitionContextToViewControllerKey];
获取到了toVC,也就是切换到哪一个控制器。
然后再通过
UIView *containerView = [transitionContext containerView];
获取containerView视图。这个是一个署理方法,可以获取到视图容器。
下面我们获取fromVC所点击的图片控件,然后通过-snapshotViewAfterScreenUpdates:将所点击的图片控件截图并用于切换使用,参数设置为NO,否则动画会很生硬。末了,我们还要将这个所点击的图片控件的坐标转换成容器视图的坐标.
UIView *toImageView = toVC.imgView;
fromImageView.hidden = YES;
toVC.view.alpha = 0.0;
toImageView.hidden = YES;
下面这两行是非常关键的,而且必须包管tempView在最上层,否则动画效果就没有了。先将目标控制器的视图添加到容器中,再添加源图片的截图到容器中,用于体现切换效果。
[containerView addSubview:toVC.view];
[containerView addSubview:tempView];
我们在动画中,将初始的截图的frame改酿成终极的效果的frame即可到达我们的目标效果。别的要注意还需要将坐标转换成容器的坐标:
tempView.frame = [toImageView convertRect:toImageView.bounds toView:containerView];
当动画完成以后,肯定要调用:[transitionContext completeTransition:YES],设置切换动画已经完成,否则想要pop归去就不能了。
pop和push差不多,这里就不赘述了。
如需demo,请留言。
您需要登录后才可以回帖 登录 | 立即注册

Powered by CangBaoKu v1.0 小黑屋藏宝库It社区( 冀ICP备14008649号 )

GMT+8, 2024-11-24 21:15, Processed in 0.270203 second(s), 33 queries.© 2003-2025 cbk Team.

快速回复 返回顶部 返回列表