UICollectionView中的cell包含UIScrollview

需求:在scrollview的子View不为0,当scrollview的展示的index不为0且向右滑动CollectionView。CollectionView不滑动Cell,而是让scrollview切换内容,想左滑同理。

开始真的难到我了。后来在CollectionView上添加了一个滑动手势,代替自带的滑动手势。

1
2
3
UIPanGestureRecognizer *ges = [[UIPanGestureRecognizer alloc]initWithTarget:self action:@selector(mainViewGes:)];
        ges.delegate =self;
        [_mainView addGestureRecognizer:ges

  MainView即UICollectionView

1
2
3
4
- (BOOL)gestureRecognizerShouldBegin:(UIGestureRecognizer *)gestureRecognizer{
    //用自定义的手势覆盖collectionView自带的手势
    return YES;
}

  重新这个方法。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
- (void)mainViewGes:(UIPanGestureRecognizer *)ges{
    if (ges.state == UIGestureRecognizerStateChanged) {
        //        [self commitTranslation:[ges translationInView:self.view]];
    }else if (ges.state == UIGestureRecognizerStateBegan){
        //        NSLog(@"UIGestureRecognizerStateBegan");
         
    }else if (ges.state == UIGestureRecognizerStateEnded){
        //        NSLog(@"UIGestureRecognizerStateEnded");
        [self commitTranslation:[ges translationInView:self.view]];
    }
}
 
/** 判断手势方向  */
- (void)commitTranslation:(CGPoint)translation {
    CGFloat absX = fabs(translation.x);
    CGFloat absY = fabs(translation.y);
    // 设置滑动有效距离
    if (MAX(absX, absY) < 50)
        return;
    if (absX > absY ) {
        if (translation.x < 0) {//向左滑动
            if (self.page.sentences.count > 1 && self.sentenceIndex + 1 < self.page.sentences.count) {
                //想左滑动时,如果句子不是最后一个句子,那么是滑动句子
                [self.currentCell.bottomView setContentOffset:CGPointMake(self.currentCell.bottomView.frame.size.width * (self.sentenceIndex + 1), 0) animated:YES];
            }else{
                if (self.sentenceIndex + 1 == self.page.sentences.count) {
                    //如果向左滑动时,句子是最后一个句子,那么是滑动page
                    if (self.pageNumber + 1 != self.currentCopyModel.pages.count) {
                        [self.mainView setContentOffset:CGPointMake(screen_width * (self.pageNumber + 1), 0) animated:YES];
                    }
                }
            }
        }else{//向右滑动
            if (self.page.sentences.count > 1 && self.sentenceIndex > 0) {
                //当sentence不是第一个时,向右滑动是滑动句子
                [self.currentCell.bottomView setContentOffset:CGPointMake(self.currentCell.bottomView.frame.size.width * (self.sentenceIndex - 1), 0) animated:YES];
            }else{
                //当sentence为第一个时。滑动就变成了滑动page
                if (self.sentenceIndex == 0) {
                    if (self.pageNumber != 0) {
                        [self.mainView setContentOffset:CGPointMake(screen_width * (self.pageNumber-1), 0) animated:YES];
                    }
                }
            }
             
        }
    } else if (absY > absX) {
        if (translation.y<0) {//向上滑动
             
        }else{ //向下滑动
             
        }
    }
}

  最后结果就是滑动手势结束之后才判断手势方向,然后手动调用CollectionView或Scrollview的setContenOffset方法。

1
- (void)scrollViewDidEndScrollingAnimation:(UIScrollView *)scrollView{

然后会在这个协议里接收到方法。进行处理

  

此外还有一个跟👆类似的方法

1
- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView{

  都是滑动动画结束时调用,区别官方注释挺清晰 = =

1
- (void)scrollViewDidEndScrollingAnimation:(UIScrollView *)scrollView; // called when setContentOffset/scrollRectVisible:animated: finishes. not called if not animating

  

1
scrollViewDidEndScrollingAnimation方法是手动调用方法,停止动画后调用,
1
scrollViewDidEndDecelerating是手滑动操作后停止滑动后调用
1
<br><br>
posted @   小师傅啊小师傅  阅读(533)  评论(0编辑  收藏  举报
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· 使用C#创建一个MCP客户端
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· Windows编程----内核对象竟然如此简单?
点击右上角即可分享
微信分享提示