亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > iOS > 正文

iOS實現通過按鈕添加和刪除控件的方法

2020-07-26 02:20:56
字體:
來源:轉載
供稿:網友

本文實例為大家分享了iOS通過按鈕添加和刪除控件,供大家參考,具體內容如下

想要達到的效果如下:

先講一下這個demo主要部分,即通過按鈕實現增刪圖標

分析:

1、每一個圖標需要兩個數據,即圖片和描述用的字符串 ,所以創建一個Item類來封裝從plist文件讀取出來的數據:

1)plist文件如下:

2)Item類:

.h文件

#import <Foundation/Foundation.h>@interface Item : NSObject//描述的字符串@property(nonatomic,copy)NSString * desStr;//圖片路徑@property(nonatomic,copy)NSString * imgPath;-(instancetype)initWithString:(NSString *)desStr andimgPath:(NSString *)imgPath;@end

.m文件

#import "Item.h"@implementation Item-(instancetype)initWithString:(NSString *)desStr andimgPath:(NSString *)imgPath{ self = [super init]; if (self) {  self.desStr = desStr;  self.imgPath = imgPath; } return self;}@end

2、然后創建一個Model類用于封裝自定義的圖標模型,我的模型是將Model類繼承于UIScrollView類,然后設置其可以滾動,然后再創建一個占據整個scrollview可滾動部分大小的button添加上去。再分別在button上半部分添加UIImageView顯示圖片,在下半部分添加UILabel顯示描述文字,結構如下

重寫model的init方法,在創建對象時用item對象初始化:
model類:

1).h文件

#import <UIKit/UIKit.h>#import "Item.h"@interface Model : UIScrollView@property(nonatomic,strong)UIButton *button;@property(nonatomic,strong)UILabel *label;//判斷button是否被點擊@property(nonatomic,assign)BOOL isClicked;-(instancetype)initWithItem:(Item *)item;//重置模型-(void)resetModel;@end

2).m文件

-(instancetype)initWithItem:(Item *)item{ self = [super initWithFrame:CGRectMake(20, 20, 80, 100)]; if (self) {  //設置模塊  self.contentSize = CGSizeMake(80, self.frame.size.height * 2);  self.pagingEnabled = NO;      //設置模塊屬性  self.button = [[UIButton alloc] initWithFrame:CGRectMake(0, 0, self.frame.size.width, self.contentSize.height)];  [self.button addTarget:self action:@selector(buttonDidClicked) forControlEvents:UIControlEventTouchUpInside];  //添加圖片視圖到button上  UIImageView *imgView = [[UIImageView alloc] initWithFrame:CGRectMake(0, 0, self.frame.size.width, self.frame.size.height)];  [imgView setImage:[UIImage imageNamed:item.imgPath]];  [self.button addSubview:imgView];  //設置button是否被點擊  self.isClicked = NO;  [self addSubview:self.button];    self.label = [[UILabel alloc] initWithFrame:CGRectMake(0, self.frame.size.height, self.frame.size.width, self.frame.size.height)];  self.label.text = item.desStr;  self.label.font = [UIFont systemFontOfSize:15];  self.label.textColor = [UIColor blackColor];  self.label.numberOfLines = 0;  self.label.textAlignment = NSTextAlignmentLeft;  [self addSubview:self.label]; } return self;}

3)button的點擊事件:即點擊圖片文字描述就會從下面升上來,再點擊就會降下去的動作:

/label升降-(void)buttonDidClicked{ if (self.isClicked == NO) {  [UIView animateWithDuration:0.5 animations:^{   self.contentOffset = CGPointMake(0, self.frame.size.height);  }];  self.isClicked = YES; }else if (self.isClicked == YES) {  [UIView animateWithDuration:0.5 animations:^{   self.contentOffset = CGPointMake(0, 0);  }];  self.isClicked = NO; }}

另外,由于必須保證每次添加model到視圖上時顯示的是圖片,所以需要一個方法來復原到初始狀態,即一旦從視圖上刪除就復原:

//復原-(void)resetModel{  self.contentOffset = CGPointMake(0, 0);  self.isClicked = NO;}

3、模型準備好了,下面在viewController類里面寫一個方法將plist文件數據讀取出來封裝到item對象里面,再用item對象初始化model對象,將所有model對象存入可變數組(_allItems)里面:

//加載數據到物品-(void)loadData{//讀取數據 NSString *filePath = [[NSBundle mainBundle] pathForResource:@"shop" ofType:@"plist"]; NSArray *itemArr = [NSArray arrayWithContentsOfFile:filePath]; //創建模型 for (int i =0;i <[itemArr count] ; i++) {  Item *item = [[Item alloc] initWithString:[[itemArr objectAtIndex:i] objectForKey:@"title"] andimgPath:[[itemArr objectAtIndex:i] objectForKey:@"pic"]];  Model *model = [[Model alloc] initWithItem:item];  //未被添加的為0,添加好的為1  model.tag = 0;  [_allItems addObject:model]; }}

**注意:**model的tag是用于判斷model是否已經被添加到視圖里面,從而只會添加數組里面未添加的model,已添加的model也會用一個數組(displayedItems)來存儲,方便刪除

4、添加和刪除按鈕及其響應的方法:

1)add按鈕:

