UIWindow和UIView

UI第一天

UIWindow

window:窗口,一个应用想要展示在屏幕上,至少要有一个window.一个手机应用程序一般只有一个window
应用程序中的所有的界面全部是展示在window上的
启动Window的步骤

func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
        
        //1.创建UIWindow对象
        //frame是UIView中的属性,确定视图显示在屏幕上的位置和大小
        //UIScreen.mainScreen() 拿到手机屏幕
        self.window = UIWindow.init(frame: UIScreen.mainScreen().bounds)
        
        //2.设置根视图控制器
        self.window?.rootViewController = UIViewController()
        
        //3.设置背景颜色
        self.window?.backgroundColor = UIColor.yellowColor()
        
        
        return true
    }

UIView

这个是在视图控制器里面创建的
UIView:是iOS中所有视图(控件)直接/间接的父类;所以UIView的属性和方法,对于其他类型的视图都有效
视图:在屏幕上能看见的所有的东西都属于视图

let redView = UIView.init()
        //想要将视图展示在屏幕上的两个必要条件:
        //a.必须设置坐标和大小(默认坐标是(0,0),大小(0,0))
        //b.将视图添加到已经展示在屏幕上的视图上
        
        //2.设置frame属性(由坐标(x,y)和大小(width,height)两个部分组成)
        redView.frame = CGRect(x: 10, y: 10, width: 100, height: 100)
        //iOS中所有的结构体都有一个对应的Make方法用来快速的创建一个结构体变量
        redView.frame = CGRectMake(10, 10, 100, 100)
        
        //3.将视图添加到界面上
        self.view.addSubview(redView)
        
        //4.设置背景颜色
        //视图的背景颜色默认是透明色
        //颜色的创建方式:
        
        
        //b.通过三原色来创建颜色
        //CGFloat就是UI中的浮点型
        //参数1,2,3: 红、绿、蓝的值(0~1) 0/255 ~ 255/255
        //参数4: 透明度(0~1)
        redView.backgroundColor = UIColor.init(red: 30/255.0, green: 133/255.0, blue: 26/255.0, alpha: 1)
        
        //c.创建灰色
        redView.backgroundColor = UIColor.init(white: 0.7, alpha: 1)
        
        //a.通过类型方法创建指定颜色
        redView.backgroundColor = UIColor.redColor()

frame的相关属性

a.view的坐标和大小
三种初始化方式

redView.frame = CGRectMake(100, 100, 100, 100)
redView.frame = CGRect(x: 10, y: 10, width: 100, height: 100)
let redView = UIView.init(frame: CGRectMake(35, 35, 50, 50))

b.view的中心点
center是通过frame的坐标和大小来确定的
可以通过改变center的值去改变frame的值

redView.center = CGPointMake(200, 200)

c.bounds(坐标和大小)
如果改变bounds的大小,frame的大小和坐标都改变,center不变
如果改变bounds的坐标,不影响当前视图的位置。但是影响添加到当前视图上的子视图的坐标,不建议修改bounds
d.transform形变
当前视图发生形变,那么添加到当前视图上的所有的视图会跟着一起形变
1.缩放(Scale)
参数1:x方向上的缩放比例
参数2:y方向上的缩放比例

redView.transform = CGAffineTransformMakeScale(0.8, 2.5)

2.旋转(Rotation)
参数:旋转角度(圆周率对应的角度值)

redView.transform = CGAffineTransformMakeRotation(CGFloat(M_PI_4 / 2))

3.平移(Traslation)
参数1:在x方向上平移的距离,负值->向左移,正值->向右移
参数2:在y方向上平移的距离,负值->向上移,正值->向下移

redView.transform = CGAffineTransformMakeTranslation(0, 300)

4.多个形变的组合

 //在另外一个形变的前提下旋转
        //参数1:另外一个形变
        //参数2:旋转角度
        redView.transform = CGAffineTransformRotate(CGAffineTransformMakeScale(0.5, 0.5), CGFloat(M_PI_4 / 2))
        
        //在另外一个形变的前提下平移(TRanslate)
        redView.transform = CGAffineTransformTranslate(redView.transform, 0, 300)
        
        //在另外一个形变的前提下缩放(Scale)
        //创建一个平移的形变
        let transLation = CGAffineTransformMakeTranslation(100, 0)
        redView.transform = CGAffineTransformScale(transLation, 0.5, 2)
        //组合两个形变
        //旋转形变
        let rotate = CGAffineTransformMakeRotation(0.2)
        //平移形变
        let transLation1 = CGAffineTransformMakeTranslation(100, 100)
        //将旋转形变和平移形变组合(Concat)
        redView.transform = CGAffineTransformConcat(rotate, transLation1)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容