4

我有一个带有动画的自动布局设置,它改变了 NSLayoutContraint 常量值

// set the slide in view's initial height to zero
self.adViewHeightConstraint = [NSLayoutConstraint constraintWithItem:self.adContainerView
                                                           attribute:NSLayoutAttributeHeight
                                                           relatedBy:NSLayoutRelationEqual
                                                              toItem:nil
                                                           attribute:NSLayoutAttributeNotAnAttribute
                                                          multiplier:1.0
                                                            constant:0.0];
[self.view addConstraint:self.adViewHeightConstraint];

//  later, set the slid in view's height to non-zero
double delayInSeconds = 3.0;
dispatch_time_t popTime = dispatch_time(DISPATCH_TIME_NOW, (int64_t)(delayInSeconds * NSEC_PER_SEC));
dispatch_after(popTime, dispatch_get_main_queue(), ^(void){
    self.adViewHeightConstraint.constant = 100;
    [UIView animateWithDuration:2.5 animations:^{
        [self.view layoutIfNeeded];
    }];
});

这正确地动画了我拥有的视图的大小,因此可以正常工作。然而,我看到的问题是,在 2.5 秒动画的持续时间内,我拥有的一些自定义图层支持的视图没有被重绘。

我看到的行为是要求自定义图层支持的视图在动画开始时绘制最终位置,然后应用变换在动画期间拉伸视图,直到最终看起来正确。

在此处输入图像描述

这 4 个镜头显示的是红色条动画向上,然后两个蓝色视图的高度各缩小以适应尺寸减小。该层知道如何为每个边界更改正确绘制自己,但动画并没有要求它在动画的每一步重绘......只是在开始时。这就是为什么黑色圆圈看起来像一个椭圆形的原因——它与图像#4 相同的两半,但被拉伸了。

自定义CAlayer子类有一个被覆盖的方法:drawInContext:,并且图层已needsDisplayOnBoundsChange设置为YES

因此,问题仍然存在......我如何告诉这个动画NSLayoutConstraints让视图在整个动画期间重绘?

4

1 回答 1

1

这是一个已知问题(如果你用谷歌搜索它,你会看到一些不错的结果,尽管我认为这个答案虽然承认关注不同的症状,但是迄今为止我看到的描述UIView 缩放问题的最清晰的答案动画......这是一个旧答案,但我相信仍然适用)。

恕我直言,最简单的解决方案是将图层放在一个不会根据动画调整大小的视图中(例如,一个固定大小的新视图,其约束使其以您的内容视图为中心,但不会随着您的内容视图确实如此)。这样,您可以享受基于约束的动画,但不会丢失自定义图层的纵横比/大小。

于 2013-08-01T03:59:58.763 回答