zoukankan      html  css  js  c++  java
  • 再转动画实现



    最普通动画:
    //开始动画
    [UIView beginAnimations:nil context:nil];  
    //设定动画持续时间
    [UIView setAnimationDuration:2];
    //动画的内容
    frame.origin.x += 150;
    [img setFrame:frame];
    //动画结束
    [UIView commitAnimations];

    连续动画:一个接一个地显示一系列的图像
    NSArray *myImages = [NSArray arrayWithObjects: 
    [UIImage imageNamed:@"myImage1.png"], 
    [UIImage imageNamed:@"myImage2.png"], 
    [UIImage imageNamed:@"myImage3.png"], 
    [UIImage imageNamed:@"myImage4.gif"], nil];

    UIImageView *myAnimatedView = [UIImageView alloc]; 
    [myAnimatedView initWithFrame:[self bounds]]; 
    myAnimatedView.animationImages = myImages; //animationImages属性返回一个存放动画图片的数组
    myAnimatedView.animationDuration = 0.25; //浏览整个图片一次所用的时间
    myAnimatedView.animationRepeatCount = 0; // 0 = loops forever 动画重复次数
    [myAnimatedView startAnimating]; 
    [self addSubview:myAnimatedView]; 
    [myAnimatedView release]; 

    CATransition Public API动画:
    CATransition *animation = [CATransition animation];
    //动画时间
        animation.duration = 0.5f;
    //先慢后快
        animation.timingFunction = UIViewAnimationCurveEaseInOut;
    animation.fillMode = kCAFillModeForwards;
    //animation.removedOnCompletion = NO;

    //各种动画效果
    /*
    kCATransitionFade;
    kCATransitionMoveIn;
    kCATransitionPush;z
    kCATransitionReveal;
    */
    /*
    kCATransitionFromRight;
    kCATransitionFromLeft;
    kCATransitionFromTop;
    kCATransitionFromBottom;
    */
    //各种组合
    animation.type = kCATransitionPush;
    animation.subtype = kCATransitionFromRight; 

    [self.view.layer addAnimation:animation forKey:@"animation"];

    CATransition Private API动画:
    animation.type可以设定为以下效果
    动画效果汇总:
    /*
     suckEffect(三角)

     rippleEffect(水波抖动)

     pageCurl(上翻页)

     pageUnCurl(下翻页)

     oglFlip(上下翻转)

     cameraIris/cameraIrisHollowOpen/cameraIrisHollowClose  (镜头快门,这一组动画是有效果,只是很难看,不建议使用



    UIView Animations 动画:
    [UIView beginAnimations:@"animationID" context:nil];
    [UIView setAnimationDuration:0.5f];
    [UIView setAnimationCurve:UIViewAnimationCurveEaseInOut];
    [UIView setAnimationRepeatAutoreverses:NO];
    //以下四种效果
    /*
    [UIView setAnimationTransition:UIViewAnimationTransitionFlipFromLeft forView:self.view cache:YES];//oglFlip, fromLeft 
    [UIView setAnimationTransition:UIViewAnimationTransitionFlipFromRight forView:self.view cache:YES];//oglFlip, fromRight  
    [UIView setAnimationTransition:UIViewAnimationTransitionCurlUp forView:self.view cache:YES];
    [UIView setAnimationTransition:UIViewAnimationTransitionCurlDown forView:self.view cache:YES];
    */

    [self.view exchangeSubviewAtIndex:1 withSubviewAtIndex:0];
    [UIView commitAnimations];
    IOS4.0新方法:
    方法: +(void)animateWithDuration:(NSTimeInterval)duration animations:(void (^)(void))animations;
    + (void)animateWithDuration:(NSTimeInterval)duration animations:(void (^)(void))animations completion:(void (^)(BOOL finished))completion; //多一个动画结束后可以执行的操作.

    //下边是嵌套使用,先变大再消失的动画效果.
    [UIView animateWithDuration:1.25 animations:^{
    CGAffineTransform newTransform = CGAffineTransformMakeScale(1.21.2);
    [firstImageView setTransform:newTransform];
    [secondImageView setTransform:newTransform];} 
    completion:^(BOOL finished){
    [UIView animateWithDuration:1.2 animations:^{
    [firstImageView setAlpha:0];
    [secondImageView setAlpha:0];} completion:^(BOOL finished){ 
    [firstImageView removeFromSuperview]; 
    [secondImageView removeFromSuperview]; }]; 
    }];


  • 相关阅读:
    Java多线程系列 基础篇10 wait/notify/sleep/yield/join
    Java多线程系列 基础篇09 Object.wait/notifyJVM源码实现
    Java多线程系列 基础篇07 synchronized底层优化
    Java多线程系列 基础篇06 synchronized(同步锁)
    Java多线程系列 基础篇05 synchronized关键字
    Java多线程系列 基础篇04 线程中断
    Java多线程系列 基础篇03 线程的优先级和守护线程
    Java多线程系列 基础篇02 线程的创建和运行
    MySQL进阶14--标识列(自增序列/auto_increment)--设置/展示步长--设置/删除标示列
    MySQL进阶13--常见六大约束: 非空/默认/主键/唯一约束/检查约束/外键约束--表级约束 / 列级约束
  • 原文地址:https://www.cnblogs.com/luyinghuai/p/2160672.html
Copyright © 2011-2022 走看看