.创建UIView
UIView * redView = [[UIView alloc] initWithFrame:CGRectMake(, , , )];
UIView * blueView = [[UIView alloc] init];
把blueView粘贴到了redView上
[redView addSubview:blueView];
redView 就是blueView 的父视图
修改父视图属性 对子视图产生影响 .设置隐藏
redView.hidden = YES;//父视图隐藏子视图也会隐藏 .如果子视图超出父视图范围是否裁剪子视图 默认是NO
redView.clipsToBounds = YES; .是否可以和用户进行交互,默认为YES
redView.userInteractionEnabled = YES;
UIView 默认 YES
/*
如果可一个用户交互那么这个视图 可以接收点击,子视图也可以接收点击事件
谁在在上方谁想接受点击 最上方的会拦截
如果设置为NO 子视图和父视图都不能接受点击事件,那么这个点击就会向下层传递知道能被接受事件的控件接收 如果最后没有控件接受这个事件 事件将会被抛弃
UILabel UIIImageView userInteractionEnabled默认是NO,不可以和用户进行交互
如果button 粘贴到UILabel 和UIIImageView上 button是不能被点击
如果想要能点击button 就要把UILabel 和 UIIImageView 的userInteractionEnabled改为YES
*/ .确定父子视图关系之后我们就可以获取所有的子视图
NSArray * subViews = redView.subviews; .获取子视图的父视图
UIView * superView = blueView.superview; .判断一个视图是否是另外一个视图的子视图
[button isDescendantOfView:redView]; .在指定的索引位置插入一个子视图(这个函数也会把子视图粘贴到父视图上)
如果指定的索引超出了 父视图对应的索引值 那么就会把这个子视图插在 最上层
索引0 对应的就是最底层
[self.view insertSubview:label4 atIndex:]; .在指定的某个子视图下方插入一个新的子视图
[self.view insertSubview:label4 belowSubview:label1]; .在指定的某个子视图上方插入一个新的子视图
[self.view insertSubview:label4 aboveSubview:label1];
.父视图 把指定的子视图 放到最前方
[self.view bringSubviewToFront:label4]; .父视图 把指定的两个视图进行交换
[self.view exchangeSubviewAtIndex: withSubviewAtIndex:]; .父视图 把指定的子视图放到最底层
[self.view sendSubviewToBack:label4]; .可以通过设置中心点位置
blueView.center = CGPointMake(, ); .通过bounds 改变 视图的边框大小
blueView.bounds = CGRectMake(, , , );
//bounds 前两项一般是 0 0
frame 和 bounds 区别
.frame 子视图相对于父视图的坐标系的坐标
.bounds 前两项的坐标是相对于自己坐标系的坐标
.如果把bounds 中的坐标改变了 那么就会影响自己的坐标系,那么最终能影响子视图 .修改view的bounds会将redView的坐标系改变
redView.bounds = CGRectMake(-, -, , ); .view.transform
.CGAffineTransformMakeRotation 设置视图的旋转角度(这个角度相对最原始的位置)
imagebutton.transform = CGAffineTransformMakeRotation(M_PI/);
.CGAffineTransformRotate函数相对于当前imagebutton.transform 旋转的角度
imagebutton.transform = CGAffineTransformRotate(imagebutton.transform, M_PI/); .CGAffineTransformMakeScale可以实现 放大 缩小 上下翻转 左右翻转
都是相对最原始的状态进行变换
CGAffineTransformMakeScale(x, y);
x 控制x 方向的大小 原始大小 > x方向放大 < 缩小
y 控制 y方向 大小 原始大小 > y纵向放大 < 1缩小
x 是负数 表示相对于原始的位置 左右翻转 翻转180度
x 是正数 原始的位置
y 负数 相对于原始的位置 上下翻转
y 正数 就是最原始的位置
imagebutton.transform = CGAffineTransformMakeScale(-, ); .动画
[UIView animateWithDuration:0.25 animations:^{//执行的第一个动画
} completion:^(BOOL finished) {//第一个动画结束时执行
}] .设置父子视图自适应/停靠模式
_redView.autoresizesSubviews = YES;//允许子视图伴随父视图自动变化 .设置子视图的自适应模式
blueView.autoresizingMask = UIViewAutoresizingFlexibleWidth|UIViewAutoresizingFlexibleHeight|UIViewAutoresizingFlexibleLeftMargin|UIViewAutoresizingFlexibleRightMargin|UIViewAutoresizingFlexibleTopMargin|UIViewAutoresizingFlexibleBottomMargin;
/*
UIViewAutoresizingFlexibleLeftMargin = 1 << 0,
父子视图的左边距 会伴随父视图的宽度 增加而增加 减少而减少
UIViewAutoresizingFlexibleWidth = 1 << 1,
//子视图的宽度会伴随父视图的宽度增加而增减 减少而减少
UIViewAutoresizingFlexibleRightMargin = 1 << 2,
父子视图的右边距 会伴随父视图的宽度 增加而增加 减少而减少
UIViewAutoresizingFlexibleTopMargin = 1 << 3,
父子视图的上边距 会伴随父视图的宽度 增加而增加 减少而减少
UIViewAutoresizingFlexibleHeight = 1 << 4,
//子视图的高度会伴随父视图的高度增加而增减 减少而减少
UIViewAutoresizingFlexibleBottomMargin = 1 << 5
父子视图的下边距 会伴随父视图的宽度 增加而增加 减少而减少
*/

