iOS应用管理(字典转模型)
2017-09-01 17:15
387 查看
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #1e9421 }
span.s1 { }
1. 新建appViewModel
1.1声明需要的属性
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #1e9421 }
p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #c42275 }
p.p3 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px "PingFang SC"; color: #1e9421 }
p.p4 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #000000 }
span.s1 { }
span.s2 { font: 18.0px "PingFang SC" }
span.s3 { color: #000000 }
span.s4 { color: #6122ae }
span.s5 { font: 18.0px Menlo }
span.s6 { color: #c42275 }
//NSString一般用copy来修饰
@property(nonatomic,copy)NSString *name;
@property(nonatomic,copy)NSString *icon;
//字典转模型的方法
- (id)initWithDict:(NSDictionary *)dict;
1.2字典转模型
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #000000 }
p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #000000; min-height: 21.0px }
p.p3 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #c42275 }
span.s1 { }
span.s2 { color: #c42275 }
span.s3 { color: #6122ae }
span.s4 { color: #3e1e81 }
span.s5 { color: #539aa4 }
span.s6 { color: #c81b13 }
span.s7 { color: #000000 }
- (id)initWithDict:(NSDictionary *)dict{
if(self = [super init]){
self.name = dict[@"name"];
self.icon = dict[@"icon"];
}
return self;
}
2.ViewController
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #c81b13 }
p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #3c828b }
p.p3 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #c42275 }
p.p4 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #000000; min-height: 21.0px }
p.p5 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #000000 }
p.p6 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #1e9421 }
p.p7 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #3e1e81 }
p.p8 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #6122ae }
span.s1 { color: #822d0f }
span.s2 { }
span.s3 { color: #c42275 }
span.s4 { color: #000000 }
span.s5 { color: #6122ae }
span.s6 { color: #539aa4 }
span.s7 { font: 18.0px "PingFang SC" }
span.s8 { color: #c81b13 }
span.s9 { color: #1e9421 }
span.s10 { font: 18.0px "PingFang SC"; color: #1e9421 }
span.s11 { color: #3e1e81 }
span.s12 { color: #3c828b }
span.s13 { color: #294c50 }
span.s14 { color: #703daa }
span.s15 { color: #0435ff }
span.s16 { font: 18.0px "PingFang SC"; color: #c81b13 }
#import "ViewController.h"
#import "appViewModel.h"
@interface ViewController ()
@property(nonatomic,strong)NSArray *apps;
@end
@implementation ViewController
- (NSArray *)apps{
if(_apps == nil){
//1-获取plist文件的路径
NSString *path = [[NSBundle mainBundle]pathForResource:@"app.plist" ofType:nil];
//2-读取文件
NSArray *dictArray = [NSArray arrayWithContentsOfFile:path];
//3-字典转模型
NSMutableArray *tempArr = [NSMutableArray array];
for(NSDictionary *dic in dictArray){
appViewModel *appModel = [[appViewModel alloc]initWithDict:dic];
[tempArr addObject:appModel];
}
_apps = tempArr;
}
return _apps;
}
- (void)viewDidLoad{
[super viewDidLoad];
//1-设置frame的相关属性
CGFloat appViewW = 100;
CGFloat appViewH = 120;
CGFloat spaceX = 20;
CGFloat spaceY = 30;
CGFloat topMargin = 30;
CGFloat leftmargin = (self.view.frame.size.width - 3 * appViewW - 2 * spaceX) * 0.5;
//2-创建格子
for( int i = 0; i < self.apps.count; i ++){
//2.1-创建一个格子视图
UIView *appView = [[UIView alloc]init];
int row = i / 3;//行号
int col = i % 3;//列号
CGFloat appViewX = leftmargin + (appViewW + spaceX) * col;
CGFloat appViewY = topMargin + (appViewH + spaceY) * row;
//2.2设置frame
appView.frame = CGRectMake(appViewX, appViewY, appViewW, appViewH);
//2.3添加
[self.view addSubview:appView];
appViewModel *appViewModel = self.apps[i];
//2.4添加图片
UIImageView *head = [[UIImageView alloc]init];
CGFloat headW = 60;
CGFloat headX = (appViewW - headW) *0.5;
CGFloat headY = 0;
CGFloat headH = 60;
head.image = [UIImage imageNamed: appViewModel.icon ];
head.frame = CGRectMake(headX, headY, headW, headH);
[appView addSubview:head];
// head.backgroundColor = [UIColor blueColor];
// 2.5添加label
// 2.5.1 创建一个文本标签
UILabel *nameLabel = [[UILabel alloc]init];
CGFloat nameLabelX = 0;
CGFloat nameLabelY = headY + headH;
CGFloat nameLabelW = appViewW;
CGFloat nameLabelH = 30;
nameLabel.frame = CGRectMake(nameLabelX, nameLabelY, nameLabelW, nameLabelH);
[appView addSubview:nameLabel];
// nameLabel.backgroundColor = [UIColor grayColor];
nameLabel.text = appViewModel.name;
// 2.5.2设置文字大小
nameLabel.font = [UIFont systemFontOfSize:13];
// 2.5.3设置文字居中
nameLabel.textAlignment = NSTextAlignmentCenter;
// 2.6添加button
UIButton *downLoadBtn = [[UIButton alloc]init];
CGFloat downLoadBtnX = 10;
CGFloat downLoadBtnY = nameLabelY + nameLabelH + 10;
CGFloat downLoadBtnW = appViewW - downLoadBtnX *2;
CGFloat downLoadBtnH = 30;
downLoadBtn.frame = CGRectMake(downLoadBtnX, downLoadBtnY, downLoadBtnW, downLoadBtnH);
[appView addSubview:downLoadBtn];
// downLoadBtn.backgroundColor = [UIColor greenColor];//设置背景色
[downLoadBtn setTitle:@"下载" forState:UIControlStateNormal];//设置文字
[downLoadBtn setBackgroundImage:[UIImage imageNamed:@"buttongreen"] forState:UIControlStateNormal];
[downLoadBtn setBackgroundImage: [UIImage imageNamed:@"buttongreen_highlighted"] forState:UIControlStateHighlighted];
// downLoadBtn.
// 按钮内部至少有两个控件,一个label,一个imageView,
downLoadBtn.titleLabel.font = [UIFont systemFontOfSize:14];
}
}
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #1e9421 }
span.s1 { }
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #c81b13 }
span.s1 { }
span.s1 { }
1. 新建appViewModel
1.1声明需要的属性
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #1e9421 }
p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #c42275 }
p.p3 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px "PingFang SC"; color: #1e9421 }
p.p4 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #000000 }
span.s1 { }
span.s2 { font: 18.0px "PingFang SC" }
span.s3 { color: #000000 }
span.s4 { color: #6122ae }
span.s5 { font: 18.0px Menlo }
span.s6 { color: #c42275 }
//NSString一般用copy来修饰
@property(nonatomic,copy)NSString *name;
@property(nonatomic,copy)NSString *icon;
//字典转模型的方法
- (id)initWithDict:(NSDictionary *)dict;
1.2字典转模型
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #000000 }
p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #000000; min-height: 21.0px }
p.p3 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #c42275 }
span.s1 { }
span.s2 { color: #c42275 }
span.s3 { color: #6122ae }
span.s4 { color: #3e1e81 }
span.s5 { color: #539aa4 }
span.s6 { color: #c81b13 }
span.s7 { color: #000000 }
- (id)initWithDict:(NSDictionary *)dict{
if(self = [super init]){
self.name = dict[@"name"];
self.icon = dict[@"icon"];
}
return self;
}
2.ViewController
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #c81b13 }
p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #3c828b }
p.p3 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #c42275 }
p.p4 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #000000; min-height: 21.0px }
p.p5 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #000000 }
p.p6 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #1e9421 }
p.p7 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #3e1e81 }
p.p8 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #6122ae }
span.s1 { color: #822d0f }
span.s2 { }
span.s3 { color: #c42275 }
span.s4 { color: #000000 }
span.s5 { color: #6122ae }
span.s6 { color: #539aa4 }
span.s7 { font: 18.0px "PingFang SC" }
span.s8 { color: #c81b13 }
span.s9 { color: #1e9421 }
span.s10 { font: 18.0px "PingFang SC"; color: #1e9421 }
span.s11 { color: #3e1e81 }
span.s12 { color: #3c828b }
span.s13 { color: #294c50 }
span.s14 { color: #703daa }
span.s15 { color: #0435ff }
span.s16 { font: 18.0px "PingFang SC"; color: #c81b13 }
#import "ViewController.h"
#import "appViewModel.h"
@interface ViewController ()
@property(nonatomic,strong)NSArray *apps;
@end
@implementation ViewController
- (NSArray *)apps{
if(_apps == nil){
//1-获取plist文件的路径
NSString *path = [[NSBundle mainBundle]pathForResource:@"app.plist" ofType:nil];
//2-读取文件
NSArray *dictArray = [NSArray arrayWithContentsOfFile:path];
//3-字典转模型
NSMutableArray *tempArr = [NSMutableArray array];
for(NSDictionary *dic in dictArray){
appViewModel *appModel = [[appViewModel alloc]initWithDict:dic];
[tempArr addObject:appModel];
}
_apps = tempArr;
}
return _apps;
}
- (void)viewDidLoad{
[super viewDidLoad];
//1-设置frame的相关属性
CGFloat appViewW = 100;
CGFloat appViewH = 120;
CGFloat spaceX = 20;
CGFloat spaceY = 30;
CGFloat topMargin = 30;
CGFloat leftmargin = (self.view.frame.size.width - 3 * appViewW - 2 * spaceX) * 0.5;
//2-创建格子
for( int i = 0; i < self.apps.count; i ++){
//2.1-创建一个格子视图
UIView *appView = [[UIView alloc]init];
int row = i / 3;//行号
int col = i % 3;//列号
CGFloat appViewX = leftmargin + (appViewW + spaceX) * col;
CGFloat appViewY = topMargin + (appViewH + spaceY) * row;
//2.2设置frame
appView.frame = CGRectMake(appViewX, appViewY, appViewW, appViewH);
//2.3添加
[self.view addSubview:appView];
appViewModel *appViewModel = self.apps[i];
//2.4添加图片
UIImageView *head = [[UIImageView alloc]init];
CGFloat headW = 60;
CGFloat headX = (appViewW - headW) *0.5;
CGFloat headY = 0;
CGFloat headH = 60;
head.image = [UIImage imageNamed: appViewModel.icon ];
head.frame = CGRectMake(headX, headY, headW, headH);
[appView addSubview:head];
// head.backgroundColor = [UIColor blueColor];
// 2.5添加label
// 2.5.1 创建一个文本标签
UILabel *nameLabel = [[UILabel alloc]init];
CGFloat nameLabelX = 0;
CGFloat nameLabelY = headY + headH;
CGFloat nameLabelW = appViewW;
CGFloat nameLabelH = 30;
nameLabel.frame = CGRectMake(nameLabelX, nameLabelY, nameLabelW, nameLabelH);
[appView addSubview:nameLabel];
// nameLabel.backgroundColor = [UIColor grayColor];
nameLabel.text = appViewModel.name;
// 2.5.2设置文字大小
nameLabel.font = [UIFont systemFontOfSize:13];
// 2.5.3设置文字居中
nameLabel.textAlignment = NSTextAlignmentCenter;
// 2.6添加button
UIButton *downLoadBtn = [[UIButton alloc]init];
CGFloat downLoadBtnX = 10;
CGFloat downLoadBtnY = nameLabelY + nameLabelH + 10;
CGFloat downLoadBtnW = appViewW - downLoadBtnX *2;
CGFloat downLoadBtnH = 30;
downLoadBtn.frame = CGRectMake(downLoadBtnX, downLoadBtnY, downLoadBtnW, downLoadBtnH);
[appView addSubview:downLoadBtn];
// downLoadBtn.backgroundColor = [UIColor greenColor];//设置背景色
[downLoadBtn setTitle:@"下载" forState:UIControlStateNormal];//设置文字
[downLoadBtn setBackgroundImage:[UIImage imageNamed:@"buttongreen"] forState:UIControlStateNormal];
[downLoadBtn setBackgroundImage: [UIImage imageNamed:@"buttongreen_highlighted"] forState:UIControlStateHighlighted];
// downLoadBtn.
// 按钮内部至少有两个控件,一个label,一个imageView,
downLoadBtn.titleLabel.font = [UIFont systemFontOfSize:14];
}
}
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #1e9421 }
span.s1 { }
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #c81b13 }
span.s1 { }
相关文章推荐
- ios-应用管理 字典转模型
- 07-应用管理(字典转模型)
- IOS2.1-应用管理示例(plist,模型,xib封装综合小示例)
- iOS_Runtime6_字典转化为模型应用
- iOS开发UI基础—07应用程序管理之字典转模型
- 详解iOS应用UI开发中的九宫格坐标计算与字典转换模型
- iOS开发中的字典转模型应用
- iOS开发UI篇—在UITableview的应用中使用动态单元格来完成app应用程序管理界面的搭建
- iOS 开发-字典转模型
- iOS 字典自动转模型
- 关于iOS应用管理之九宫格的坐标计算以及与UIScrollView的结合
- iOS UI-应用管理(使用Cell模板)
- 做服务的必看:应用性能管理成熟度模型 --Idea Worth Spread
- iOS开发UI篇—在UITableview的应用中使用动态单元格来完成app应用程序管理界面的搭建
- ios开发-UI基础-应用管理(单纯界面)改进4-xib封装
- 第四章:iOS应用漏洞利用 ——4.8 脆弱的会话管理机制
- iOS runtime字典转模型
- 应用:超级猜图(字典转模型,重写 description 方法)
- ios开发-UI基础-应用管理(单纯界面)改进5-使用代理实现监听下载按钮的点击(delegate)
- IOS 应用视图交互模型分析