[目标]

  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基础][实现]九宫格之应用程序管理的更多相关文章

  1. iOS UI基础-4.0应用程序管理

    功能与界面 功能分析: 以九宫格的形式展示应用信息 点击下载按钮后,做出相应的操作 步骤分析: 加载应用信息 根据应用的个数创建对应的view 监听下载按钮点击 整个应用界面: 程序实现 思路 UI布 ...

  2. iOS UI基础-4.1应用程序管理 字典转Model

    用模型取代字典 使用字典的坏处 一般情况下,设置数据和取出数据都使用“字符串类型的key”,编写这些key时,编辑器没有智能提示,需要手敲 dict[@"name"] = @&qu ...

  3. UI基础UIWindow、UIView

    UI基础UIWindow.UIView 在PC中,应用程序多是使用视窗的形式显示内容,手机应用也不例外,手机应用中要在屏幕上显示内容首先要创建一个窗口承载内容,iOS应用中使用UIWindow.UIV ...

  4. CentOS学习笔记--程序管理

    程序管理 一个程序被加载到内存当中运行,那么在内存内的那个数据就被称为程序(process).程序是操作系统上非常重要的概念, 所有系统上面跑的数据都会以程序的型态存在.那么系统的程序有哪些状态?不同 ...

  5. iOS开发UI基础—手写控件,frame,center和bounds属性

    iOS开发UI基础—手写控件,frame,center和bounds属性 一.手写控件 1.手写控件的步骤 (1)使用相应的控件类创建控件对象 (2)设置该控件的各种属性 (3)添加控件到视图中 (4 ...

  6. Android UI基础教程 目录

    从csdn下载了这本英文版的书之后,又去京东搞了一个中文目录下来.对照着看. 话说,这本书绝对超值.有money的童鞋看完英文版记得去买中文版的~~ Android UI基础教程完整英文版 pdf+源 ...

  7. Android项目实战--手机卫士20--拿到已经安装了的程序以及程序管理主界面

    好了,之前我们就讲了高级工具里面的短信备份与还原,那么我们高级工具里面的功能就基本上完成的啦,还有一个叫程序锁的功能而已,但我们今天先不做它先,我们先把我们的程序管理这个功能完成先. 先让大家看一下我 ...

  8. 游戏UI框架设计(三) : 窗体的层级管理

    游戏UI框架设计(三) ---窗体的层级管理 UI框架中UI窗体的"层级管理",最核心的问题是如何进行窗体的显示管理.窗体(预设)的显示我们前面定义了三种类型: 普通.隐藏其他.反 ...

  9. .NET应用程序管理服务AMS设计

    AMS全称是Application Management Server即应用程序管理服:由于经常要写些一些应用服务,每次部署和维护都比较麻烦,首先要针对服务编写一个windows服务程序方便系统启动里 ...

随机推荐

  1. chrome单步调试代码

    单步调试代码 所有步骤选项均通过边栏中的可点击图标 表示,但也可以通过快捷键触发(鼠标悬停在操作图标上就可以看到快捷键).下面是简要介绍: 图标/按钮 操作 描述 Resume 继续执行直到下一个断点 ...

  2. salt更换新key

    1  停止salt-minion服务 service salt-minion stop 2 删除salt-minion公钥文件 rm /etc/salt/pki/minion/minion.pub r ...

  3. 破谣言——iPhone砍价

    微信朋友圈和QQ空间很多朋友在传一个iPhone砍价免费送的活动.好吧,砍页面下面的那邪恶广告,第一感觉就是假的.但我要给出证明,所以就有了下面的代码.[只需把UID换成自己的就行],当你砍到5分钱的 ...

  4. Android 通过Socket 和服务器通讯

    Extends:(http://www.cnblogs.com/likwo/p/3641135.html) Android 通过Socket 和服务器通讯,是一种比较常用的通讯方式,时间比较紧,说下大 ...

  5. mysql 选择优化的数据类型

    选择最小的数据类型,因为它们占更少的磁盘,内存和CPU缓存: 选择简单的数据类型,如用整型来存储ip: http://blog.csdn.net/lyd518/article/details/2070 ...

  6. python2在安装pywin32后出现ImportError: DLL load failed 解决方法

    python2在安装pywin32后出现ImportError: DLL load failed 解决方法 在python2中有时候会出现: import win32api   ImportError ...

  7. CentOS7使用yum安装nginx

    CentOS默认没有nginx的yum源需要yum安装nginx可以使用一下方法 一,环境检测 二,设置yum源 rpm -Uvh http://nginx.org/packages/centos/7 ...

  8. HOJ 2139 Spiderman's workout(动态规划)

    Spiderman's workout My Tags (Edit) Source : Nordic Collegiate Programming Contest 2003 Time limit : ...

  9. 用了快1年的MacBook Pro遇到的硬件问题

    去年11月7日买的MacBook Pro,到目前快1年了,遇到了3个硬件问题(之前用了5年的Thinkpad在5年内未出现任何硬件问题): 1. 有一次MacBook放在背包中,背包拎在手上落在地上, ...

  10. struts2的琐碎知识点

    servlet:void init(ServletConfig cfg):// 读取servlet的配置参数void service(ServletRequest request, ServletRe ...