美文网首页IOS
JazzHands + AutoLayout 基本使用

JazzHands + AutoLayout 基本使用

作者: 王大屁帅2333 | 来源:发表于2016-03-05 02:19 被阅读706次

    在上一篇文章中,我们已经能用JazzHands做出一个完整的 Guide 动画了,但是这个动画还有一些不足.

    • 它是用 Frame 来布局的,在不同的机型上适配起来很麻烦

    JazzHands 2.0已经解决了这个问题
    用 AutoLayout 来布局,用 IFTTTConstraintConstantAnimation 和 IFTTTConstraintMultiplierAnimation来做动画
    使用起来代码会复杂一些,但是对屏幕适配,屏幕旋转, iPad split-screen 支持的更好.

    使用 IFTTTAnimatedPagingScrollViewController

    IFTTTAnimatedPagingScrollViewController 内部Override 下面这2个方法,结合 AutoLayout 完成适配.

    - (void)viewWillTransitionToSize:(CGSize)size withTransitionCoordinator:(id<UIViewControllerTransitionCoordinator>)coordinator:
    
    - (void)willRotateToInterfaceOrientation:(UIInterfaceOrientation)toInterfaceOrientation duration:(NSTimeInterval)duration:
    

    接下来我们使用AutoLayout 和 JazzHands做一个简单的 透明度渐变动画.

    创建一个空 ViewController 继承 IFTTTAnimatedPagingScrollViewController
    这是 JazzHands 提供给我们的方便结合使用 AutoLayout 制作动画的类,以后我们使用 AutoLayout 做动画直接继承这个类就可以了,它已经帮我们初始化好了 scrollView,contentView,Animator

    在类扩展中只需添加我们动画的 View

    @interface JazzHandsPageViewControllerDemo ()
    @property (strong,nonatomic) UIView  *v;
    @end
    

    在 ViewDidLoad 中

    - (void)viewDidLoad {
        [super viewDidLoad];
        
        self.v=[UIView new];
        self.v.backgroundColor=[UIColor redColor];
        [self.contentView addSubview:self.v]; //注意添加 view到 contentView 中
        self.scrollView.showsHorizontalScrollIndicator=YES;
        self.scrollView.backgroundColor=[UIColor whiteColor];
        
        
        self.edgesForExtendedLayout = UIRectEdgeNone; //ios7以后 NavigationBar 会遮住内容,加上这行保证内容显示在 navigationBar 下面,一般来说我们的 Guide 动画都是全屏的,不需要加这行
        [self.v mas_makeConstraints:^(MASConstraintMaker *make) {
            make.width.height.equalTo(@30); //固定 view 宽高为30
        }];
        
        [self keepView:self.v onPage:0]; //keepView 下面会说到
        
        IFTTTAlphaAnimation *alpha=[IFTTTAlphaAnimation animationWithView:self.v];
        [self.animator addAnimation:alpha];
        
        [alpha addKeyframeForTime:0 alpha:1];
        [alpha addKeyframeForTime:1 alpha:0]; //注意 time 是 1
    }
    

    运行一下,效果如图

    JazzHands+AutoLayoutDemo.gif

    上面的代码和我们前2篇文章使用 Frame 布局制作动画类似,但有3点不同.

    1. 将 View 添加到了 contentView中.
    2. Masonry 给 view 布局
    3. addKeyframeForTime:1 time 是1.

    关于第一点 : 将 View 添加到了 contentView中.

    引用一段 斯坦福大学公开课:iOS 7应用开发

    KeepViewDemo.gif

    我们并没有给 ITFFF imageView设置任何的动画和约束,但是它在 X轴居中,
    就是因为我们设置了[self keepView:self.ifttt onPage:0];,让 imageView 出现在第一页,

    我们继续使用它的重载方法..

        [self keepView:self.ifttt onPages:@[@(0),@(1)]]; 
    

    运行结果如下..

    KeepViewDemo_2.gif

    注意看下面的 scrollIndicator, 即使我滑动到第二页,它还是保持在屏幕中间的位置,

    继续修改代码为

        [self keepView:self.ifttt onPages:@[@(0),@(1)] atTimes:@[@(0),@(1)]];
    

    这个运行的结果和上面一样,其实我们调用 [self keepView:self.ifttt onPages:@[@(0),@(1)]];时,
    内部会调用它的重载方法
    [self keepView:self.ifttt onPages:@[@(0),@(1)] atTimes:@[@(0),@(1)]];,
    所以这2个方法的效果是一样的

    再次修改代码,最后一次了...

        [self keepView:self.ifttt onPages:@[@(0),@(1.5)] atTimes:@[@(0),@(1)]]; 
    

    运行结果如下

    KeepViewDemo_3.gif

    这个运行结果看起来有点诡异,
    先来解释这个方法,

    [self keepView:self.ifttt onPages:@[@(0),@(1)] atTimes:@[@(0),@(1)]]; 
    

    调用这个方法起到的效果是, ImageView 会保持在第一页和第二页的中间,
    当我们调用这个方法时,内部会给 imageView 和 contentView 添加一个 X 轴的约束,让 imageView 保持在页面中间,
    onPages:@[@(0),@(1)] 就代表保持在第一二页的中间, atTimes:@[@(0),@(1)] 代表2个时间点,

    它内部的实现是在 scrollView 滚动时,将 scrollView.contentOffset.x 累加给 imageView 和 contentView 的约束的 constant 上,也就是 scrollView 滚动多少, imageView 也滚动多少,所以产生的效果就是 imageView 一直保持在第一页和第二页的中间不动.

    别忘了 JazzHands 是一个帧动画,所以我们设置参数的解释就是,在 time=0时, imageView 保持在第一页中间, time=1时, imageView 保持在第二页中间,我们只需设置这2个关键帧,其余的 JazzHands 会帮我们搞定.

    那么下面这个方法呢?..

    [self keepView:self.ifttt onPages:@[@(0),@(1.5)] atTimes:@[@(0),@(1)]]; 
    

    在 time=0时, imageView 保持在第一页中间,在 time=1时, imageView 保持在第二页中间 再偏离中间0.5倍的位置.

    具体的实现是,现在 scrollView 滚动10px, imageView 滚动 15px, 所以从第一页滚动到第二页的过程中,感觉 imageView 滚动的距离比较长,滚动的比较快.

    所以[self keepView:self.ifttt onPages:@[@(0),@(1.5)] atTimes:@[@(0),@(1)]];这个方法不仅能将 view 保持在某一页面出现,调整参数后,还能制作 X 轴偏移的动画,所以后我们给 view设置约束时,不用设置 X 轴的约束,只需调用此方法即可约束 view 的 X 轴位置.

    明白了这点就可以无压力的制作动画了..

    Done

    所有代码你可以在 Github 中找到

    下一篇 我们用 JazzHands+AutoLayout 来模仿 官方 Demo 的效果

    相关文章

      网友评论

        本文标题:JazzHands + AutoLayout 基本使用

        本文链接:https://www.haomeiwen.com/subject/fmgokttx.html