【问题标题】:Manually scrolling two UICollectionViews showing the same content手动滚动显示相同内容的两个 UICollectionView
【发布时间】:2013-06-25 17:30:20
【问题描述】:

正如标题所示,我有一个UIViewController 和两个UICollectionViews,它们以水平方式显示相同的内容。主要的一次显示一张照片,拇指显示几张。

我重写了UIScrollViewDelegate 方法并添加了一些代码,这样当用户滚动主CV 时,拇指CV 也会滚动。但是,我也想启用相反的功能(滚动拇指将快速移动主体)。但是我得到了反馈效果。

这是我的代码 sn-p:

#pragma mark - UIScrollViewDelegate
- (void)scrollViewDidScroll:(UIScrollView *)scrollView{
    if(scrollView == self.mainCollectionView){
        CGFloat x = self.mainCollectionView.contentOffset.x / self.mainCollectionView.bounds.size.width * SM_IPHONE_THUMB_CONTAINER_SIZE; // cell width + spacing 48 + 8
        CGFloat y = 0;
        CGPoint contentOffset = CGPointMake(x, y);
        self.thumbsCollectionView.contentOffset = contentOffset;

    }
    else if(scrollView == self.thumbsCollectionView){
//        CGFloat   x = self.thumbsCollectionView.contentOffset.x / self.thumbsCollectionView.bounds.size.width * SM_IPHONE_THUMB_CONTAINER_SIZE; // cell width + spacing 48 + 8
//        CGFloat y = 0;
//        CGPoint contentOffset = CGPointMake(x, y);
//        self.mainCollectionView.contentOffset = contentOffset;

    }
}

我想我可以跟踪着陆/上升事件以掩盖允许发生的事情,但在我尝试之前我想我会看看是否有不同的方法来做到这一点?我是否忽略了提供的可以帮助我的方法?

谢谢。

编辑:解决方案。有一个 UIScrollViewDelegate 方法提供了我需要跟踪哪个布局被触摸。更新代码:

#pragma mark - UIScrollViewDelegate
- (void)scrollViewDidScroll:(UIScrollView *)scrollView{
    if(scrollView == self.mainCollectionView &&
       self.scrollingView == self.mainCollectionView){
        CGFloat x = self.mainCollectionView.contentOffset.x / self.mainCollectionView.bounds.size.width * SM_IPHONE_THUMB_CONTAINER_SIZE; // cell width + spacing 48 + 8
        CGFloat y = 0;
        CGPoint contentOffset = CGPointMake(x, y);
        self.thumbsCollectionView.contentOffset = contentOffset;

    }
    else if(scrollView == self.thumbsCollectionView &&
            self.scrollingView == self.thumbsCollectionView){
        CGFloat x = self.thumbsCollectionView.contentOffset.x / SM_IPHONE_THUMB_CONTAINER_SIZE * self.mainCollectionView.frame.size.width; // cell width + spacing 48 + 8
        CGFloat y = 0;
        CGPoint contentOffset = CGPointMake(x, y);
        self.mainCollectionView.contentOffset = contentOffset;

    }
}


-(void)scrollViewWillBeginDragging:(UIScrollView *)scrollView{
    self.scrollingView = scrollView;
}

【问题讨论】:

    标签: iphone ios uiscrollview uicollectionview uiscrollviewdelegate


    【解决方案1】:

    在调用scrollViewWillBeginDragging: 时跟踪当前拖动的滚动视图。

    scrollViewDidScroll:中,更新未拖动的滚动视图:

    - (void)scrollViewDidScroll:(UIScrollView *)scrollView{
        if(scrollView == self.mainCollectionView 
                 && self.mainCollectionView == self.scrollingView){ // new check
            CGFloat x = self.mainCollectionView.contentOffset.x / self.mainCollectionView.bounds.size.width * SM_IPHONE_THUMB_CONTAINER_SIZE; // cell width + spacing 48 + 8
            CGFloat y = 0;
            CGPoint contentOffset = CGPointMake(x, y);
            self.thumbsCollectionView.contentOffset = contentOffset;
    
        }
        else if(scrollView == self.thumbsCollectionView 
               && self.thumbsCollectionView== self.scrollingView){ // new check
            CGFloat   x = self.thumbsCollectionView.contentOffset.x / self.thumbsCollectionView.bounds.size.width * SM_IPHONE_THUMB_CONTAINER_SIZE; // cell width + spacing 48 + 8
            CGFloat y = 0;
            CGPoint contentOffset = CGPointMake(x, y);
            self.mainCollectionView.contentOffset = contentOffset;
    
    }
    

    【讨论】:

    • 谢谢。这就是我想做的事情,尽管我打算继承 UICollectionViews 并跟踪它们的触摸事件以跟踪哪个正在主动滚动。在我修正了偏移量的数学之后,您提供的委托方法效果很好。
    【解决方案2】:

    使用委托。子类化 CollectionView 并实现 scrollViewDelegate 的选择器 scrollViewDidScroll:。同时创建一个名为

    的新属性
    id scrollDistanceDelegate;
    

    现在在子类 CollectionView 中创建您自己的协议。当滚动视图滚动时将调用此协议,并将发送它滚动的距离。所以协议选择器可以是:

    scrollView: (UIScrollView *) sv didScrollADistance: (CGFloat) distance
    

    所以现在在 scrollViewDidScroll: 选择器中,当滚动视图滚动时,它会计算距离。然后调用scrollDistanceDelegate的scrollView:didScrollDistance:方法。

    此时,顶部CollectionView的scrollDistanceDelegate将设置为底部CollectionView,底部CollectionViews的scrollDistancedelgate将设置为顶部CollectionView。

    所以现在当 CollectionView 滚动时,另一个也会滚动。我看到的唯一问题是反馈循环。一个滚动,另一个滚动,它告诉第一个滚动....

    但这应该是可以处理的。

    【讨论】:

      猜你喜欢
      • 2013-07-13
      • 1970-01-01
      • 2021-06-27
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多