iOS實(shí)現(xiàn)帶遮罩的彈出選項(xiàng)卡
在我們?nèi)粘i_發(fā)的過程中難免會(huì)碰到一些選項(xiàng)的需求,下面是我針對(duì)我們?cè)摯涡枨笞龅囊粋€(gè)小的Demo,閑話不多說了,上圖片,上代碼。

這樣在我們選擇上面一個(gè)Cell進(jìn)行點(diǎn)擊的時(shí)候,我會(huì)通過一個(gè)代理把數(shù)據(jù)傳遞到下面的頁面,下面是代碼
// // 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
下面是具體實(shí)現(xiàn)
//
// 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 文件只是一個(gè)自定義的Cell,我們可以根據(jù)自己的需求自己設(shè)計(jì),就不上傳了,最后我們說說用法:
LCAlertListView* alertListView = [[LCAlertListView alloc]initWithFrame:CGRectMake(0, 0, kScreenWidth, kScreenHeight) datas:visibleRoleArray count:visibleRoleCountArray]; alertListView.delegate = self; [[[self.view superview] superview] addSubview:alertListView];
下面是代理傳值的使用
#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 就做好了。
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
iOS開發(fā)中的ViewController轉(zhuǎn)場(chǎng)切換效果實(shí)現(xiàn)簡介
這篇文章主要介紹了iOS開發(fā)中的ViewController轉(zhuǎn)場(chǎng)切換效果實(shí),主要針對(duì)iOS7以后新加入的API進(jìn)行講解,需要的朋友可以參考下2015-09-09
IOS 數(shù)據(jù)存儲(chǔ)詳解及實(shí)例代碼
這篇文章主要介紹了IOS 數(shù)據(jù)存儲(chǔ)詳解及實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下2017-02-02
總結(jié)iOS App開發(fā)中控制屏幕旋轉(zhuǎn)的幾種方式
這篇文章主要介紹了iOS app開發(fā)中控制屏幕旋轉(zhuǎn)的方法總結(jié),分為自動(dòng)旋轉(zhuǎn)和手動(dòng)旋轉(zhuǎn)以及強(qiáng)制旋轉(zhuǎn)三種情況,代碼為Objective-C語言,需要的朋友可以參考下2016-02-02
iOS開發(fā)中class和#import的區(qū)別介紹
這篇文章主要介紹了iOS開發(fā)中class和#import的區(qū)別,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧2018-02-02
iOS實(shí)現(xiàn)圖片自動(dòng)切換效果
這篇文章主要為大家詳細(xì)介紹了iOS實(shí)現(xiàn)圖片自動(dòng)切換效果,類似android畫廊效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-02-02

