8--UI 初步认识 简易计算器

UI是App的根基:一个App应该是先有UI界面,然后在UI的基础上增加实用功能(2)UI相对简单易学:UI普遍是学习过程中最简单的一块,能快速拥有成就感和学习兴趣(3)UI至关重要:开发中的绝大部分时间都在处理UI

谨记一条IOS软件开发定律:万物皆对象,UI界面上的每一个元素都是一个对象

IOS,android 软件开发过程

 

 

UIKit框架是跟UI有关系的,标签,文本,按钮,进度条,开关等控件,都是封装在UIKit框架内部的,UIKit框架中提供了丰富多彩的可视化组件 元素,利用UIKit框架提供的类来创建各种可视化组件对象,最后组成复杂而美观的UI界面。 为了方便开发者开发出强大的功能,苹果提供了各种各样的框 架(1)UIKit:创建和管理应用程序的用户界面(2)QuartzCore:提供动画特效以及通过硬件进行渲染的能力 (3)CoreGraphics:提供2D绘制的基于C的API(4)CoreLocation:使用GPS和WIFI获取位置信息(5)MapKit: 为应用程序提供内嵌地图的接口(6)AVFoundation:音频、视频处理(7)……

在开发过程中需要用到一些特殊功能时,可以先尝试使用系统自带的框架。

通过一个简单的计算器的开发,来学习和认识IOS 开发的基础控件

 

分析一下这个简易的计算机程序 需要分哪几步进行:

(1): 需要两个输入框 是 text 按钮;  + = 是lable 标签需要两个 还需要一个计算的 button;

(2)监听按钮的点击事件----点击计算按钮之后执行什么操作

(3)取得2个文本框值 将计算好的最终结果显示到右边的文本标签上

什么是控件?能在界面上看得到的,可以进行交互的,就是控件 常用的控件介绍:

 

上述这些都是控件;

UILabel—文本标签:显示一串固定的文字

UIButton – 按钮:监听用户的点击事件,在用户点击后做出响应

UITextField – 文本输入框,文本输入框可以弹出键盘,让用户输入文本内容 

UIView:屏幕上能看得见摸得着的东西就是UIView,比如屏幕上的按钮、文字、图片,一般翻译叫做:视图/控件/组件。

UIButton、UILabel、UITextField都继承自UIView,每一个UIView都是一个容器,能容纳其他UIView(比如整个键盘是一个UIView,里面容纳很多小格子的数字UIView) 在“加法计算器”中,最后面那块白色的全屏的东西也是一个UIView,白色的大UIView中容纳了很多小的UIView,视图层次结构如下图所示

 

在白色的大UIView中,容纳了6个小UIView(1个UIButton、2个UITextField、3个UILabel),白色的大UIView为6个小UIView的父控件(父视图),6个小UIView都是白色大UIView的子控件(子视图)。 每一个新的界面都是一个新的UIView,在切换过程中,涉及到了:1、UIView的创建和销毁2、UIView跟用户的交互(处理UIView内部每一行的点击)这 是视图控制器 viewController 的工作,UIView 负责显示,控制器来控制视图。每当显示一个新界面时,首先会创建一个新的UIViewController对象,然后创建一个对应的全屏 UIView,UIViewController负责管理这个UIView。UIViewController就是UIView的大管家,负责创建、显 示、销毁UIView,负责监听UIView内部的事件,负责处理UIView与用户的交互。大部分代码都是写在控制 器。 UIViewController内部有个UIView属性,就是它负责管理UIView对象

 

先进行 UI 设计,使用单视图页面进行开发(常用),Single View Application是最适合初学者的模板.

先来看一下故事板 就是上图中所描述的 storyboard 简单的说就是显示UI界面的程序

程序一启动就会显示箭头所指的界面 在iOS5之前,苹果使用xib文件来描述UI界面,在iOS5之后,苹果采取了更加强大和先进的storyboard文件来描述界面(Xcode5是基于iOS7),因此,可以得出结论:修改项目中的Main.storyboard文件就可以修改UI界面。 打开Main.storyboard文件一看,里面有一个全白的界面,这个界面就是模拟器上显示的界面。 往storyboard的界面中添加其他控件,得显示工具栏

 

注意:在属性查看器里,更改控件显示的内容,控件不会自动调节自己的宽度,而双击控件填写内容,控件会自动调整宽度来适应填写的内容。