創建:

//添加添加按鈕 UIButton *addButton = [[UIButton alloc] initWithFrame:CGRectMake(_width*2/3, _height/10, 40, 40)]; [addButton setImage:[UIImage imageNamed:@"add"] forState:UIControlStateNormal]; [addButton addTarget:self action:@selector(add) forControlEvents:UIControlEventTouchUpInside]; [self.view addSubview:addButton];

add方法:

//添加事件-(void)add{ NSInteger itemCount = [_displayedItems count]; for (Model* model in _allItems) {  if (model.tag == 0) {   switch (itemCount) {    case 1:     model.frame = CGRectMake(40 + model.frame.size.width, 20, 80, 100);     break;    case 2:     model.frame = CGRectMake(60 + model.frame.size.width*2, 20, 80, 100);     break;    case 3:     model.frame = CGRectMake(20,40 + model.frame.size.height, 80, 100);     break;    case 4:     model.frame = CGRectMake(40 + model.frame.size.width, 40 + model.frame.size.height, 80, 100);     break;    case 5:     model.frame = CGRectMake(60 + model.frame.size.width*2, 40 + model.frame.size.height, 80, 100);     break;    default:     break;   }   [_scrollView addSubview:model];   [_displayedItems addObject:model];   model.tag = 1;   break;  } }}

2)delete按鈕:

//添加刪除按鈕 UIButton *deleteButton = [[UIButton alloc] initWithFrame: CGRectMake(_width/5, _height/10, 40, 40)]; [deleteButton setImage:[UIImage imageNamed:@"delete"] forState:UIControlStateNormal]; [deleteButton addTarget:self action:@selector(delete) forControlEvents:UIControlEventTouchUpInside]; [self.view addSubview:deleteButton];

delete方法:

-(void)delete{ Model *model = _displayedItems.lastObject; [model removeFromSuperview]; model.tag = 0; [model resetModel]; [_displayedItems removeObject:model];}

嗯,由于這里為了方便,所以添加控件時的位置判斷直接寫死了,所以還有待改進。以上就是用按鈕添加控件這個demo的主要部分,另外還有那個背景圖片的模糊處理使用的是UIVisualEffectView類實現的,在此不詳述了。

代碼不足之處:

1、位置判斷寫死了
2、模型其實建一個類就夠了,Item類有點多余

進階方案:

