UICollectionView单选多选的实现

今天收到一个页面,是要实现简单的单选,多选,重置等功能,在网上找了夏没找到合适的,然后自己就造了一个轮子,哈哈。。。效果如下,不喜勿喷~~~




废话不多说,具体代码如下:

#import "ShaiXuanViewController.h"

#import "ShaiXuanCell.h"

@interface ShaiXuanViewController ()

@property (nonatomic, strong)UICollectionView *collectionView;

@property (nonatomic, strong)UIButton *selectedBtn;

@property (nonatomic, strong)NSMutableArray *dataArray;

@property (nonatomic, strong)NSMutableArray *selectedArray;

@property (nonatomic, strong)UIButton *chongzhiBtn;

@property (nonatomic, strong)UIButton *okBtn;

@end

@implementationShaiXuanViewController

-(void)viewWillAppear:(BOOL)animated{

    [superviewWillAppear:animated];

    [self.navigationController setNavigationBarHidden:NO animated:NO];

}

- (void)viewDidLoad {

    [super viewDidLoad];

    self.title=@"筛选";

    self.view.backgroundColor = [UIColor whiteColor];

    _selectedArray = [NSMutableArray array];

    _dataArray=  [NSMutableArray arrayWithObjects:@"经济",@"法规",@"管理",@"建筑实务",@"机电实务",@"公路实物",@"好的", nil];

    [selfsetUI];

     [self setcollectionView];

-(void)setUI{

    UIView *view = [[UIView alloc]initWithFrame:CGRectMake(0, NAVIGATION_BAR_HEIGHT, ScreenWidth, 5 * KscreenHeight)];

    [self.view addSubview:view];

    UILabel*lable = [UILabelnew];

    lable.text=@"科目";

    lable.font = [UIFont systemFontOfSize:16 * KscreenWidth];

    [self.viewaddSubview:lable];

    lable.sd_layout

    .topSpaceToView(view,20*KscreenHeight)

    //    .rightSpaceToView(self.view, 0)

    .leftSpaceToView(self.view, 20 * KscreenWidth)

    .widthIs(40 * KscreenWidth)

    .heightIs(20 * KscreenHeight);

    _selectedBtn = [UIButton new];

    [_selectedBtn setBackgroundColor:[UIColor whiteColor]];

    [_selectedBtn setBackgroundImage:[UIImage imageNamed:@"User_choose"] forState:UIControlStateSelected];

    [_selectedBtn setBackgroundImage:[UIImage imageNamed:@"User_selected"] forState:0];

    [_selectedBtn addTarget:self action:@selector(quanxuanAction) forControlEvents:(UIControlEventTouchUpInside)];

    [_selectedBtn setTitleColor:ZhuTiColor forState:UIControlStateNormal];

    [self.view addSubview:_selectedBtn];

    _selectedBtn.sd_layout

    .topSpaceToView(view,20*KscreenHeight)

    .leftSpaceToView(lable,10*KscreenWidth)

    .widthIs(20 * KscreenWidth)

    .heightIs(20 * KscreenHeight);

UILabel *lable1 = [UILabel new];

    lable1.text=@"全选";

    lable1.font = [UIFont systemFontOfSize:16 * KscreenWidth];

    [self.viewaddSubview:lable1];


    lable1.sd_layout

    .topSpaceToView(view,20*KscreenHeight)

    //    .rightSpaceToView(self.view, 0)

    .leftSpaceToView(_selectedBtn, 10 * KscreenWidth)

    .widthIs(40 * KscreenWidth)

    .heightIs(20 * KscreenHeight);


    _chongzhiBtn = [UIButton new];

    _chongzhiBtn.layer.masksToBounds = YES;

    _chongzhiBtn.layer.cornerRadius = 5;

    _chongzhiBtn.layer.borderColor = ZhuTiColor.CGColor;

    _chongzhiBtn.layer.borderWidth = 1;

    [_chongzhiBtn setTitle:@"重置" forState:0];

    [_chongzhiBtn addTarget:self action:@selector(chongzhiAction) forControlEvents:(UIControlEventTouchUpInside)];

    [_chongzhiBtn setTitleColor:ZhuTiColor forState:UIControlStateNormal];

    [self.view addSubview:_chongzhiBtn];

    _chongzhiBtn.sd_layout

    .bottomSpaceToView(self.view,50 * KscreenHeight)

    .leftSpaceToView(self.view, 20 * KscreenWidth)

    .widthIs((ScreenWidth - 60 * KscreenWidth)/2)

    .heightIs(50 * KscreenHeight);


    _okBtn = [UIButton new];

    _okBtn.layer.masksToBounds = YES;

    _okBtn.layer.cornerRadius = 5;

    _okBtn.backgroundColor = ZhuTiColor;

    [_okBtn setTitle:@"提交" forState:0];

    [_okBtn addTarget:self action:@selector(okAction) forControlEvents:(UIControlEventTouchUpInside)];

    [self.view addSubview:_okBtn];

    _okBtn.sd_layout

    .bottomSpaceToView(self.view,50 * KscreenHeight)

    .rightSpaceToView(self.view, 20 * KscreenWidth)

    .widthIs((ScreenWidth - 60 * KscreenWidth)/2)

    .heightIs(50 * KscreenHeight);

}

//取消

-(void)chongzhiAction{

     _selectedArray = [NSMutableArray array];

    [self.collectionView reloadData];

}

//确定按钮

-(void)okAction{

}

//全选勾选事件

-(void)quanxuanAction{

    _selectedBtn.selected = !_selectedBtn.selected;

    if(_selectedBtn.selected==YES) {

        _selectedArray = _dataArray.mutableCopy;

    }else{

        _selectedArray = [NSMutableArray array];

    }

     [self.collectionView reloadData];

}

-(void)setcollectionView{

    //设置布局对象

    UICollectionViewFlowLayout *flowLayout = [[UICollectionViewFlowLayout alloc]init];

    //设置item大小

    flowLayout.itemSize=CGSizeMake(100*KscreenWidth,30*KscreenHeight);

    //设置最小列间距

    flowLayout.minimumInteritemSpacing = 20 * KscreenWidth;

    //设置最小行间距

    flowLayout.minimumLineSpacing=20*KscreenHeight;

    //设置滚动方向

    flowLayout.scrollDirection = UICollectionViewScrollDirectionVertical;

_collectionView = [[UICollectionView alloc]initWithFrame:CGRectMake(0, 52 * KscreenHeight + NAVIGATION_BAR_HEIGHT, ScreenWidth, Screenheight - NAVIGATION_BAR_HEIGHT - 152 * KscreenHeight) collectionViewLayout:flowLayout];

    _collectionView.backgroundColor = [UIColor whiteColor];

    //设置代理

    _collectionView.delegate = self;

    //设置数据源

    _collectionView.dataSource = self;

    //注册

    [_collectionView registerClass:[ShaiXuanCell class] forCellWithReuseIdentifier:@"ShaiXuanCell"];

    //添加到视图

    [self.view addSubview:_collectionView];

}

#pragma mark 必须实现的方法

//每分区有多少个item

- (NSInteger)collectionView:(UICollectionView*)collectionView numberOfItemsInSection:(NSInteger)section{

    return _dataArray.count;

}

//每个item上面现实的内容

- (UICollectionViewCell*)collectionView:(UICollectionView*)collectionView cellForItemAtIndexPath:(NSIndexPath*)indexPath{

//    从重用池里面获取cell

    ShaiXuanCell *cell = [collectionView dequeueReusableCellWithReuseIdentifier:@"ShaiXuanCell" forIndexPath:indexPath];

//    防止cell复用带来的控件重叠

//        for (UIView *view in cell.contentView.subviews) {

//            [view removeFromSuperview];

//        }

    cell.nameLable.text=_dataArray[indexPath.row];

    if(_selectedBtn.selected==YES) {

        cell.contentView.backgroundColor = hui1Color;

    }else{

        cell.contentView.backgroundColor = [UIColor whiteColor];

    }

    returncell;

}

//设置分区数

-(NSInteger)numberOfSectionsInCollectionView:(UICollectionView*)collectionView{

    return 1;

}

//点击item触发的事件

-(void)collectionView:(UICollectionView*)collectionView didSelectItemAtIndexPath:(NSIndexPath*)indexPath{

    UICollectionViewCell *cell = [collectionView cellForItemAtIndexPath:indexPath];

    NSString*str =_dataArray[indexPath.row];

    NSLog(@"%@",str);

    if (_selectedArray.count > 0) {

        if([self.selectedArraycontainsObject:str]) {

            [self.selectedArrayremoveObject:str];

            cell.contentView.backgroundColor = [UIColor whiteColor];

            cell.selected= !cell.selected;

            return;

        }

        [self.selectedArrayaddObject:str];

        cell.contentView.backgroundColor = hui1Color;

    }else{

        [self.selectedArrayaddObject:str];

        cell.contentView.backgroundColor = hui1Color;

    }

}

//返回分区内边距的上左下右的距离

-(UIEdgeInsets)collectionView:(UICollectionView*)collectionView layout:(UICollectionViewLayout*)collectionViewLayout insetForSectionAtIndex:(NSInteger)section{

    return UIEdgeInsetsMake(30 * KscreenWidth, 30 *KscreenHeight, 30 * KscreenWidth, 30 * KscreenHeight);

}



cell中只用了一个lable,具体如下:

-(instancetype)initWithFrame:(CGRect)frame{

    if(self= [superinitWithFrame:frame]) {

        self.nameLable = [[UILabel alloc]initWithFrame:CGRectMake(0, 0, 90 * KscreenWidth, 30 * KscreenHeight)];

        self.nameLable.center = self.contentView.center;

        self.nameLable.textAlignment = NSTextAlignmentCenter;

        self.nameLable.font = [UIFont systemFontOfSize:15 * KscreenWidth];

        self.nameLable.textColor=ZhuTiColor;

        self.nameLable.text=@"经济";

        [self.contentView addSubview:self.nameLable];


        self.contentView.layer.masksToBounds = YES;

        self.contentView.layer.cornerRadius = 5 * KscreenWidth;

        self.contentView.layer.borderColor = ZhuTiColor.CGColor;

        self.contentView.layer.borderWidth = 0.5;

    }

    return self;

}

到此完活,因为按照需求写完之后从项目中抠出的一部分,所以有点乱,欢迎大家指正!勿喷,哈哈。。。

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

推荐阅读更多精彩内容