我是靠谱客的博主 个性钻石,这篇文章主要介绍iOS实现带遮罩的弹出选项卡,现在分享给大家,希望可以做个参考。

在我们日常开发的过程中难免会碰到一些选项的需求,下面是我针对我们该次需求做的一个小的Demo,闲话不多说了,上图片,上代码。

这样在我们选择上面一个Cell进行点击的时候,我会通过一个代理把数据传递到下面的页面,下面是代码

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
// // LCAlertListView.h // MeiMeiDu // // Created by 韩伟佳 on 16/4/6. // Copyright © 2016年 LangCuang. All rights reserved. // #import <UIKit/UIKit.h> @class LCAlertListView; @protocol LCAlertListViewDelegate <NSObject> -(void)alertListView:(LCAlertListView*)view didSelectedRow:(NSInteger)row; @end @interface LCAlertListView : UIView<UITableViewDataSource, UITableViewDelegate> -(instancetype)initWithFrame:(CGRect)frame datas:(NSArray*)datas; -(instancetype)initWithFrame:(CGRect)frame datas:(NSArray*)datas count:(NSArray*)counts; @property(nonatomic, strong) id<LCAlertListViewDelegate> delegate; @end

下面是具体实现

复制代码
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
// // LCAlertListView.m // MeiMeiDu // // Created by 韩伟佳 on 16/4/6. // Copyright © 2016年 LangCuang. All rights reserved. // #import "LCAlertListView.h" #import "NoFreeCell.h" static CGFloat TableViewHeight ; @implementation LCAlertListView{ UITableView* mTableView; NSArray* tableData; NSArray* visiableData; NSArray* visiableCount; UIButton* backgroundBtn; } -(instancetype)initWithFrame:(CGRect)frame datas:(NSArray*)datas{ if (self = [super initWithFrame:frame]) { self.backgroundColor = [UIColor clearColor]; backgroundBtn = [[UIButton alloc] initWithFrame:frame]; backgroundBtn.backgroundColor = RGBA(88, 88, 88, 0.8); [backgroundBtn addTarget:self action:@selector(dismiss) forControlEvents:UIControlEventTouchUpInside]; [self addSubview:backgroundBtn]; tableData = datas; TableViewHeight = (datas.count + 1) * 44 + 20; mTableView = [[UITableView alloc] initWithFrame:CGRectMake(0, kScreenHeight, kScreenWidth, TableViewHeight) style:UITableViewStylePlain]; [mTableView registerClass:[UITableViewCell class] forCellReuseIdentifier:@"cell"]; mTableView.delegate = self; mTableView.dataSource = self; [self addSubview:mTableView]; [UIView animateWithDuration:.25 animations:^{ [mTableView setFrame:CGRectMake(0, kScreenHeight - TableViewHeight, kScreenWidth, TableViewHeight)]; } completion:^(BOOL finished) { }]; } return self; } -(instancetype)initWithFrame:(CGRect)frame datas:(NSArray*)datas count:(NSArray*)counts{ if (self = [super initWithFrame:frame]) { self.backgroundColor = [UIColor clearColor]; backgroundBtn = [[UIButton alloc] initWithFrame:frame]; backgroundBtn.backgroundColor = RGBA(88, 88, 88, 0.8); [backgroundBtn addTarget:self action:@selector(dismiss) forControlEvents:UIControlEventTouchUpInside]; [self addSubview:backgroundBtn]; visiableData = datas; visiableCount = counts; TableViewHeight = (datas.count + 1) * 44 + 20; mTableView = [[UITableView alloc] initWithFrame:CGRectMake(0, kScreenHeight, kScreenWidth, TableViewHeight) style:UITableViewStylePlain]; [mTableView registerClass:[UITableViewCell class] forCellReuseIdentifier:@"cell"]; mTableView.delegate = self; mTableView.dataSource = self; [self addSubview:mTableView]; [UIView animateWithDuration:.25 animations:^{ [mTableView setFrame:CGRectMake(0, kScreenHeight - TableViewHeight, kScreenWidth, TableViewHeight)]; } completion:^(BOOL finished) { }]; } return self; } - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section{ if(tableData.count > 0){ return [tableData count]; }else if (visiableCount.count > 0){ return [visiableCount count]; } return nil; } - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{ UITableViewCell* cell; NoFreeCell *doubleCell; if([tableData count] <= 3 && [tableData count] > 0){ cell = [tableView dequeueReusableCellWithIdentifier:@"cell" forIndexPath:indexPath]; cell.textLabel.text = tableData[indexPath.row]; return cell; }else { static NSString *identifier = @"cell0"; doubleCell =[tableView dequeueReusableCellWithIdentifier:identifier]; if (doubleCell == nil){ doubleCell= [[NoFreeCell alloc]initWithStyle:UITableViewCellStyleDefault reuseIdentifier:identifier]; doubleCell.visibleRoleLabel.text = visiableData[indexPath.row]; doubleCell.showVisibleRoleLabel.text = visiableCount[indexPath.row]; } return doubleCell; } } -(void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath{ NSInteger row = indexPath.row; [self dismiss:row]; } -(void)dismiss:(NSInteger) row{ if (_delegate && [_delegate respondsToSelector:@selector(alertListView:didSelectedRow:)]) { [_delegate alertListView:self didSelectedRow:row]; } [UIView animateWithDuration:.15 animations:^{ [mTableView setFrame:CGRectMake(0, kScreenHeight, kScreenWidth, TableViewHeight)]; } completion:^(BOOL finished) { [self removeFromSuperview]; }]; } -(void)dismiss{ [UIView animateWithDuration:.15 animations:^{ [mTableView setFrame:CGRectMake(0, kScreenHeight, kScreenWidth, TableViewHeight)]; } completion:^(BOOL finished) { [self removeFromSuperview]; }]; } @end

上面的NoFree 文件只是一个自定义的Cell,我们可以根据自己的需求自己设计,就不上传了,最后我们说说用法:

复制代码
1
2
3
LCAlertListView* alertListView = [[LCAlertListView alloc]initWithFrame:CGRectMake(0, 0, kScreenWidth, kScreenHeight) datas:visibleRoleArray count:visibleRoleCountArray]; alertListView.delegate = self; [[[self.view superview] superview] addSubview:alertListView];

下面是代理传值的使用

复制代码
1
2
3
4
5
6
7
8
9
10
11
#pragma mark - LCAlertListViewDelegate -(void)alertListView:(LCAlertListView *)view didSelectedRow:(NSInteger)row{ if(didSelectedIndex == 0){ testVisibleRole = visibleRoleArray[row]; }else{ testData = datas[row]; } NSIndexPath *indexPath = [NSIndexPath indexPathForRow:didSelectedIndex inSection:0]; [_myTableView reloadRowsAtIndexPaths:@[indexPath] withRowAnimation:UITableViewRowAnimationFade]; }

这样,我们的AlertTableVIew 就做好了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持靠谱客。

最后

以上就是个性钻石最近收集整理的关于iOS实现带遮罩的弹出选项卡的全部内容,更多相关iOS实现带遮罩内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(138)

评论列表共有 0 条评论

立即
投稿
返回
顶部