0

这个问题实际上解释了这一切。

我使用以下代码在当前视图上加载了一个自定义 UIView 动画:

- (void)showView
{
    self.blurView.alpha = 0.f;

    [UIView animateWithDuration:2.0 delay:0.0 options:UIViewAnimationOptionAllowUserInteraction animations:^
     {
         self.blurView.alpha = 1.f;
     } completion:^(BOOL finished) {
         [UIView animateWithDuration:2.0 delay:0.0 options:UIViewAnimationOptionAllowUserInteraction animations:^
          {
              self.blurView.alpha = 0.f;
          } completion:nil];
     }];
}

它可以工作,但是当我在仍然动画时再次执行 -(void)showView,自定义视图不会从屏幕上删除。

它只是这样:

在此处输入图像描述

4

3 回答 3

1

我弄清楚了问题所在。

blurView是一个公共变量,每次我这样做-(void)showView时都使用相同的变量,只将 alpha 设置为 0.f 一次,因此永远不会更改第一个节目的 alpha。

我在方法本身中声明了变量blurView,现在它可以工作了,因为每个blurView都有它自己的指针。

-(void)someMethod
{
    //Create a live blur view
    FXBlurView *blurView = [[FXBlurView alloc] initWithFrame:CGRectMake(0, 0, 200, 200)];
    blurView.center = CGPointMake(self.view.window.frame.size.width / 2, self.view.window.frame.size.height / 2);
    blurView.layer.cornerRadius = 20.f;
    [self.view.window addSubview:blurView];

    [self showView:(blurView)];
}

- (void)showView:(FXBlurView *)blurView
{
    //Make full transparent before showing
    blurView.alpha = 0.f;

    //Start animation
    [FXBlurView animateWithDuration:1.0 delay:0.0 options:UIViewAnimationOptionAllowUserInteraction animations:^
     {
         blurView.alpha = 1.f;
     } completion:^(BOOL finished) {
         if (finished)
         {
             //End animation
             [FXBlurView animateWithDuration:1.0 delay:0.0 options:UIViewAnimationOptionAllowUserInteraction animations:^
              {
                  blurView.alpha = 0.f;
              } completion:nil];
         }
     }];
}
于 2013-09-24T20:00:21.890 回答
0

您应该将此行添加到函数的顶部:

[self.view.layer removeAllAnimations];

它将删除所有活动的动画。

于 2013-09-23T20:35:41.027 回答
0

它不起作用,因为您已经实现了延迟,请使用带有延迟的动画块 - 它会创建可以使用上面的此功能删除的动画键。

[UIView animateWithDuration:0.3 delay:0.0
                    options:UIViewAnimationOptionAllowUserInteraction
                 animations:^
 {
     // ...
 } completion:NULL];
于 2013-09-24T05:52:04.507 回答