iOS UIView 基本属性用法的更多相关文章

  1. IOS UIVIEW layer动画 总结(转)

    转发自:http://www.aichengxu.com/article/%CF%B5%CD%B3%D3%C5%BB%AF/16306_12.html   IOS UIVIEW layer动画 总结, ...

  2. IOS NSUserDefaults 讲解 用法

    IOS NSUserDefaults 讲解 用法    NSUserDefaults适合存储轻量级的本地数据,比如要保存一个登陆界面的数据,用户名.密码之类的,个人觉得使用NSUserDefaults ...

  3. IOS UIView圆角,阴影,边框,渐增光泽

    圆角 sampleView.layer.cornerRadius = 2.5; // 圓角的弧度sampleView.layer.masksToBounds = YES; 阴影 sampleView. ...

  4. [转]IOS UIView 之属性篇

    [转载自:IOS UIView 之属性篇 From CSDN] UIView 继承于UIResponder             所遵守的协议有 NSCoding .UIAppearance. UI ...

  5. ios Block详细用法

    ios Block详细用法 ios4.0系统已开始支持block,在编程过程中,blocks被Obj-C看成是对象,它封装了一段代码,这段代码可以在任何时候执行.Blocks可以作为函数参数或者函数的 ...

  6. iOS - UIView

    前言 NS_CLASS_AVAILABLE_IOS(2_0) @interface UIView : UIResponder <NSCoding, UIAppearance, UIAppeara ...

  7. iOS UIView控件的常用属性和方法的总结

    一 UIVIew 常见属性1.frame 位置和尺寸(以父控件的左上角为原点(0,0))2.center 中点 (以父控件的左上角为原点(0,0))3.bounds 位置和尺寸(以自己的左上角为原点 ...

  8. iOS UIApplication sharedapplication用法

    应用中打开其他应用 我们来讨论一下,在iOS开发中,如何实现从app1打开app2. 基本的思路就是,可以为app2定义一个URL,在app1中通过打开这个URL来打开app2,在此过程中,可以传送一 ...

  9. IOS UIView 04- 自定义控件

    注:本人是翻译过来,并且加上本人的一点见解. 前言 本文将讨论一些自定义视图.控件的诀窍和技巧.我们先概述一下 UIKit 向我们提供的控件,并介绍一些渲染技巧.随后我们会深入到视图和其所有者之间的通 ...

随机推荐

  1. 【待填坑】bzoj上WC的题解

    之前在bzoj上做了几道WC的题目,现在整理一下 bzoj2115 去膜拜莫队的<高斯消元解xor方程组> bzoj2597 LCT维护MST bzoj1758 分数规划+树分治+单调队列 ...

  2. WCF 服务调用RFC 出现异常

    我在VS2010的WCF项目用connecter 3.0 调用 RFC  运行到       IDestinationConfiguration ID = new SAPConfig();       ...

  3. Spring Autowire自动装配介绍

    在应用中,我们常常使用<ref>标签为JavaBean注入它依赖的对象.但是对于一个大型的系统,这个操作将会耗费我们大量的资源,我们不得不花费大量的时间和精力用于创建和维护系统中的< ...

  4. android 组件设置屏幕大小

    WindowManager wManager = getWindowManager(); DisplayMetrics metrics = new DisplayMetrics(); wManager ...

  5. AngularJS 拦截器和好棒例子

    目录[-] 什么是拦截器? 异步操作 例子 Session 注入(请求拦截器) 时间戳(请求和响应拦截器) 请求恢复 (请求异常拦截) Session 恢复 (响应异常拦截器) 总结 Intercep ...

  6. WCF:为 SharePoint 2010 Business Connectivity Services 构建 WCF Web 服务(第 1 部分,共 4 部分)

    转:http://msdn.microsoft.com/zh-cn/library/gg318615.aspx 摘要:通过此系列文章(共四部分)了解如何在 Microsoft SharePoint F ...

  7. WCF学习笔记(一):WCF简介

    转:http://www.cnblogs.com/wengyuli/archive/2009/11/04/1595693.html MSDN上关于WCF给出如下注解: 设计 Windows Commu ...

  8. HDU 5328 Problem Killer

    题意:给一段序列,求连续的子序列中最长的等差数列或者等比数列的长度. 解法:O(n)的扫两遍一次判等差一次判等比就好了. 代码: #include<stdio.h> #include< ...

  9. 【工具类】如何通过代码安装一个apk文件

    <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android=&quo ...

  10. 4、什么构成了我们Android应用程序?(七大件)

    一.应用程序四大组件 [Activity] Activity是Android应用程序的一个界面,可以通过这个界面查看联系人,打电话戒玩游戏. b. 一个应用程序通常包含多个Activity. c. A ...