UIView的一些常用属性和方法
1. UIView的属性
UIView继承自UIResponder,拥有touches方法。
- - (instancetype)initWithFrame:(CGRect)frame; 通过Frame来初始化一个UIView控件
@property(nonatomic,getter=isUserInteractionEnabled) BOOL userInteractionEnabled; 默认为YES 能够跟用户进行交互
@property(nonatomic)NSInteger tag; 控件的一个标记(父控件可以通过tag找到对应的子控件) 默认为 0
@property(nonatomic,readonly,strong) CALayer *layer; 图层(可以用来设置圆角效果\阴影效果)
@interface UIView(UIViewGeometry)
- @property(nonatomic) CGRect frame; 位置和尺寸(以父控件的左上角为坐标原点(0, 0))
- @property(nonatomic) CGRect bounds; 位置和尺寸(以自己的左上角为坐标原点(0, 0)
- @property(nonatomic) CGPoint center; 中点(以父控件的左上角为坐标原点(0, 0))
- @property(nonatomic) CGAffineTransform transform; default is CGAffineTransformIdentity 形变属性(平移\缩放\旋转)
- @property(nonatomic,getter=isMultipleTouchEnabled) BOOL multipleTouchEnabled; // default is NO // YES:支持多点触摸
@interface UIView(UIViewHierarchy)
- @property(nonatomic,readonly) UIView *superview; // 父控件
- @property(nonatomic,readonly,copy) NSArray *subviews; // 子控件(新添加的控件默认都在subviews数组的后面, 新添加的控件默认都显示在最上面\最顶部)
- @property(nonatomic,readonly) UIWindow *window; // 获得当前控件所在的window
- - (void)removeFromSuperview; // 从父控件中移除一个控件
- - (void)insertSubview:(UIView *)view atIndex:(NSInteger)index; // 添加一个子控件(可以将子控件插入到subviews数组中index这个位置)
- - (void)exchangeSubviewAtIndex:(NSInteger)index1 withSubviewAtIndex:(NSInteger)index2; // 交换subviews数组中所存放子控件的位置
- - (void)addSubview:(UIView *)view; // 添加一个子控件(新添加的控件默认都在subviews数组的后面, 新添加的控件默认都显示在最上面\最顶部)
- - (void)insertSubview:(UIView *)view belowSubview:(UIView *)siblingSubview; // 添加一个子控件view(被挡在siblingSubview的下面)
- - (void)insertSubview:(UIView *)view aboveSubview:(UIView *)siblingSubview ; // 添加一个子控件view(盖在siblingSubview的上面)
- - (void)bringSubviewToFront:(UIView *)view; // 将某个子控件拉到最上面(最顶部)来显示
- - (void)sendSubviewToBack:(UIView *)view; // 将某个子控件拉到最下面(最底部)来显示
- - (BOOL)isDescendantOfView:(UIView *)view; // returns YES for self. // 是不是view的子控件或者子控件的子控件(是否为view的后代)
- - (UIView *)viewWithTag:(NSInteger)tag; // recursive search. includes self // 通过tag获得对应的子控件(也可以或者子控件的子控件)
- /**系统自动调用(留给子类去实现)**/
- (void)didAddSubview:(UIView *)subview;
- (void)willRemoveSubview:(UIView *)subview;- (void)willMoveToSuperview:(UIView *)newSuperview;
- (void)didMoveToSuperview;
- (void)willMoveToWindow:(UIWindow *)newWindow;
- (void)didMoveToWindow;
/**系统自动调用**/ - /**系统自动调用(留给子类去实现)**/
// 控件的frame发生改变的时候就会调用,一般在这里重写布局子控件的位置和尺寸
// 重写了这个写方法后,一定调用[super layoutSubviews];
- (void)layoutSubviews;
@interface UIView(UIViewRendering)
- @property(nonatomic) BOOL clipsToBounds; // YES : 超出控件边框范围的内容都剪掉
- @property(nonatomic,copy) UIColor *backgroundColor; // default is nil // 背景色
- @property(nonatomic) CGFloat alpha; // default is 1.0 // 透明度(0.0~1.0)
- @property(nonatomic,getter=isOpaque) BOOL opaque; // default is YES // YES:不透明 NO:透明
- @property(nonatomic,getter=isHidden) BOOL hidden; // YES : 隐藏 NO : 显示
- @property(nonatomic) UIViewContentMode contentMode; // default is UIViewContentModeScaleToFill // 内容模式
- 设置属性改变时的动画
@interface UIView(UIViewAnimationWithBlocks)
+ (void)animateWithDuration:(NSTimeInterval)duration delay:(NSTimeInterval)delay options:(UIViewAnimationOptions)options animations:(void (^)(void))animations completion:(void (^)(BOOL finished))completion;
+ (void)animateWithDuration:(NSTimeInterval)duration animations:(void (^)(void))animations completion:(void (^)(BOOL finished))completion;
+ (void)animateWithDuration:(NSTimeInterval)duration animations:(void (^)(void))animations;
+ (void)animateWithDuration:(NSTimeInterval)duration delay:(NSTimeInterval)delay usingSpringWithDamping:(CGFloat)dampingRatio initialSpringVelocity:(CGFloat)velocity options:(UIViewAnimationOptions)options animations:(void (^)(void))animations completion:(void (^)(BOOL finished))completion;
UIView的一些常用属性和方法的更多相关文章
-
UIView常用属性与方法/UIKit继承结构
UIView常用属性与方法 @interface UIView : UIResponder<NSCoding, UIAppearance, UIAppearanceContainer, UIDy ...
-
UITableView常用属性和方法 - 永不退缩的小白菜
UITableView常用属性和方法 - 永不退缩的小白菜 时间 2014-05-27 01:21:00 博客园精华区原文 http://www.cnblogs.com/zhaofucheng11 ...
-
Node.js process 模块常用属性和方法
Node.js是常用的Javascript运行环境,本文和大家发分享的主要是Node.js中process 模块的常用属性和方法,希望通过本文的分享,对大家学习Node.js http://www.m ...
-
ios基础篇(四)——UILabel的常用属性及方法
UILabel的常用属性及方法:1.text //设置和读取文本内容,默认为nil label.text = @”文本信息”; //设置内容 NSLog(@”%@”, label.text); //读 ...
-
SVG DOM常用属性和方法介绍(1)
12.2 SVG DOM常用属性和方法介绍 将以Adobe SVG Viewer提供的属性和方法为准,因为不同解析器对JavaScript以及相关的属性和方法支持的程度不同,有些方法和属性是某个解析 ...
-
第190天:js---String常用属性和方法(最全)
String常用属性和方法 一.string对象构造函数 /*string对象构造函数*/ console.log('字符串即对象');//字符串即对象 //传统方式 - 背后会自动将其转换成对象 / ...
-
JavaScript中Number常用属性和方法
title: JavaScript中Number常用属性和方法 toc: false date: 2018-10-13 12:31:42 Number.MAX_VALUE--1.79769313486 ...
-
iOS UIView控件的常用属性和方法的总结
一 UIVIew 常见属性1.frame 位置和尺寸(以父控件的左上角为原点(0,0))2.center 中点 (以父控件的左上角为原点(0,0))3.bounds 位置和尺寸(以自己的左上角为原点 ...
-
12-27 UITableView常用属性及方法
UITableView也有自己的代理协议,它本身继承自UIScrollView 一:代理要遵守代理协议<UITableViewDelegate>,代理协议中的代理方法: 1.改变某一行的行 ...
随机推荐
-
python模块引用梳理
文件组织结构: t ├── __init__.py ├── main.py ├── t1 │ ├── A.py │ └── __init__.py └── t2 ├── B.py └── __ ...
-
最详细的 Android Toolbar 开发实践总结
http://www.codeceo.com/article/android-toolbar-develop.html 参考此链接!
-
jsconsole
在移动设备或者其他无法启动 chrome developer tools 的时候可以用以下方法进行console 步骤: 1. 进入 http://jsconsole.com 的console画面,在 ...
-
js 代码命名规范系列
在微博上看到一个段子 “老子哪天出任ceo迎娶白富美走上人生巅峰之后,一定要雇两个长腿大熊的妹子.一个帮我想变量名字,一个帮我想git commit的message!” 可以看出 命名方方面面的问题困 ...
-
quartz定时任务的简单使用
开发环境: springmvc quartz-2.2.3在官网下载的. 步骤: 1.首先在web.xml中加入以下代码: <servlet> <servlet-name>Qua ...
-
JAVAssist字节码操作
Java动态性的两种常见实现方式 字节码操作 反射 运行时操作字节码可以让我们实现如下功能: 动态生成新的类 动态改变某个类的结构(添加/删除/修改 新的属性/方法) 优势: 比反射开销小,性能高 ...
-
PHPthinking赠书了!
[站长赠书]2014年10月第一期幸运用户 大家好,我是PHP开发学习门户的站长,小站建站一个多月,感谢大家以来的关注和支持,假设大家对本站有什么建议或者投稿,欢迎留言或者给我发邮件. 本站宣布对于 ...
-
router-link params传参
1.router.js配置 需要在路径后定义上要传的属性名 --> /:属性名(query方式不需要) { path: '/CreateProgress/:name1', name: ...
-
VS2015创建WDK的问题
在微软官网找了半天.. 搜索window driver kit,好吧.进入一页英文页面.. https://docs.microsoft.com/en-us/windows-hardware/driv ...
-
重新总结flex布局(flex,flex-direction,justify-content,align-items,flex-wrap,align-self)
1.flex,主要就是按比例分配.(例如:两个div的flex:1,就大小相等) .box1{ flex:1; background-color: red; } .box2{ flex:1; back ...