5

私はそのプルダウンしてリフレッシュすることをやっています。scrollViewDidEndDecelerating では、オフセットが特定のポイントを超えているかどうかを確認し、scrollViewDidEndDragging では、プルダウン セクションが表示されるように contentInset を設定します。

ただし、アニメーションのスクロール中に contentInset がリセットされるため、ちらつきが発生します。scrollViewWillEndDraggingでtargetContentOffsetを設定することでこれを防ぐことができるかもしれないと思っていましたが、うまくいかないようです。

 - (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate 
{

     if (scrollView.contentOffset.y < -kRefreshViewDelta) 
     {
         self.tableView.contentInset = UIEdgeInsetsMake(kRefreshViewHeight, 0.0f, 0.0f, 0.0f);

     }
}

- (void)scrollViewWillEndDragging:(UIScrollView *)scrollView withVelocity:(CGPoint)velocity targetContentOffset:(inout CGPoint *)targetContentOffset
 {
     if (scrollView.contentOffset.y  < -kRefreshViewDelta) 
     {
          targetContentOffset->y = kRefreshViewHeight ;
     }
 }
4

3 に答える 3

10

UITableView に割り当てられたフレームをまったく変更すると (スクロール中またはそれ以外の場合)、contentInset がデフォルト (0,0,0,0) にリセットされます。私のためにいくつかの状態チェックがありますが、本質的にこれは私が私のために行ったことです...

- (void)scrollViewDidEndDragging:(UIScrollView *)scrollView
                  willDecelerate:(BOOL)decelerate {
  if (scrollView.contentOffset.y < -kRefreshDeltaY) {
    animation = ^{
        [self setContentInset:UIEdgeInsetsMake(kRefreshDeltaY,
                                                          0, 0, 0)];
    };

    [UIView animateWithDuration:0.3
                          delay:0
                        options:UIViewAnimationOptionAllowUserInteraction
                     animations:animation
                     completion:completion];
  } // if
}

サブビューをレイアウトしたり、UITableView のフレームを変更したりしない限り、問題なく動作しました。

于 2012-03-07T05:55:50.387 に答える
4

マイクの答えはうまくいきました(ただし、賛成票を投じたり、コメントしたりすることはできませんでした)。コードをアニメーション ブロックにラップすると、ちらつきが解消されたようです。

- (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate 
{
    if (scrollView.contentOffset.y < 0 && scrollView.contentInset.top < 0)
    {
        // shows table header view
        // setting inset without using animation block causes flicker
        [UIView animateWithDuration:0.1 animations:^
        {
            scrollView.contentInset = UIEdgeInsetsZero;
        }];
    }

    // hides table header view
    if (scrollView.contentOffset.y > 44 && scrollView.contentInset.top == 0)
    {
        scrollView.contentInset = UIEdgeInsetsMake(-44, 0, 0, 0);
    }
}
于 2012-03-28T17:34:02.190 に答える
0

このプルをリフレッシュするための別のメカニズムを試しました。コードを確認してください

- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView
{
    if (!reloading)
    {
        checkForRefresh = YES;  //  only check offset when dragging
    }
}

- (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
    if (reloading) return;

    if (checkForRefresh) {
        if (refreshHeaderView.isFlipped
            && scrollView.contentOffset.y > -65.0f
            && scrollView.contentOffset.y < 0.0f
            && !reloading) {
            [refreshHeaderView flipImageAnimated:YES];
            [refreshHeaderView setStatus:kPullToReloadStatus];


        } else if (!refreshHeaderView.isFlipped
                   && scrollView.contentOffset.y < -65.0f) {
            [refreshHeaderView flipImageAnimated:YES];
            [refreshHeaderView setStatus:kReleaseToReloadStatus];

        }
    }
}
- (void)scrollViewDidEndDragging:(UIScrollView *)scrollView
                  willDecelerate:(BOOL)decelerate
{
    if (reloading) return;

    if (scrollView.contentOffset.y <= - 65.0f) {
        if([self.tableView.dataSource respondsToSelector:
            @selector(reloadTableViewDataSource)]){
            [self showReloadAnimationAnimated:YES];
            [self reloadTableViewDataSource];
        }
    }
    checkForRefresh = NO;
}   


- (void)reloadTableViewDataSource
{
    [self performSelectorOnMainThread:@selector(refresh) withObject:nil waitUntilDone:NO];

}
于 2012-03-13T04:24:46.247 に答える