iOS實(shí)現(xiàn)帶遮罩的彈出選項(xiàng)卡
在我們?nèi)粘i_(kāi)發(fā)的過(guò)程中難免會(huì)碰到一些選項(xiàng)的需求,下面是我針對(duì)我們?cè)摯涡枨笞龅囊粋€(gè)小的Demo,閑話不多說(shuō)了,上圖片,上代碼。
這樣在我們選擇上面一個(gè)Cell進(jìn)行點(diǎn)擊的時(shí)候,我會(huì)通過(guò)一個(gè)代理把數(shù)據(jù)傳遞到下面的頁(yè)面,下面是代碼
// // 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ì),就不上傳了,最后我們說(shuō)說(shuō)用法:
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 就做好了。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
iOS開(kāi)發(fā)中的ViewController轉(zhuǎn)場(chǎng)切換效果實(shí)現(xiàn)簡(jiǎn)介
這篇文章主要介紹了iOS開(kāi)發(fā)中的ViewController轉(zhuǎn)場(chǎng)切換效果實(shí),主要針對(duì)iOS7以后新加入的API進(jìn)行講解,需要的朋友可以參考下2015-09-09IOS 數(shù)據(jù)存儲(chǔ)詳解及實(shí)例代碼
這篇文章主要介紹了IOS 數(shù)據(jù)存儲(chǔ)詳解及實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下2017-02-02總結(jié)iOS App開(kāi)發(fā)中控制屏幕旋轉(zhuǎn)的幾種方式
這篇文章主要介紹了iOS app開(kāi)發(fā)中控制屏幕旋轉(zhuǎn)的方法總結(jié),分為自動(dòng)旋轉(zhuǎn)和手動(dòng)旋轉(zhuǎn)以及強(qiáng)制旋轉(zhuǎn)三種情況,代碼為Objective-C語(yǔ)言,需要的朋友可以參考下2016-02-02iOS開(kāi)發(fā)中class和#import的區(qū)別介紹
這篇文章主要介紹了iOS開(kāi)發(fā)中class和#import的區(qū)別,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧2018-02-02iOS實(shí)現(xiàn)圖片自動(dòng)切換效果
這篇文章主要為大家詳細(xì)介紹了iOS實(shí)現(xiàn)圖片自動(dòng)切換效果,類(lèi)似android畫(huà)廊效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-02-02去除IOS蘋(píng)果手機(jī)自帶按鈕樣式的方法(推薦)
下面小編就為大家分享一篇去除IOS蘋(píng)果手機(jī)自帶按鈕樣式的方法(推薦),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-01-01