因此可以使用鼠标或者键盘的方向键进行调节,由于苹果的官方限制 在应该使用数字的地方,必须只能输入数字,否则无法通过。也就是说,本来应该输入数字,最起码弹出的键盘应该是数字键盘,而不是如图所示。改进方法:在属性查看器里,找到 keyboard 属性,修改为 number。

 

另外在新版本的 XCODE 里面取消了键盘和虚拟键盘之前的通用,如果模拟器不弹出虚拟键盘,需要将模拟器里面的键盘设置取消联接物理键盘即可.

和界面进行关联: 先点击 UI 按钮,然后按住 ctrl 键不放,会出现一条线将改线已到对应的方法上等待变为圆圈即可关联成功.

 

 

小结:

 

IOS 程序的开发步骤:

 

1、设计界面

 

2、连线关联

 

3、写代码实现功能(最难,最复杂 )


故事板:本质是一个 xml 文件,可以手动的设置程序启动时加载的storyboard是哪个这个设置表明:程序启动时会加载Main.storyboard 了解延迟加载和懒加载的概念在程序需要的时候,才加载到内存里,效率上变低了,但是程序的内存消耗小了,这就是苹果手机的性能优化的好的原因之一!

简单加法计算器的运行过程

1. 读取Main.storyboard文件

2.创建箭头所指的ViewController对象

3.根据storyboard文件中描述创建 ViewController的UIView对象

4.将UIView对象显示到用户眼前 现在已经知道:应该由ViewController来监听按钮的 点击,换句话说,ViewController应该提供一个方法出来,当用户点击按钮时,就调用这个方法来通知ViewController按钮被人点了。ViewController就在这个方法中实现想做的任何事情,比如计算2个文本输入框内值的和。 退出键盘的两种方式resignFirstResponder当叫出键盘的那个控件(第一响应者)调用这个方法时,就能退出键盘 endEditing只要调用这个方法的控件内部存在第一响应者,就能退出键盘 苹果官方建议:从 xcode5开始,把不对外开放的属性和方法声明,放到 .m 文件内。

A: 设置Text1 Text2 和 lable3属性:

 1 //
 2 //  ViewController.h
 3 //  01-第一个 IOS 程序
 4 //
 5 //  Created by Stephen on 16/4/2.
 6 //  Copyright © 2016年 Stephen. All rights reserved.
 7 //
 8 
 9 #import <UIKit/UIKit.h>
10 
11 @interface ViewController : UIViewController
12 // 申明一个方法来监听按钮的动作
13 
14 - (IBAction)btnClick;  // IBAction 对应的是方法
15 
16 /*
17  BAction 和 IBOutlet区别
18  
19  1. IBAction,从返回值角度上看,作用相当于void,只是返回值声明为IBAction的方法,才能跟storyboard中的控件进行连线
20  2. IBOutlet 用来和界面的元素建立关系,用来修改,获得界面控件的属性,故对应的是@property,而 IBAction 对应的是方法。只有声明为IBOutlet的属性,才能跟storyboard中的控件进行连线。 UIViewController是负责程序的控制,相当于管家的角色,而UIView 是负责界面的展示,联系 MVC 模式。严格来讲,下图箭头所指的应该是一个UIViewController对象,里面白色的界面仅仅是UIViewController内部的UIView属性
21  
22  */
23 @property (nonatomic,weak) IBOutlet UITextField *num1;  // Text 类型是UITextFiled 
24 @property (nonatomic,weak) IBOutlet UITextField *num2;
25 
26 @property (nonatomic, weak) IBOutlet UILabel *result; // UILable 是对应UI 的类型
27 
28 
29 
30 @end

B:监听计算 button 的动作:

 1 #pragma 监听按钮点击
 2 
 3 - (void)btnClick{
 4     // 1.获得文本输入框的文字
 5     NSString *text1 = self.num1.text;  // 使用点语法调用 get 方法获取对应的值 text
 6     NSString *text2 = self.num2.text;
 7     // 2. 将string 字符串转换成整数
 8     int i1 = [text1 intValue];
 9     int i2 = [text2 intValue];
10     
11     self.result.text = [NSString stringWithFormat:@"%d",i1 +i2];// 把整数转换成字符串
12     
13     }
14 
15 @end

http://www.th7.cn/Program/IOS/201502/398336.shtml

posted @ 2016-04-03 00:20  淡定的人参果  阅读(595)  评论(0编辑  收藏  举报