UI --UIView 及其子类
- iOS 是 Apple 公司的移动操作系统,主要用于iPhone, iPad, iPad Mini , iPod Touch 等移动产品.
- 借助iOS 我们可以开发视频类 , 美图类 , 音乐类 , 团购类 ,电商类 ,出行类, 生活类 ,生活服务类 , 游戏类 ...应用程序
- 除此之外,ios还可以与外部设备通信,开发出更多改变生活的产品,比如:智能家居( ios App 控制电视,空调.. ) , 健身产品 ( 将人体的健康状况通过App 直观的展现出来.... )
- UI ( User Interfance ) : 用户界面,用户能看到的各种各样的页面元素 .
- iOS App = 各种各样的UI控件 + 业务逻辑 和算法 .
- 熟练掌握UI控件 .
- window 是窗口,每个app 都需要借助window 将内容展现给用户看.
- 在 iOS 中,使用UIWindow 类来表示窗口,通常一个应用程序只创建一个UIWindow 对象
- window 的主要作用是呈现内容给用户,我们不会对window 做太多操作 .
- 在创建window的时候,需要指定window的大小
- 通常window的大小( frame ) 与屏幕( UIScreen ) 大小 一致 .—>screen [skriːn] 屏幕
- 示例代码如下:
- self.window =[ [UIWindow alloc ] initWith Frame: [[UIScreen mainScreen] bounds] ] ;
- 1> command +shift +N ——>iOS 下的Application ——>Empty Application .点击Next .
- 2> 输入Product Name .点击Next .
- 3>选择项目保存路径 ,点击Create. create [kriː'eɪt] 创建
- view (视图) :代表屏幕上的一个矩形区域,ios中用UIView 来表示视图.
- PPT里看到的各种UI控件都属于view
- 不同的控件代表不同种类的view
- iOS中所有能看到的内容都是view 或其子类
- 1>开辟空间并初始化视图 ( 初始化时,给出视图位置和大小)
- 2>对视图做一些设置 ( 比如:背景颜色 )
- 3>将视图添加到window上进行显示
- 4>释放视图对象
- frame 是view的重要属性 ,是我们做图布局的关键,它决定了视图的大小和位置 .
- 根据ios坐标系 来掌控view的大小和位置 .
- 左上角为坐标系的原点 ,
- 水平向右 :为x的正方向, 屏幕最左到最右可划分320 等份
- 垂直向下:为Y的正方向 ,屏幕最上到最下可划分480等份 ( 3.5 inch 屏幕 )
- 坐标系不是以像素作为划分依据的,而是以”点" 作为依据
- center ( 中心点 ) 也是view 重要的属性
- center 是一个结构体 ,包含2个部分 : X,Y.
- center 与 frame 有着密切的联系
- center.x = frame.origin.x + frame.size.with/2 ;
- center.y = frame.origin.y +frame.size.height/2 ;
- //改变greenview的center值,那么greenview位置也会跟着改变//
[greenView setCenter:CGPointMake(100, 100)];
//或者
//greenView.center = CGPointMake(100, 100)//
- bounds (边界) 也是view 的重要属性 ,用于定义自己的边界,它同frame一样是一个CGRect 结构体变量
- 当一个view 设置 bounds 时,会把自己当成一个容器,定义自己的边界大小以及左上角的初始坐标.例如:view.bounds = CGRectMake( 0,0,100,100 ) ;
- 当子视图添加到此视图时,会根据bounds 指定的原点( 0,0 ) 计算frame,而非左上角
//3>2>设置redView的bounds 属性,将bounds.origin改为(10 ,30) 查看结果
- UIView 的 addSubview : 方法可以添加子视图,对于同一个视图的所有子视图来讲,后添加的子视图会把已加的子视图盖在下面
- UIView 提供了其他添加视图的方法.
- UIView 除了提供添加视图的方法 ,还提供了管理视图层次的方法
- UIView 作为其他UI控件的BaseClass( 基类 ) ,提供了很多属性
- UILabel (标签 ) : 是显示文本的控件,在App 中 UILabel 是出现频率最高的控件
- UILabel 是 UIView 子类 ,作为子类一般是 为了 扩充父类的功能,UILabel 扩展了文字显示的功能 ( UIView 不能显示文字 , ) UILabel 是能显示文字的视图.
- 文本: 就是我们的文字 (字符串)
- 文本显示 : 在视图上显示文字
- 文本显示都有哪些方面?—> 文本内容,文本字体
- 1> 开辟空间并初始化 ( 如果本类有初始化方法 , 使用自己的,否则使用父类的 )
self.window.backgroundColor = [UIColor whiteColor];
[self.window makeKeyAndVisible];
- 2>设置文本控制相关的属性
- 3>添加到父视图上,用于显示
- 4>释放
- UIView 是所有可视化控件的基类
- UILabel 是具有特定外观,特定功能的视图 (能显示文字 )
- UILabel 侧重于文本的呈现
- APP 靠window 来呈现内容,一个呈现一般只创建一个window
- APP 中能看的到的元素,都是UIView 及其子类
- UIView 作为所有可视化控件的baseclass ,提供了许多属性和方法,能显示效果控制 (frame .alpha .. )视图添加和移除 (addSubview: .. ) ,视图层次调整 ( bringSubviewToFront: … ) .
- UILabel 属于具体的视图,有自己的侧重点
UI --UIView 及其子类的更多相关文章
- UIView及其子类
一.UI概述 UI(User Interface):用户界⾯,用户能看到的各种各样的⻚面元素. iOS App = 各种各样的UI控件 + 业务逻辑和算法 二.UIView 在手机上显示的内容都是UI ...
- UI UIView
课程内容: 一.iOS概述 2007年1月9日Macworld大会上公布iPhone OS系统,2010WWDC大会上改名为iOS 二. UI编程概述 UI的本意是用户界面,是英文User和 ...
- 关于UIView及其子类重绘drawRect
转载自:https://nezha.gitbooks.io/ios-developmentarticles/content/UIView%E7%9A%84drawRect%E9%87%8D%E7%BB ...
- IOS UIView子类UIScrollView
转自:http://www.cnblogs.com/nightwolf/p/3222597.html 虽然apple在IOS框架中提供了很多可以直接使用的UI控件,但是在实际开发当中我们通常都是要自己 ...
- UI基础UIWindow、UIView
UI基础UIWindow.UIView 在PC中,应用程序多是使用视窗的形式显示内容,手机应用也不例外,手机应用中要在屏幕上显示内容首先要创建一个窗口承载内容,iOS应用中使用UIWindow.UIV ...
- iOS开发——UI篇OC篇&UIView/UIWindow/UIScreen/CALayer
UIView/UIWindow/UIScreen/CALayer 1.UIScreen可以获取设备屏幕的大小. 1 2 3 4 5 6 7 // 整个屏幕的大小 {{0, 0}, {320, 480} ...
- UI基础视图----UIView总结
UIView是UIKit框架里面最基础的视图类,是UIResponder的子类,是UIApplication和UIViewController的兄弟类,是UIWindow,UILabel,UIImag ...
- IOS学习笔记(五)——UI基础UIWindow、UIView
在PC中,应用程序多是使用视窗的形式显示内容,手机应用也不例外,手机应用中要在屏幕上显示内容首先要创建一个窗口承载内容,iOS应用中使用UIWindow.UIView来实现内容显示. UIWindow ...
- iOS开发-UI 从入门到精通(一)
一.UI概述 (1)UI(User Interface)用户界面,用户能看到的各种各样的页面元素: (2)iOS App = 各种各样的UI控件+业务逻辑和算法: (3)想要开发出一款精美的应用程序, ...
随机推荐
- 部署statspack工具(二)之解决方案2
解决方案二:在emp2的empno列上面创建索引,再执行share_pool_sql_1.sh脚本,查看sp报告 8.1在emp2的empno列上创建索引 sys@TESTDB12>create ...
- Oracle基础学习(二)v$session中Command的数字含义
v$session中Command的数字含义. 1 CREATE TABLE 2 INSERT 3 SELECT 4 CREATE CLUSTER 5 ALTER CLUSTER 6 UPDATE 7 ...
- BOM之history对象(转)
前面的话 history对象保存着用户上网的历史记录,从窗口被打开的那一刻算起.由于安全方面的考虑,开发人员无法得到用户浏览器的URL,但借由用户访问过的页面列表,可以在不知道实际URL的情况下实现后 ...
- IIS配置步骤,绝对有用,百度上的不全面,是百度的补充
百度教程:http://www.jb51.net/article/29787.htm 参照百度教程,但是配置不成功,关键的地方来了!! 下面的也要配置设置 1. 2. 3.C:\Windows\Sys ...
- JavaScript null 和 undefined
null null 表示一个变量被声明了,并被赋值为空 var lzh = null; console.log(lzh); // null console.log(typeof lzh); // ob ...
- (@WhiteTaken)设计模式学习——原型模式
有这样一个需求,两个对象,只是名称以及其他几个属性不一样,而其他的大部分的属性都是相同的. 这时候我们可以用到原型模式,也就是克隆模式. 原型模式:原型模式是一个对象创建型模式,通过克隆原对象,可以使 ...
- 如何解决在chrome中自动完成表单后input出现黄色背景
可以对input:-webkit-autofill使用足够大的纯色内阴影来覆盖input输入框的黄色背景:如: 代码如下: input:-webkit-autofill { -webkit-box-s ...
- Asp.net mvc 知多少(八)
本系列主要翻译自<ASP.NET MVC Interview Questions and Answers >- By Shailendra Chauhan,想看英文原版的可访问[http: ...
- 【UWP】列表项宽度自适应的实现
目的 在UWP开发中,我们常常用到两个显示列表的控件:ListView和GridView.而这两个列表控件在PC等大屏幕上如果能多列"智能"调整自己的大小(通常是根据当前窗口大小调 ...
- sping整合hibernate之二:dao层开发
在上一篇日志中将hibernate的会话工厂sessionFactory注入到了spring的容器中,但这样还不够,因为hibernate的增删改查是要使用事务机制的, 所以还要在spring中配置 ...