前言:

IOS的界面,分为:状态栏、导航栏、主界面、底部状态栏。

本篇讲述主界面的相对布局,其它三个的操作,在其它文章独立讲述。

1、相对布局的基本语法:

 基本方法定义:

//!相对当前UI的父视图布局 XYLocation 决定相对的位置
-(UIView*)relate:(XYLocation)location v:(CGFloat)value;
-(UIView*)relate:(XYLocation)location v:(CGFloat)value v2:(CGFloat)value2;
-(UIView*)relate:(XYLocation)location v:(CGFloat)value v2:(CGFloat)value2 v3:(CGFloat)value3;
-(UIView*)relate:(XYLocation)location v:(CGFloat)value v2:(CGFloat)value2 v3:(CGFloat)value3 v4:(CGFloat)value4;

XYLocation的枚举定义:

//!布局时的相对位置(取值的依据为:Left:1 Top:2 Ritht:3 Bottom:4 可以根据值来检测所相对哪些位置)
typedef NS_ENUM(NSUInteger,XYLocation)  {
    Left = 1,
    LeftTop = 12,
    LeftTopRight = 123,
    LeftTopBottom = 124,
    LeftRight = 13,
    LeftBottom = 14,
    LeftBottomRight = 143,
    
    Top = 2,
    TopRight = 23,
    TopBottom = 24,
    TopRightBottom = 234,
    
    Right = 3,
    RightBottom = 34,
    
    Bottom = 4,
    //相对四边
    LeftTopRightBottom = 1234
};

2、布局示例:

布局的起始写法:

如果是在XXXUIView中:以self开头
如果是在XXXController中:以小写sagit开头(宏定义为self.view)

示例:

 

添加logo图标的布局:

写法一:相对左上右固定三个位置。

[[[sagit addImageView:@"logo" img:@"logo"] width:170 height:170] relate:LeftTopRight v:290 v2:200 v3:290];

写法二:相对顶部位置,再居中。

[[[[sagit addImageView:@"logo" img:@"logo"] width:170 height:170] relate:Top v:200] toCenter:X];

 

3、定义添加控件时设定XY坐标(即默认为相对 LeftTop的相对布局)

如:添加logo图片并定义宽高和初始坐标(相对父UI)

[[sagit addImageView:nil img:@"logo"] width:170 height:170 x:290 y:200];

和以下代码功能一致:

 [[[sagit addImageView:nil img:@"logo"] width:170 height:170] relate:LeftTop v:290 v2:200];

 

总结:

Sagit的布局比较简单,只要看着标注好的图写代码就可以了。

相对布局是相对于父UI、下一篇介绍同级UI的相对布局使用方法。

posted on 2020-08-12 17:19  路过秋天  阅读(364)  评论(0编辑  收藏  举报
路过秋天