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)想要开发出一款精美的应用程序, ...
随机推荐
- FineUI表格模板列Undefined问题
一般是配置文件未添加ClientID="AutoID"引起
- C#综合揭秘——细说进程、应用程序域与上下文之间的关系
引言 本文主要是介绍进程(Process).应用程序域(AppDomain)..NET上下文(Context)的概念与操作.虽然在一般的开发当中这三者并不常用,但熟悉三者的关系,深入了解其作用,对提高 ...
- Flex Socket 安全沙箱问题解决
Flex使用Socket与C++通讯时遇到了安全沙箱问题,NND,折腾我半天,这是我的解决方法: 1):策略文件与主套接字在同一端口,只需调用 Socket.connect() 或 XMLSocket ...
- Nancy简单实战之NancyMusicStore(一):准备工作和搭建项目
开发环境 OS : Windows 10 10.0.14393 IDE : Visual Studio 2015 Community With Update 3 Database : PostgreS ...
- Hadoop权威指南:通过distcp并行复制
Hadoop权威指南:通过distcp并行复制 distcp是一个分布式复制程序,改程序可以从Hadoop文件系统间复制大量数据,也可以将大量的数据复制到Hadoop中 distcp的典型应用是在两个 ...
- Mac系统安装Aircrack-ng破解wifi密码(2)
我们上一篇文章说过如何通过Aircrack-ng, 破解使用WPA/PSK加密方式的路由密码, 这一篇介绍的是使用Aircrack-ng破解使用WEP加密方式的路由密码: WEP和WPA/PSK的区别 ...
- yum安装CDH5.5 Hadoop集群
1.环境说明 系统环境: 系统环境:centos6.7 Hadoop版本:CDH5.5 JDK运行版本:1.7.0_67 集群各节点组件分配: 2.准备工作 安装 Hadoop 集群前先做好下面的准备 ...
- webAppbuilder微件使用教程1 快速入门
by 李远祥 webAppbuilder是arcgis portal 和arcgis.com 上用来配置应用程序的利器.合理利用webAppbuilder的微件功能,可以实现应用程序的零代码定制,并能 ...
- java 多线程之卖票两种方式
1.通过extends Thread /* 需求:简单的卖票,多个窗口同时买票 (共用资源) 创建线程的第二种方式:实现Runnable接口 步骤: 1,定义类实现Runnable接口 2,覆盖/重写 ...
- node-webkit制作桌面应用
心血来潮突然想用js尝试写桌面应用,突然发现我大js真的无所不能.在网上搜到了这么一个东东:node-webkit.用Node.js来进行系统资源的访问,用HTML+CSS完成页面的搭建.哇,一切突然 ...