1、通過拖動圖標放置在父視圖任何位置
2、點擊控件文字顯示于圖片之上,圖片成為背景并虛化

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲a∨日韩av高清在线观看| 中文字幕日韩av综合精品| 欧美大学生性色视频| 久久久久国产精品免费| 国产精品91久久久| 57pao成人国产永久免费| 色综合久久中文字幕综合网小说| 亚洲美女免费精品视频在线观看| 欧美性高潮在线| 精品国产一区二区三区久久狼5月| 久久综合国产精品台湾中文娱乐网| 中文字幕日韩综合av| 97精品欧美一区二区三区| 精品国产老师黑色丝袜高跟鞋| 日韩国产高清视频在线| 久久九九国产精品怡红院| 精品亚洲一区二区| 亚洲视频自拍偷拍| 欧美视频在线免费| 欧美另类交人妖| 色妞在线综合亚洲欧美| 欧美极品少妇xxxxⅹ裸体艺术| 欧美中文在线观看国产| 亚洲精品福利在线| 欧美最猛性xxxx| 欧美在线精品免播放器视频| 成人黄色在线播放| 欧美在线免费视频| 欧美激情免费视频| 国产成人高清激情视频在线观看| 欧美国产日韩免费| 91高潮精品免费porn| 国产视频一区在线| 欧美在线观看一区二区三区| 色视频www在线播放国产成人| 国产日韩在线视频| 欧美精品www在线观看| 亚州欧美日韩中文视频| 国产91成人在在线播放| 国产视频精品在线| 欧美性猛交xxxx免费看| 91精品在线一区| 精品人伦一区二区三区蜜桃免费| 欧美在线激情网| 97在线视频免费看| 夜夜躁日日躁狠狠久久88av| 91av福利视频| 91久久国产综合久久91精品网站| 国产精品高潮呻吟久久av黑人| 91精品久久久久久| 日韩视频第一页| 人体精品一二三区| 欧美老女人性视频| 色综合老司机第九色激情| 久久精品国产成人| 91精品国产高清| 国产精品999999| 中文字幕成人精品久久不卡| 中文字幕日本精品| 7777免费精品视频| 日韩av手机在线| 欧美视频在线观看 亚洲欧| 日韩精品一二三四区| 成人欧美一区二区三区黑人孕妇| 午夜精品久久久久久久99热浪潮| 色综合伊人色综合网站| 亚洲va久久久噜噜噜久久天堂| 中文字幕日韩在线视频| 国产69精品久久久久9999| 国外成人在线播放| 成人免费激情视频| 日韩av网站导航| 欧美激情2020午夜免费观看| 国内精品一区二区三区| 懂色av中文一区二区三区天美| 4388成人网| 久久久之久亚州精品露出| 国产精品久久久久免费a∨大胸| 91国偷自产一区二区三区的观看方式| 有码中文亚洲精品| 国产成人a亚洲精品| 精品成人乱色一区二区| 久久91亚洲精品中文字幕| 日韩成人av在线播放| 伊人男人综合视频网| 亚洲黄色av女优在线观看| 国产精品精品久久久久久| 在线色欧美三级视频| 成人欧美一区二区三区在线湿哒哒| 国语自产精品视频在线看抢先版图片| 亚洲精品91美女久久久久久久| 成人a视频在线观看| 欧美电影在线播放| 亚洲精品日韩激情在线电影| 国产成人在线精品| 日韩视频免费中文字幕| 中国日韩欧美久久久久久久久| 国产一区二区三区直播精品电影| 日韩欧美在线中文字幕| 久久精品国产v日韩v亚洲| 欧美人在线观看| 日韩在线观看免费高清完整版| 国产亚洲人成网站在线观看| 性欧美xxxx交| 中文日韩在线观看| 精品欧美激情精品一区| 亚洲一区二区国产| 欧美专区福利在线| 国内久久久精品| 亚洲视频日韩精品| 久久久久一本一区二区青青蜜月| 精品久久久香蕉免费精品视频| 日韩午夜在线视频| 欧美限制级电影在线观看| 亚洲欧洲日本专区| 国产一区二区在线免费视频| 中文字幕在线精品| 国产在线观看精品| 国产视频久久网| 欧美视频二区36p| 国产主播在线一区| 91精品国产综合久久香蕉最新版| 成人国产精品久久久| 日韩动漫免费观看电视剧高清| 国产综合久久久久| 国产精品羞羞答答| 国模视频一区二区三区| 欧美精品在线视频观看| 精品美女永久免费视频| 日韩免费在线看| 91久久精品国产91性色| 日韩国产激情在线| 夜夜嗨av一区二区三区四区| 日韩人在线观看| 日韩在线视频观看正片免费网站| 96pao国产成视频永久免费| 91最新在线免费观看| 久久夜色精品国产亚洲aⅴ| 久久精品中文字幕免费mv| 亚洲精品黄网在线观看| 日韩在线不卡视频| 亚洲qvod图片区电影| 韩国日本不卡在线| 色一区av在线| 57pao成人永久免费视频| 成人妇女淫片aaaa视频| 国产香蕉一区二区三区在线视频| 久久天堂电影网| 91老司机在线| 国产精品自拍网| 日韩av电影手机在线观看| 欧日韩不卡在线视频| 5566日本婷婷色中文字幕97| 欧美视频在线观看免费网址| 高跟丝袜欧美一区| 国产精品一区二区av影院萌芽| 亚洲第一中文字幕在线观看| 九九热这里只有在线精品视| 欧美日韩视频免费播放| 欧美精品一本久久男人的天堂| 精品欧美一区二区三区| 日韩在线播放一区| 一夜七次郎国产精品亚洲| 欧美国产日韩在线|