zoukankan      html  css  js  c++  java
  • AJ学IOS(05)UI之360等下载管理器九宫格UI

    AJ分享,必须精品

    先看效果

    这里写图片描述
    这里写图片描述
    主要是完成了九宫格UI的搭建

    代码

    - (void)viewDidLoad {
        [super viewDidLoad];
    //九宫格中每个格子的宽
    #define kAppViewW 80
    //九宫格中每个格子的高
    #define kAppViewH 90
    ////九宫格中有多少个格子
    #define kColCount 3
    //九宫格中第一行距离屏幕最上边距离
    #define kStartY 20
    
        /*
         思路:将三个控件放到一个view中
         没有通过双层for循环换行,而是通过第几个然后判断他的行和列 来定位他的xy坐标完成
         012 在第一行:相当于i/kColCount
         //行 一行:012 二行:345 三行:678
         int row = i/kColCount;
         //列 一列:036  二列:147
         int col = i%kColCount;
    
         */
        //每行的间隔
        CGFloat marginX = (self.view.frame.size.width - kColCount*kAppViewW)/(kColCount+1);
        //每列的间隔
        CGFloat marginY = 10;
    
        for (int i=0; i<12; i++) {
    
            //行 一行:012 二行:345 三行:678
            int row = i/kColCount;
            //列 一列:036  二列:147
            int col = i%kColCount;
    
            CGFloat x = marginX + col*(marginX+kAppViewW);//每个view的X坐标
            CGFloat y = kStartY + +marginY + row * (marginY + kAppViewH);//每个view的Y坐标
    
    
            UIView *appView = [[UIView alloc] initWithFrame:CGRectMake(x, y ,kAppViewW, kAppViewH)];
            [self.view addSubview:appView];
    
    
            //实现视图内部细节
            NSDictionary *dict = self.appList[i];//得到appList中的每一个字典元素(图像 标题  按钮图像)
    
            //UIImageView:应用程序图片
            UIImageView *icon  = [[UIImageView alloc] initWithFrame:CGRectMake(0, 0, kAppViewW, 50)];
    //        icon .backgroundColor = [UIColor redColor];
            icon.image = [UIImage imageNamed:dict[@"icon"]];//设置图片
            //设置图片填充模式
            icon.contentMode = UIViewContentModeScaleAspectFit;//fill的会更大
    
            [appView addSubview:icon];
    
            //UILabel:应用程序名称
            UILabel *label = [[UILabel alloc] initWithFrame:CGRectMake(0, CGRectGetMaxY(icon.frame), kAppViewW, 20)];
            label.text = dict[@"name"];
            label.font = [UIFont systemFontOfSize:13.0];
            label.textAlignment = NSTextAlignmentCenter;
    
            [appView addSubview:label];
    
            //UIButton:应用程序下载按钮
            UIButton *button = [[UIButton alloc] initWithFrame:CGRectMake(0, CGRectGetMaxY(label.frame), kAppViewW, 20)];
            [button setBackgroundImage:[UIImage imageNamed:@"buttongreen"] forState:UIControlStateNormal];
            [button setBackgroundImage:[UIImage imageNamed:@"buttongreen_highlighted"] forState:UIControlStateHighlighted];
    
            [button setTitle:@"下载" forState:UIControlStateNormal];
            // *** 一定不要使用以下方法,修改按钮标题
            //        button.titleLabel.text = @"aaa";
    
            // 修改字体(titleLabel是只读的)
            // readonly表示不允许修改titleLabel的指针,但是可以修改label的字体
            // 提示:按钮的字体是不区分状态的!
            button.titleLabel.font = [UIFont systemFontOfSize:12.0];
            [appView addSubview:button];  
        }    
    }

    思路

    思路:将三个控件放到一个view中
    没有通过双层for循环换行,而是通过第几个然后判断他的行和列 来定位他的xy坐标完成
    012 在第一行:相当于i/kColCount
    //行 一行:012 二行:345 三行:678
    int row = i/kColCount;
    //列 一列:036 二列:147
    int col = i%kColCount;

    算法分析图

    这里写图片描述

    注意点

    设置图片与设置图片铺垫样子的时候有点不同,如果最后设置成UIViewContentModeScaleAspectFit的话会超出定义的边框,按照原来像素大小来布置。
    icon.image = [UIImage imageNamed:dict[@”icon”]];
    icon.contentMode = UIViewContentModeScaleAspectFit;

    UILabel;UIButton的字体设置

            //设置标题
            label.text = dict[@"name"];
            //设置字体大小
            label.font = [UIFont systemFontOfSize:13.0];
            //设置Label居中
            label.textAlignment = NSTextAlignmentCenter;

    button字体设置

    [button setTitle:@"下载" forState:UIControlStateNormal];
            // *** 一定不要使用以下方法,修改按钮标题
            //        button.titleLabel.text = @"aaa";
    
            // 修改字体(titleLabel是只读的)
            // readonly表示不允许修改titleLabel的指针,但是可以修改label的字体
            // 提示:按钮的字体是不区分状态的!
            button.titleLabel.font = [UIFont systemFontOfSize:12.0];
    
  • 相关阅读:
    怎样用Lodrunner测试WAP站点的性能(两种解决方案)
    LR测试登陆后进行的操作时 绕过登录
    单元测试 模块接口测试
    一个分布式服务器集群架构方案
    利用loadrunner代理方式,录制手机APP脚本
    安卓开发环境安卓
    安卓自动化测试(2)Robotium环境搭建与新手入门教程
    安卓自动化测试(1)安卓自动化测试原理概念
    HTML框架
    HTML5表单提交与PHP环境搭建
  • 原文地址:https://www.cnblogs.com/luolianxi/p/4990394.html
Copyright © 2011-2022 走看看