[UI基础][实现]九宫格之应用程序管理
[目标]
1、完成下图所示的View,View中的图片、文字数据从app.list文件读出。
2、思考代码哪里可以进行优化。
[分析]
1、创建控件
整个View分12个部分,其中包含一个 UIImageView、UILabel、UIButton,这三个控件可以作为一个整体
作为subView的子控件。那么先创建12个subView,然后为每个subView添加三个子控件。
view
| ----- subView
| | ---- UIImageView
| | ---- UILabel
| | ---- UIButton
... ...
| ----- subView
| | ---- UIImageView
| | ---- UILabel
| | ---- UIButton
2、为子控件填充数据
控件的图片数据以及文字数据都存储在app.plist文件中,这个文件是存储了字典对象的12个数组,通过mainBundle
获取文件的路径然后创建字典导出数据并加载到相应的控件。
[实现]
1、创建工程,加载必要的素材以及文件到工程。
略
2、创建12个subView
创建一个subView可以分以下几个步骤进行:
//2.1 创建subView
UIView *subView = [[UIView alloc] init];
//2.2 设置subView的frame
subView.frame = CGRectMake(subViewX, subViewY, subViewW, subViewH);
// 3.3.添加subView到控制器的view
[self.view addSubview:subView];
3、为subView加载图片、文字
subView的图片文字属性存储在app.plist文件,首先把这个文件的数据导出到一个数组中。
3.1 添加属性
@interface ViewController ()
/** 存放应用信息 */
@property (nonatomic, strong) NSArray *appData;
@end
3.2 重写appData的getter
- (NSArray *)apps {
if (_apps == nil) {
// 1.获得plist的全路径
NSString *path = [[NSBundle mainBundle] pathForResource:@"app.plist" ofType:nil];
// 2.加载数组
_appData = [NSArray arrayWithContentsOfFile:path];
}
return _appData;
}
现在数据以及导出到appData这个数组中了,而这个数组的元素是字典,根据key分别读出图片文字信息加载到
相应的控件的属性。
3.3 添加图片数据到UIImagView
NSDictionary *appInfo = self.appData[index];
// 3.3.1.添加图片
UIImageView *iconView = [[UIImageView alloc] init];
// 3.3.2 设置frame
iconView.frame = CGRectMake(iconX, iconY, iconW, iconH);
// 3.3.3 设置图片
iconView.image = [UIImage imageNamed:appInfo[@"icon"]];
[subView addSubview:iconView];
3.4 添加Label的文本属性
// 3.4.1 创建Label
UILabel *nameLabel = [[UILabel alloc] init];
// 3.4.2 设置frame
nameLabel.frame = CGRectMake(nameX, nameY, nameW, nameH);
// 设置文字
nameLabel.text = appInfo[@"name"];
// 设置字体
nameLabel.font = [UIFont systemFontOfSize:13];
// 设置文字居中对齐
nameLabel.textAlignment = NSTextAlignmentCenter;
[appView addSubview:nameLabel];
3.4 添加下载按钮
略
至此,整个UI的根据以上的步骤可以完成。全部代码如下
- (void)viewDidLoad
{
[super viewDidLoad]; // 0.总列数(一行最多3列)
int totalColumns = ; // 1.应用的尺寸
CGFloat subViewW = ;
CGFloat subViewH = ; // 2.间隙 = (控制器view的宽度 - 3 * 应用宽度) / 4
CGFloat marginX = (self.view.frame.size.width - totalColumns * subViewW) / (totalColumns + );
CGFloat marginY = ; // 3.根据应用个数创建对应的框框(index 0 ~ 11)
for (int index = ; index<self.appData.count; index++) {
// 3.1.创建1小框框
UIView *subView = [[UIView alloc] init]; // 3.2.计算框框的位置
// 计算行号和列号
int row = index / totalColumns;
int col = index % totalColumns;
// 计算x和y
CGFloat subViewX = marginX + col * (subViewW + marginX);
CGFloat subViewY = + row * (subViewH + marginY);
// 设置frame
subView.frame = CGRectMake(subViewX, subViewY, subViewW, subViewH); // 3.3.添加框框到控制器的view
[self.view addSubview:subView]; // 3.4.添加内部的小控件
// 3.4.0.index位置对应的应用信息
NSDictionary *appInfo = self.appData[index]; // 3.4.1.添加图片
UIImageView *iconView = [[UIImageView alloc] init];
// 设置位置
CGFloat iconW = ;
CGFloat iconH = ;
CGFloat iconX = (subViewW - iconW) * 0.5;
CGFloat iconY = ;
iconView.frame = CGRectMake(iconX, iconY, iconW, iconH);
// 设置图片
iconView.image = [UIImage imageNamed:appInfo[@"icon"]];
[subView addSubview:iconView]; // 3.4.2.添加名字
UILabel *nameLabel = [[UILabel alloc] init];
// 设置位置
CGFloat nameW = subViewW;
CGFloat nameH = ;
CGFloat nameX = ;
CGFloat nameY = iconY + iconH;
nameLabel.frame = CGRectMake(nameX, nameY, nameW, nameH);
// 设置文字
nameLabel.text = appInfo[@"name"];
// 设置字体
nameLabel.font = [UIFont systemFontOfSize:];
// 设置文字居中对齐
nameLabel.textAlignment = NSTextAlignmentCenter;
[subView addSubview:nameLabel]; // 3.4.3.添加下载按钮
UIButton *downloadBtn = [[UIButton alloc] init];
// 设置位置
CGFloat downloadX = ;
CGFloat downloadY = nameY + nameH;
CGFloat downloadW = subViewW - * downloadX;
CGFloat downloadH = ;
downloadBtn.frame = CGRectMake(downloadX, downloadY, downloadW, downloadH);
// 设置默认的背景
UIImage *normalImage = [UIImage imageNamed:@"buttongreen"];
[downloadBtn setBackgroundImage:normalImage forState:UIControlStateNormal];
// 设置高亮的背景
UIImage *highImage = [UIImage imageNamed:@"buttongreen_highlighted"];
[downloadBtn setBackgroundImage:highImage forState:UIControlStateHighlighted];
// 设置按钮的文字
[downloadBtn setTitle:@"下载" forState:UIControlStateNormal];
// 不推荐直接拿到按钮内部的label设置文字
// downloadBtn.titleLabel.text = @"5435345345";
// 设置按钮文字的字体
downloadBtn.titleLabel.font = [UIFont systemFontOfSize:];
[subView addSubview:downloadBtn];
}
} - (NSArray *)appData
{
if (_appData == nil) {
// 初始化 // 1.获得plist的全路径
NSString *path = [[NSBundle mainBundle] pathForResource:@"app.plist" ofType:nil]; // 2.加载数组
_appData = [NSArray arrayWithContentsOfFile:path];
}
return _appData;
}
[UI基础][实现]九宫格之应用程序管理的更多相关文章
- iOS UI基础-4.0应用程序管理
功能与界面 功能分析: 以九宫格的形式展示应用信息 点击下载按钮后,做出相应的操作 步骤分析: 加载应用信息 根据应用的个数创建对应的view 监听下载按钮点击 整个应用界面: 程序实现 思路 UI布 ...
- iOS UI基础-4.1应用程序管理 字典转Model
用模型取代字典 使用字典的坏处 一般情况下,设置数据和取出数据都使用“字符串类型的key”,编写这些key时,编辑器没有智能提示,需要手敲 dict[@"name"] = @&qu ...
- UI基础UIWindow、UIView
UI基础UIWindow.UIView 在PC中,应用程序多是使用视窗的形式显示内容,手机应用也不例外,手机应用中要在屏幕上显示内容首先要创建一个窗口承载内容,iOS应用中使用UIWindow.UIV ...
- CentOS学习笔记--程序管理
程序管理 一个程序被加载到内存当中运行,那么在内存内的那个数据就被称为程序(process).程序是操作系统上非常重要的概念, 所有系统上面跑的数据都会以程序的型态存在.那么系统的程序有哪些状态?不同 ...
- iOS开发UI基础—手写控件,frame,center和bounds属性
iOS开发UI基础—手写控件,frame,center和bounds属性 一.手写控件 1.手写控件的步骤 (1)使用相应的控件类创建控件对象 (2)设置该控件的各种属性 (3)添加控件到视图中 (4 ...
- Android UI基础教程 目录
从csdn下载了这本英文版的书之后,又去京东搞了一个中文目录下来.对照着看. 话说,这本书绝对超值.有money的童鞋看完英文版记得去买中文版的~~ Android UI基础教程完整英文版 pdf+源 ...
- Android项目实战--手机卫士20--拿到已经安装了的程序以及程序管理主界面
好了,之前我们就讲了高级工具里面的短信备份与还原,那么我们高级工具里面的功能就基本上完成的啦,还有一个叫程序锁的功能而已,但我们今天先不做它先,我们先把我们的程序管理这个功能完成先. 先让大家看一下我 ...
- 游戏UI框架设计(三) : 窗体的层级管理
游戏UI框架设计(三) ---窗体的层级管理 UI框架中UI窗体的"层级管理",最核心的问题是如何进行窗体的显示管理.窗体(预设)的显示我们前面定义了三种类型: 普通.隐藏其他.反 ...
- .NET应用程序管理服务AMS设计
AMS全称是Application Management Server即应用程序管理服:由于经常要写些一些应用服务,每次部署和维护都比较麻烦,首先要针对服务编写一个windows服务程序方便系统启动里 ...
随机推荐
- chrome单步调试代码
单步调试代码 所有步骤选项均通过边栏中的可点击图标 表示,但也可以通过快捷键触发(鼠标悬停在操作图标上就可以看到快捷键).下面是简要介绍: 图标/按钮 操作 描述 Resume 继续执行直到下一个断点 ...
- salt更换新key
1 停止salt-minion服务 service salt-minion stop 2 删除salt-minion公钥文件 rm /etc/salt/pki/minion/minion.pub r ...
- 破谣言——iPhone砍价
微信朋友圈和QQ空间很多朋友在传一个iPhone砍价免费送的活动.好吧,砍页面下面的那邪恶广告,第一感觉就是假的.但我要给出证明,所以就有了下面的代码.[只需把UID换成自己的就行],当你砍到5分钱的 ...
- Android 通过Socket 和服务器通讯
Extends:(http://www.cnblogs.com/likwo/p/3641135.html) Android 通过Socket 和服务器通讯,是一种比较常用的通讯方式,时间比较紧,说下大 ...
- mysql 选择优化的数据类型
选择最小的数据类型,因为它们占更少的磁盘,内存和CPU缓存: 选择简单的数据类型,如用整型来存储ip: http://blog.csdn.net/lyd518/article/details/2070 ...
- python2在安装pywin32后出现ImportError: DLL load failed 解决方法
python2在安装pywin32后出现ImportError: DLL load failed 解决方法 在python2中有时候会出现: import win32api ImportError ...
- CentOS7使用yum安装nginx
CentOS默认没有nginx的yum源需要yum安装nginx可以使用一下方法 一,环境检测 二,设置yum源 rpm -Uvh http://nginx.org/packages/centos/7 ...
- HOJ 2139 Spiderman's workout(动态规划)
Spiderman's workout My Tags (Edit) Source : Nordic Collegiate Programming Contest 2003 Time limit : ...
- 用了快1年的MacBook Pro遇到的硬件问题
去年11月7日买的MacBook Pro,到目前快1年了,遇到了3个硬件问题(之前用了5年的Thinkpad在5年内未出现任何硬件问题): 1. 有一次MacBook放在背包中,背包拎在手上落在地上, ...
- struts2的琐碎知识点
servlet:void init(ServletConfig cfg):// 读取servlet的配置参数void service(ServletRequest request, ServletRe ...