View的定位
iOS界面组成
data:image/s3,"s3://crabby-images/3a07b/3a07be180c5aa68daaadd6c6a1283f308891db3e" alt=""
UIView的层次:
UIView的层次是树状的
data:image/s3,"s3://crabby-images/bd1f4/bd1f4a960bebe0e3a01720608e44160a552183d4" alt=""
iOS坐标的表示方式
左上角为(0,0)开始增大
data:image/s3,"s3://crabby-images/c6691/c669174c5fe06e6b247689cf8e25cabc537ff869" alt=""
控件位置的表示方式CoreGraphics - CGGeometry
描述View的位置大小
CGRect{CGPoint origin,GSize size}
:CGRect结构中有2个元素origin,size,其中:
CGPoint{CGFloat x,CGFloat y}
:origin为CGPoint类,CGPoint结构2个元素,表示起点位置
CGPoint{CGFloat width,CGFloat height}
:size为CGSize类,CGSize结构2个元素,表示大小
例:
//view位置还原
CGRect rect = CGRectMake(0.0f, 0.0f, self.view.frame.size.width, self.view.frame.size.height);
self.view.frame = rect;
view.frame
在superview里的位置大小描述
//创建新View
CGRect frame =CGRectMake(0.0f,0.0f,100.0f,100.0f);
frame.origin.x = 100.0f;
frame.origin = CGPointMake(10.0f, 10.0f);
frame.size.height =200.0f;
frame.size = CGSizeMake(150.0f, 150.0f);
UIView * view =[[UIView alloc]initWithFrame:frame];
view.backgroundColor =[UIColor redColor];
[self.view addSubview:view];
view.bounds
在self.view里的位置大小描述
Center
data:image/s3,"s3://crabby-images/a1fe3/a1fe37a892520a706a77633ce9bbd59e661717f1" alt=""
View.transform
CGAffineTransform transForm
二维图形变换:包括平移、旋转、缩放
在界面旋转时作用很大
处理界面方向
在设备转动时,界面保持原来方向,则需要反向转相应角度。
界面布局 - Autoresizing
iOS2.0以后加入,现在推荐用Autolayout
有2点原因需要认真学习
- 在很多情况下比较方便
- nib实例化出来的默认开着Autoresizing
界面布局的过程
super view
-layoutSubviews//iOS后继版本实现了autolayout支持
-setNeedsLayout//下次重新绘制前需要重新推算布局
-layoutIfNeeded//立即重新推算布局
布局的主要工作
确定界面元素之间的距离:
- 固定距离:struts
- 比例调整:springs
autoresizingMask
typedef NS_OPTIONS(NSUInteger, UIViewAutoresizing) {
UIViewAutoresizingNone = 0,//固定fixed
UIViewAutoresizingFlexibleLeftMargin = 1 << 0,
UIViewAutoresizingFlexibleWidth = 1 << 1,
UIViewAutoresizingFlexibleRightMargin = 1 << 2,
UIViewAutoresizingFlexibleTopMargin = 1 << 3,
UIViewAutoresizingFlexibleHeight = 1 << 4,
UIViewAutoresizingFlexibleBottomMargin = 1 << 5
};
设置方式:
Step1:
data:image/s3,"s3://crabby-images/20a8a/20a8ac332b8dd236eca3ceaba3d45c4ddfd4e2e0" alt=""
Step2:
data:image/s3,"s3://crabby-images/ba85e/ba85eb203ca6c0ccbdb9b6d3499191fa78be8164" alt=""
Step3:
data:image/s3,"s3://crabby-images/71166/711668970a69e6bb1ee028b94f0de3080044d320" alt=""
Step4:
data:image/s3,"s3://crabby-images/a5bfd/a5bfd1f769a5f3986d54aba9613f379edb15e5ae" alt=""
代码控制
从nib中定义的View默认都开着
关闭:
self.view.autoresizesSubviews = NO;
tips:
在Autolayout下Autoresizing也可以用代码实现,默认情况下会进行自动翻译。
Autolayout
用约束条件(constraint)描述View定位属性之间的关系
与Autoresizing的比较
Autoresizing只描述上下级视图之间关系
Autolayout支持更多样的视图关系和定位属性
NSLayoutConstraint.
!只能表达线性关系
data:image/s3,"s3://crabby-images/5b62c/5b62cd491866ae2d1640611e4b0073968b41821e" alt=""
操作方式-拖
data:image/s3,"s3://crabby-images/097f8/097f86137d912dcde1094b8631b18f37280ade0a" alt=""
向上拖的选择菜单
data:image/s3,"s3://crabby-images/a24e1/a24e1ad691357f215c9f500e15723a0a6466434b" alt=""
adaptive
选项的位置
data:image/s3,"s3://crabby-images/54d07/54d07c1a912389671cefbb4b9dc4f7000e11b8d1" alt=""
compact_regular
data:image/s3,"s3://crabby-images/7f764/7f764dab81e0e2c6edea203abafc626923b8034e" alt=""
any_any
data:image/s3,"s3://crabby-images/b0495/b0495b1f7915f6b089411e2d717929adc63f0d39" alt=""
compact_any
data:image/s3,"s3://crabby-images/6e02a/6e02a1f7b2d74e50848938f7d513c780f0901483" alt=""
compact_regular
data:image/s3,"s3://crabby-images/0a64a/0a64a12e3b880aa60f5cc3863f19db782a44e150" alt=""
Size Class
data:image/s3,"s3://crabby-images/b42e6/b42e6526ea1486fac16f67614cc1601e2a07af14" alt=""
stackview 堆栈视图
data:image/s3,"s3://crabby-images/320fc/320fce3bf4236122d3c6877fc0822039dec823d9" alt=""
data:image/s3,"s3://crabby-images/27f25/27f250962f759cffc7f64f31b62307fac085d945" alt=""
data:image/s3,"s3://crabby-images/1ad1b/1ad1b6e9610cf67e98628ccf551aa1c4dc00de02" alt=""
Trait(设备特性)
@protocol UITraitEnvironment <NSObject>
@interface UITraitCollection : NSObject <NSCopying, NSSecureCoding>
+ (UITraitCollection *)traitCollectionWithHorizontalSizeClass:(UIUserInterfaceSizeClass)horizontalSizeClass;
+ (UITraitCollection *)traitCollectionWithVerticalSizeClass:(UIUserInterfaceSizeClass)verticalSizeClass;
//point to pixel,retina 2.0 ,non retina 1.0 ,5.5 inch iphone 3.0
+ (UITraitCollection *)traitCollectionWithDisplayScale:(CGFloat)scale;
//iPhone,iPad
+ (UITraitCollection *)traitCollectionWithUserInterfaceIdiom:(UIUserInterfaceIdiom)idiom;
+ (UITraitCollection *)traitCollectionWithForceTouchCapability:(UIForceTouchCapability)capability;
Alignment Rectangle
- (CGRect)frameForAlignmentRect:(CGRect)alignmentRect
- (CGRect)alignmentRectForFrame:(CGRect)frame
- (UIEdgeInsets)alignmentRectInsets
data:image/s3,"s3://crabby-images/12b97/12b97710ff56cde61ab8a493dff9b456e2d6e5cd" alt=""
固有尺寸
data:image/s3,"s3://crabby-images/111ff/111ff263677f24b4481482fe200d346e865ea791" alt=""
对自我的坚持(CHCR)
是否难于被拉伸或者压缩
Content Hugging(默认值250)
Content Compression Resistance(默认值750)
1000表示不能被压缩或者拉伸
data:image/s3,"s3://crabby-images/e1fa5/e1fa53119f7dff768d4d6c2a0436caf6e7436e20" alt=""
布局相关调用顺序
-updateConstraints //自定义的View,不要直接调用
-updateConstraintIfNeeded //updateConstraints替代
-setNeedUpdateConstraints
-layoutSubviews
网友评论