如何将 UIScrollView 交叉淡入淡出到开头



>我在iPad应用程序中有一个水平滚动的分页UIScrollView,其中包含大量页面。在最后一页上,我点击屏幕上的按钮以重置回第 1 页。我希望能够交叉溶解这种过渡,但它似乎不起作用:

[UIView transitionWithView:self.view duration:1.0 options:UIViewAnimationOptionTransitionCrossDissolve|UIViewAnimationOptionAllowAnimatedContent animations:^{
    pagingScrollView.contentOffset = CGPointZero;
} completion:^(BOOL finished) {
    [self refreshPages];
}];

我读到添加UIViewAnimationOptionAllowAnimatedContent将允许所有内容过渡,但它不起作用。相反,屏幕交叉溶解到背景颜色,当过渡完成时,第一页就会出现。

您不能淡出UIView(滚动器)并同时淡入同一视图...

你可以只使用不同的UIViews...

您可以做的是:

1)淡出当前位置的滚动条(到后台)

2)当滚动条不可见时,将其移动到正确的位置(没有动画)

3)淡入淡出在后台的滚动条中

像这样:

// START FIRST PART OF ANIMATION
[UIView animateWithDuration:0.5 delay:0.0 options: options:UIViewAnimationOptionTransitionCrossDissolve|UIViewAnimationOptionAllowAnimatedContent animations:^{
    pagingScrollView.alpha = 0;

} completion:^(BOOL finished) {
// FIRST PART ENDED
// MOVE SCROLLER (no animation)
    pagingScrollView.contentOffset = CGPointZero;
// START SECOND PART OF ANIMATION
[UIView animateWithDuration:0.5 delay:0.0 options: options:UIViewAnimationOptionTransitionCrossDissolve|UIViewAnimationOptionAllowAnimatedContent animations:^{
// fadeIn - animated
    pagingScrollView.alpha = 1;
} completion:^(BOOL finished) {
// ANIMATION ENDED
    [self refreshPages];
}];

}];

新编辑:

感谢阿马杜尔,他的评论教会了我一些东西,

我希望他能补充一个自己的答案,我会投票给他

无论如何,要回答乔维的原始问题:

我得到了正确的动画,只是将内容偏移设置移出动画块,并删除 UIViewAnimationOptionAllowAnimatedContent(不是真正需要的),并将 pagingScrollView 作为 transitionWithView 的参数传递

这对我有用:

    pagingScrollView.contentOffset = CGPointZero;
    [UIView transitionWithView:pagingScrollView duration:3.0 options:UIViewAnimationOptionTransitionCrossDissolve animations:^{
//        pagingScrollView.contentOffset = CGPointZero; // move up, outside of animation block
    } completion:^(BOOL finished) {
        NSLog(@"-->> END amimation");
        [self refreshPages];
    }];

最新更新