Skip to content

筛选视图,条件筛选,多层筛选,一层筛选:类似美团外卖下拉分类筛选,三层筛选:类似地区筛选,下拉筛选视图,功能强大,使用方便

Notifications You must be signed in to change notification settings

WallaceYou/YYFilterTool

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

38 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

YYFilterTool

  • 筛选视图,条件筛选,多层筛选,一层筛选:类似美团外卖下拉分类筛选,三层筛选:类似地区筛选,下拉筛选视图,功能强大,使用方便。

Installation

1、选择Download ZIP 下载YYFilterTool。
2、将YYFilterTool整个文件夹拖入工程中。
3、import "YYStarTool.h"
4、YYFilterTool使用Masonry布局,请先导入Masonry才可继续使用。


Function

  • 最多可支持3层筛选。
  • 支持单选和多选。
  • 多选时,可支持顶部条件框显示,角标显示。
  • 可自定义选择图片的样式。
  • 工具对象是全局单例的,用到的时候只需拿到单例对象,然后赋值相应属性,调用弹出pop方法即可。

How to use

1、单选 + 一层筛选

    YYFilterTool *filterTool = [YYFilterTool shareInstance];
    filterTool.firstLevelElements = @[@"智能排序",@"离我最近",@"好评优先",@"人气最高"];
//    filterTool.levelType = YYBaseFilterTypeSingleLevel;//默认是一层,所以可以不用写
//    filterTool.multiSelectionEnable = NO;//默认不支持多选,所以可以不写
    [filterTool popFilterViewWithStartY:150 startAnimateComplete:nil closeAnimateComplete:nil];
  • 效果

图片

2、多选 + 一层筛选

    filterTool.multiSelectionEnable = YES;//多选
  • 效果

图片

3、多选 + 一层筛选 + 顶部条件框

    //加一句
    filterTool.topConditionEnable = YES;//顶部条件框的显示
  • 效果

图片

4、多选 + 三层筛选 + 顶部条件框

    YYFilterTool *filterTool = [YYFilterTool shareInstance];
    
    NSMutableArray *firstLevelElements = [NSMutableArray new];
    NSMutableArray *secondLevelElements = [NSMutableArray new];
    NSMutableArray *thirdLevelElements = [NSMutableArray new];
    
    for (int i = 0; i < 30; i++) {
        [firstLevelElements addObject:[NSString stringWithFormat:@"%i",i]];
        NSMutableArray *elements = [NSMutableArray new];
        NSMutableArray *elementss = [NSMutableArray new];
        for (int j = 0; j < 15; j++) {//random()%30+1
            [elements addObject:[NSString stringWithFormat:@"%i%i",i,j]];
            NSMutableArray *elementsss = [NSMutableArray new];
            for (int k = 0; k < 15; k++) {
                [elementsss addObject:[NSString stringWithFormat:@"%i%i%i",i,j,k]];
            }
            [elementss addObject:elementsss];
        }
        [secondLevelElements addObject:elements];
        [thirdLevelElements addObject:elementss];
    }
    filterTool.firstLevelElements = firstLevelElements;
    filterTool.secondLevelElements = secondLevelElements;
    filterTool.thirdLevelElement = thirdLevelElements;
    filterTool.levelType = YYBaseFilterTypeThreeLevel;//三层筛选
    filterTool.multiSelectionEnable = YES;//多选
    filterTool.topConditionEnable = YES;//顶部条件框的显示
    [filterTool popFilterViewWithStartY:150 startAnimateComplete:nil closeAnimateComplete:nil];
  • 效果

图片

5、多选 + 三层筛选 + 顶部条件框 + 角标

    filterTool.indexCountShowEnable = YES;//角标显示
  • 效果

图片

6、自定义图片

    filterTool.selectedBtnHighlightedName = @"1";//设置选中图片
    filterTool.selectedBtnNormalName = @"2";//设置没选中图片
  • 效果

图片 图片

7、其他自定义

如果想自定义其他东西,比如背景颜色,角标样式,完成按钮样式等,可以去源码中修改,源码中有很多注释,看起来比较容易。


Last

  • 如果你感觉不错,不要吝啬,给颗星鼓励一下吧~😊thank you very much for give me a star~
  • 如果你在使用过程中有发现不合理的地方或者bug,请疯狂issues我!谢谢!

About

筛选视图,条件筛选,多层筛选,一层筛选:类似美团外卖下拉分类筛选,三层筛选:类似地区筛选,下拉筛选视图,功能强大,使用方便

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published