一、介绍一下ViewController中的结构

二、九宫格设计思路

三、代码实现

 // 点击增加按钮
- (void)add:(UIButton *)btn
{
// 定义一行中的列数(个数)
NSInteger cols = ; // 小格子的尺寸
NSInteger bagWidth = ;
NSInteger bagHeight = ; // 小格子横向之间的间距
CGFloat marginX = (self.shops.frame.size.width - (bagWidth*cols))/(cols - );
// 小格子纵向之间的间距
CGFloat marginY = ; // x方向的倍数
CGFloat x = bagWidth + marginX;
// y方向的倍数
CGFloat y = bagHeight + marginY; // 小格子的索引
NSInteger index = self.shops.subviews.count;
// 小格子x坐标
NSInteger tempX = index % cols; // 小格子所在的列
CGFloat bagX = tempX * x;
// 小格子y坐标
NSInteger tempY = index / cols; // 小格子所在的行
CGFloat bagY = tempY * y;
// 创建放图片和标签的view
UIView *bag = [[UIView alloc] init];
bag.frame = CGRectMake(bagX, bagY, bagWidth, bagHeight);
bag.backgroundColor = [UIColor redColor]; // 创建图片
UIImageView *image = [[UIImageView alloc] init];
[image setImage:[UIImage imageNamed:self.things[index][@"icon"]]];
image.frame = CGRectMake(, , , ); // 创建标签
UILabel *label = [[UILabel alloc] init];
label.frame = CGRectMake(, , , );
label.text = self.things[index][@"name"];
label.textAlignment = NSTextAlignmentCenter;
label.font = [UIFont systemFontOfSize:]; [bag addSubview:label];
[bag addSubview:image];
[self.shops addSubview:bag]; // 改变按钮状态
[self changeState:btn];
}

四、练习效果图

PS:参考小码哥视频教学,初学者膜拜大神!

iOS边练边学--九宫格布局的更多相关文章

  1. iOS边练边学--介绍布局的三种方法

    使用代码实现Autolayout的方法1- 创建约束 +(id)constraintWithItem:(id)view1attribute:(NSLayoutAttribute)attr1relate ...

  2. iOS边练边学--Http网络再学习,简单介绍

    一.URL 什么是URL URL中常见的协议 二.Http Http的基本通信过程 发送Http请求的方法 GET 和 POST 对比 GET 和 POST 的选择 三.iOS中的Http学习 iOS ...

  3. iOS边练边学--多线程介绍、NSThread的简单实用、线程安全以及线程之间的通信

    一.iOS中的多线程 多线程的原理(之前多线程这块没好好学,之前对多线程的理解也是错误的,这里更正,好好学习这块) iOS中多线程的实现方案有以下几种 二.NSThread线程类的简单实用(直接上代码 ...

  4. iOS边练边学--父子控件之作为导航控制器的子类产生的问题以及网易新闻练习

    一.导航控制器的子类 作为导航控制器的子类,并且是导航控制器子类中的第一个,系统会默认给子控件添加EdgeInsert属性,把导航栏的宽度挤出来.但是系统只会默认修改第一个. 解决办法1:系统帮忙给第 ...

  5. iOS边练边学--CALayer,非根层隐式动画,钟表练习

    一.CALayer UIView之所以能显示在屏幕上,完全是因为他内部的一个图层 在创建UIView对象时,UIView内部会自动创建一个图层(即CALayer对象),通过UIView的layer属性 ...

  6. iOS边练边学--UIGestureRecognizer手势识别器简单介绍

    iOS 3.2之后,苹果退出了手势识别功能(Gesture Recognizer),在触摸事件处理方面,大大简化了开发者的开发难度. 一.UIGestureRecognizer UIGestureRe ...

  7. iOS边练边学--触摸事件以及能够拖拽的UIView的练习

    一.用户在使用APP的过程中,会产生各种各样的事件.iOS中的事件可以分为3大类型: 二.响应者对象 在iOS中只有继承了了UIResponder的对象才能接受并处理事件,这样的对象称之为“响应者对象 ...

  8. iOS边练边学--应用数据存储的常用方式(plist,Preference,NSKeyedArchiver)其中的三种

    iOS应用数据存储的常用方式: XML属性列表(plist)归档 Preference(偏好设置) NSKeyedArchiver归档(NSCoding) SQLite3--这里暂且不讲 Core D ...

  9. iOS边练边学--图片的拉伸

    图片拉伸方法一: IOS 5.0以后才有的方法: - (void)viewDidLoad { [super viewDidLoad]; UIImageView *imageView = [[UIIma ...

随机推荐

  1. 【LeetCode】34. Search for a Range

    Search for a Range Given a sorted array of integers, find the starting and ending position of a give ...

  2. Evernote如何邮件分享

    把你的笔记通过邮件发送给别人,从而实现分享

  3. OAF_OAF编译代码至应用详解(案例)

    201-06-01 Created By BaoXinjian

  4. Android 自定义属性动画&Camera动画

      摘要: Android 自定义属性动画&Camera动画 1.相关知识点 对于Androi的帧动画,可以制作gif图片,有时为了能够动态的生成帧动画,就得需要使用代码构建了 Animati ...

  5. Android之getSystemService

    getSystemService是Android很重要的一个API,它是Activity的一个方法,根据传入的NAME来取得对应的Object,然后转换成相应的服务对象.以下介绍系统相应的服务. 传入 ...

  6. python中如果函数后面有多于一个括号是怎么回事?

    一般而言,调用一个函数是加一个括号.如果看见括号后还有一个括号,说明第一个函数返回了一个函数,如果后面还有括号,说明前面那个也返回了一个函数.以此类推. 比如fun()() def fun(): pr ...

  7. PHP通过__call实现简单的AOP(主事务后的其他操作)比如前置通知,后置通知

    /** * person class */ class Person { /** * person class -> function say */ public static function ...

  8. php批量删除数据库下指定前缀的表

    如何用php批量删除数据库下所有前缀为prefix_的表. 例子,统一删除前缀为“prefix_”的表. <?php //设置数据库连接信息.数据库服务器地址,数据库用户名,数据密码 mysql ...

  9. [na]802.1x协议无线认证协议&dot1x有线认证实验

    以前搞无线时候,会涉及到无线client接入方式的认证协议. 认证方式+加密方式+有线的dot1x. 注:以前都是doc粘贴到博客的,加上没写博客的习惯,因此会比较乱. EAP(扩展认证协议)是什么? ...

  10. 【Android】12.1 Intent基本概念

    分类:C#.Android.VS2015: 创建日期:2016-02-23 一.简介 Intent:意图,含义就是你想利用它调用哪个组件实现相关的功能,比如调用相机组件实现拍照.调用Contact组件 ...