【问题标题】:Core Animation Image sequence核心动画图像序列
【发布时间】:2011-04-26 21:57:43
【问题描述】:

我将如何创建带有核心动画的图像序列。我想:

添加 image1 1 秒然后删除图像

添加 image2 2 秒然后删除图像

添加 image1 3 秒然后删除

    CGImageRef image1 = [self getImage1];
    CALayer *image1Layer = [CALayer layer];
    image1Layer.bounds = CGRectMake(0, 0, 480, 320);
    image1Layer.position = CGPointMake(0, 0);
    image1Layer.contents = (id)image1;


    CABasicAnimation *animation1 = [CABasicAnimation animationWithKeyPath:@"animation"];
    animation1.repeatCount = 0; 
    animation1.duration = 2.0;
    animation1.removedOnCompletion = YES; // i would like to remove image here
    animation1.beginTime = AVCoreAnimationBeginTimeAtZero; 
    [image1Layer addAnimation:animation1 forKey:nil];

上面的代码添加了一个图像,但没有删除它。

干杯

【问题讨论】:

    标签: ios iphone image core-animation


    【解决方案1】:

    您也可以使用CAKeyframeAnimation 来实现此目的。请按照以下步骤操作:

    1. 创建 UIImage 数组,并添加图片
    2. 准备CAKeyframeAnimation动画
    3. 准备CALayer
    4. 向图层添加动画

    Reference

    【讨论】:

      【解决方案2】:

      最简单的方法是使用 CABasicAnimation 作为内容键:

      CABasicAnimation *animation = [CABasicAnimation animation];
      animation.fromValue = (id)[UIImage imageNamed:@"image1.png"].CGImage;
      animation.toValue = (id)[UIImage imageNamed:@"image2.png"].CGImage;
      animation.duration = 1.0f;
      animation.repeatCount = HUGE_VAL;
      //  animation.autoreverses = YES;
      [image1Layer addAnimation:animation forKey:@"contents"];
      

      此动画将无限更改 image1 和 image2 之间的图层内容。您可能需要设置autoreverses 属性以获得更平滑的过渡 - 以任何一种方式测试动画并选择您最喜欢的选项。

      【讨论】:

      • 我收到错误:无法在参数传递中将 'CGImage*' 转换为 'objc_object*'。我想添加大约十张图片,然后直接从一张剪到另一张。感谢您的回答。
      • 抱歉,您需要将 cgimage 显式转换为 id - 这应该可以修复错误。要对 10 个图像进行动画处理,您可以以类似于 CABasicAnimation 的方式使用 CAKeyFrameAnimation,您只需要提供一组图像来迭代并提供一组 keyTimes 来控制动画时间
      • @Vladimir-我如何从您的代码中的数组中播放图像序列。像这样stackoverflow.com/questions/18955031/…...我有同样的问题
      • @VivekSehrawat,您需要找出不允许将所有 100 张图像加载到内存中的方法。我的解决方案无法直接扩展
      • @Vladimir- 谢谢,但你能详细说明stackoverflow.com/questions/442076/…brad lanson 的答案吗
      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多