三种左右两个列表联动效果

这个效果我们经常会看到比如外卖,电商App的分类页面上看到,大概就是这样:


image.png

点击左侧列表右侧会跳到指定位置,滑动右侧左侧会跟着切换,就是这么个东西。

然后常见的交互效果有两种。一种是像“饿了吗”点餐那种,右侧是一体的可以一直滑动。第二种是像“网易严选”分类那样,右侧多个列表,然后使用pagingEnabled效果进行切换的。感兴趣的可以看看这两种。然后我这次做了一个在第二种上进行优化的效果,算是第三种吧。下面我们就说说这三个效果都是怎么做的。

第一种

左侧列表没什么好说的就是一个列表,使用table和Collection都是可以的(我是比较习惯使用Collection)。右侧由于也是连贯滑动的,所以也使用一个Collection就可以了。数据上看,一般都是返回的一个对象集合,集合里每个对象还有个子分类的几个:

"list": [{
                "name": "大分类"
                "list": [{
                    "name": "小分类",
                    "img": "https:\/\/res2.kongfz.com\/app\/search\/channel\/xianzhuang.png?2021122817"
                }, {
                    "name": "小分类",
                    "img": "https:\/\/res2.kongfz.com\/app\/search\/channel\/minguo.png?2021122817"
                }]
            },
            {
                "name": "大分类"
                "list": [{
                    "name": "小分类",
                    "img": "https:\/\/res2.kongfz.com\/app\/search\/channel\/xianzhuang.png?2021122817"
                }, {
                    "name": "小分类",
                    "img": "https:\/\/res2.kongfz.com\/app\/search\/channel\/minguo.png?2021122817"
                }]
            }

        ]

这样我们左侧用外层的集合做数据。右侧根据两层数据对列表进行分组处理。外层对应section里层对应row。然后在点击左侧切换时跳转到对应的section,监听右侧滑动的位置来刷新左侧的选择状态就可以了。参考代码如下:

- (void)scrollViewDidScroll:(UIScrollView *)scrollView {
    if (scrollView == _leftCollectionView ) {//如果是左侧的直接返回
        return;
    }
    //举例这个每一个必有header,所以使用header判断的,取最小是因为判断点在屏幕顶部
    NSIndexPath *indexPath = [self getMinIndexPathForHeaderView];
    if (!indexPath) { // 没有header的情况
        return;
    }
    KFZAuctionHeadCatModel *headerCatModel = [_categoryHomeModel.localCatList objectAtIndexCheck:indexPath.section];
    KFZAuctionFirstCatModel *currentCatModel = [_categoryHomeModel.localContaniner objectForKey:headerCatModel.localSuperId];
    if (currentCatModel.localSelected) {
        return;
    }
    _categoryHomeModel.localCurrentCatModel.localSelected = NO;
    currentCatModel.localSelected = YES;
    _categoryHomeModel.localCurrentCatModel = currentCatModel;
    [_leftCollectionView reloadData];
    WS(ws)
    [_leftCollectionView performBatchUpdates:nil completion:^(BOOL finished) {
        NSInteger row = [ws.categoryHomeModel.localModelData indexOfObject:currentCatModel];
        [ws.leftCollectionView scrollToItemAtIndexPath:[NSIndexPath indexPathForRow:row inSection:0] atScrollPosition: UICollectionViewScrollPositionCenteredVertically animated:YES];
    }];
}
- (NSIndexPath *)getMinIndexPathForHeaderView{
    NSIndexPath *targetIndexPath;
    NSMutableArray *headerArray = [[_rightCollectionView indexPathsForVisibleSupplementaryElementsOfKind:UICollectionElementKindSectionHeader] mutableCopy];
    if (headerArray.count > 0) {
        NSSortDescriptor *sortDescriptor = [[NSSortDescriptor alloc] initWithKey:@"section" ascending:YES];
        NSArray *sortDescriptors = [[NSArray alloc] initWithObjects:&sortDescriptor count:1];
        [headerArray sortUsingDescriptors:sortDescriptors];
        if (headerArray.count > 1) {
            targetIndexPath = [headerArray firstObject];
        } else {
            NSIndexPath *indexPath = [headerArray firstObject];
            UICollectionViewLayoutAttributes *attr = [_rightCollectionView.collectionViewLayout layoutAttributesForSupplementaryViewOfKind:UICollectionElementKindSectionHeader atIndexPath:indexPath];
            CGRect endFrame = [self.view convertRect:attr.frame fromView:_rightCollectionView];
            }
        }
    }
    if (!targetIndexPath){
        NSMutableArray *itemArray = [[_rightCollectionView indexPathsForVisibleItems] mutableCopy];
        targetIndexPath = [itemArray firstObject];
    }
    return targetIndexPath;
}

第二种

左侧和数据其实和第一种一样。主要是右侧的处理不同,以为要有分页效果,右侧用一个Collection就不行了,我这里使用的Collection套Collection的结构(底层是一个Collection它的cell的大小是整个显示区域然后里再放Collection),这样在底层左右两个Collection是一一对应的。外层多个小的Collection正常滑动,底层右侧Collection设置pageing效果就可以了。

第三种(第二种优化版)

还是先看效果:


Mar-20-2022 11-04-44.gif

页面大体结构和第二种是一样的。优化的点:
1.右侧paging是怎么切换的,“网易严选”是划不动了然后切换,低层Collection是没有滑动能力的切换的触发是靠外层做的像加载下一页效果一样。然后我这里是通过底层自身的滑动去切换的好处就是手动往下拉的时候能看到下面数据(正常是白色的)。
2.点击左侧切换,从上往下切换时,下一个外层列表默认在顶部;从下往上切换时下一个外层列表默认在底部。代码如下:

- (void)collectionView:(UICollectionView *)collectionView willDisplayCell:(UICollectionViewCell *)cell forItemAtIndexPath:(NSIndexPath *)indexPath{
    
    if (collectionView == self.rightCollectionView && collectionView.dragging) {
        KFZCategoryHomeRightCell *rightCell = (KFZCategoryHomeRightCell *)cell;
        if (indexPath.section >= self.selectIndex.section) {
            [rightCell scrollToTop];
        }else if (indexPath.section < self.selectIndex.section) {
            [rightCell scrollToBottom];
        }
    }
}

3.有一部分楼层合并
gif上可以看出来,我这个有一部分是连贯滑动。做法上其实是在数据上就把需要连贯滑动的数据合并到一起,然后在通过代理把外层的刷新回传到底层做的,具体有不少要处理的点,这里就不一一说了,我觉得正常用不到这个,,,

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,835评论 4 364
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,598评论 1 295
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,569评论 0 244
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,159评论 0 213
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,533评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,710评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,923评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,674评论 0 203
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,421评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,622评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,115评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,428评论 2 254
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,114评论 3 238
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,097评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,875评论 0 197
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,753评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,649评论 2 271

推荐阅读更多精彩内容