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)想要开发出一款精美的应用程序, ...
随机推荐
- TCMalloc
一. 原理 tcmalloc就是一个内存分配器,管理堆内存,主要影响malloc和free,用于降低频繁分配.释放内存造成的性能损耗,并且有效地控制内存碎片.glibc中的内存分配器是ptmalloc ...
- python如何安装模块
1.从 https://pypi.python.org/pypi/XXXX 下载压缩包 2.解压所下载的压缩包 3.CD到解压目录,执行 sudo python setup.py install
- permeation开篇
学习方法: To follow the path look to the master follow the master walk with the master see through the m ...
- Android的文件存储
//文件的写入 String content1 = edt_file.getText().toString(); //用于文件的写操作 FileOutputStream fos=null; //缓冲输 ...
- JSP page指令
JSP page指令: JSP文件: <%@ page language="java"%> <%@ page import="java.util.*&q ...
- lufylegend库 LGraphics扭曲图片
lufylegend库 LGraphics扭曲图片 <!DOCTYPE html> <html lang="en"> <head> <me ...
- [随笔]利用云虚拟机和学校VPN实现校外访问校内站点(反向代理)
探究背景简介: 大学校内站点一般不对外开放,个人认为原因有二: 一是站点内容受众就是大学师生: 二是站点基本无防御措施,在公网环境下容易发生意外情况. 至于为何不对外开放,不是这篇随笔探讨的重点,利用 ...
- mac下为gdb创建证书赋权其调试其它应用
1 使用/Applications/Utilities/Keychain Access.app创建证书 钥匙串访问->证书助理->创建证书 给证书随笔取一个名字,身份类型"自签名 ...
- removeEventListener('2016');
2016----最后一天工作日要快结束了,趁剩下的一点时间写篇博客玩玩,想到啥就写啥.总结下来就一句---累并快乐着... 先祝大家新年快乐!万事如意发大财. 一年跳了三家公司,上半年在家小公司干着整 ...
- UI进阶 即时通讯之XMPP好友列表、添加好友、获取会话内容、简单聊天
这篇博客的代码是直接在上篇博客的基础上增加的,先给出部分代码,最后会给出能实现简单功能的完整代码. UI进阶 即时通讯之XMPP登录.注册 1.好友列表 初始化好友花名册 #pragma mark - ...