你的位置:首页 > 操作系统

[操作系统]iOS基础 01 构建HelloWorld,剖析并真机测试


iOS基础 01 构建HelloWorld,剖析并真机测试

 

前言:

  从控制台输出HelloWorld是我们学习各种语言的第一步,也是我们人生中非常重要的一步。

  多年之后,我希望我们仍能怀有学习上进的心情,继续以HelloWorld去认识这世界上更多的东西。

 

  本篇以HelloWorld作为切入点,向大家系统介绍什么事iOS应用以及如何使用Xcode创建iOS应用。

 

目录:

  1. 创建HelloWorld工程

  1.1. 设计界面

  1.2. 真机测试

  2. Xcode中的iOS工程模板

  2.1. Application类型

  2.2. Framework&Library类型

  2.3. Other类型

  3. 应用剖析

  4. 最后再扯个犊子

 

 

 

1. 创建HelloWorld工程

  启动Xcode,然后点击File-New-Project菜单,或直接点击“Create a new Xcode project”:

 

  在打开的Choose a template for your new project界面中选择Single View Application工程模板:

 

  接着点击Next按钮,然后提示输入项目名称等信息:

 

  这里我们可以按照上图并结合自己的实际情况和需要输入相关内容。

  下面简要介绍一下上图中各个选项:

选项说明
Project Name工程项目的名称。
Organization Name公司或组织的名称。
Organization Identifier

公司或组织的标识(很重要)。

一般情况下,这里输入的是公司或组织的域名(如com.geeksss)。写法类似于Java中的包名。

Bundle Identifier

捆绑标识符(很重要)。该标识符由Project Name+Organization Identifier构成。

因为在App Store上发布应用时会用到它,所以它的命名不可重复。

Language

开发语言选择。

这里可以选择开发应用所使用哦的语言,Xcode 6中可以选择Swift和Objective-C。

Devices

选择设备。可以构建基于iPhone或iPad的工程,也可以构建通用工程。

通用工程是指一个工程在iPhone和iPad上都可以正常运行。

 

  设置完相关的工程选项后,点击Next按钮,根据提示选择存放项目文件的位置:

 

  选择完存放路径之后,点击Create按钮,项目就创建完毕了。
  在项目资源列表中选择Main.storyboard,即可在编辑区中打开对应的设计器:

 

  在右下角的对象库中选择Label,将其拖拽到View设计界面上并调整其位置。

  双击Label,使其处于编辑状态(也可以通过控件的属性来设置),在其中输入HelloWorld:

 

  添加Label控件后,需要设置Label控件的位置。

  拖拽Label控件,此时会出现蓝色的虚线,说明该Label现在处于水平居中位置:

 

  但是如果现在运行该实例,我们会发现Label并非居中,还需要为Label添加Auto Layout约束。

  关于Auto Layout约束相关的内容,等后续再专门儿介绍吧。

 

  我们选择工具栏中的Resolve Auto Layout Issues(解决Auto Layout问题)按钮,在弹出的菜单中选择Add Missing Constrains(添加缺少约束):

 

  添加完成后,Label控件的上面和下面会出现两条蓝色竖线:

 

  至此,整个工程创建完毕。

 

  如图,选择运行的模拟器或设备,然后点击左上角的运行按钮,即可看到运行结果:

 

  点击运行后,如果是真机测试,第一次会提示输入您的Apple ID帐号,输入即可。完事儿就会在手机桌面上看到您的应用:

 

  但是当我们打开时,提示该应用来自不受信任的开发者,打开受限。

  毕竟我也没有购买开发者证书。。呵呵:

 

  这里我们按照提示,找到设置:

 

  通用:

 

  设备管理:

 

  在开发商列表中选择你刚刚在Xcode中输入的那个帐号:

 

  然后会看到该帐号所有应用的列表,点击信任该开发者:

 

  然后会有一个提示,确定要信任这家伙吗?确定即可:

 

  然后我们会看到咱的应用已经通过验证了:

 

  重新回到桌面,点击启动应用,OK,激动的一个界面映入眼帘:

 

  虽然界面很磕砷,并不高大上吧。但是我们在没有输入任何代码的情况下,就已经利用Xcode工具的Single View Application模板创建了一个工程,并成功运行。

  Xcode之强大可见一斑。

 

 

 

2. Xcode中的iOS工程模板

  刚刚我们创建项目的时候可以看到,iOS工程模板大概分为3类:Application、Framework&Library和Other。

  下面将分别介绍这三类模板:

2.1. Application类型

  我们大部分的开发工作都是从使用Application类型模板创建iOS程序开始的。该类型共包含5个模板,具体如下:

模板名称模板介绍
Master-Detail Application可以构建树形结构导航模式应用,生成的代码包含了导航控制器和表视图控制器等。
Game可以构建基于iOS的游戏应用。
Page-Based Application可以构建类似于电子书效果的应用,这是一种平铺导航。
Single View Application可以构建简单的单个视图应用。
Tabved Application可以构建标签导航模式的应用,生成的代码包含了标签控制器和标签栏等。

 

 

 

2.2. Framework&Library类型

  Famework&Library类型的模板如图,它可以构建基于Cocoa Touch Framework和Cocoa Touch Static Library的应用:

 

  Cocoa Touch Framework可以让开发者自定义应用于UIKit的框架,而Cocoa Touch Static Library可以让开发者创建基于Framework框架的静态库。

  由于代码安全和多个工程重用代码的考虑,我们可以将一些类或者函数编写成静态库。

  静态库不能独立运行,编译成功时会生成名为libXXX.a的文件(例如libHelloWorld.a)。

 

 

 

2.3. Other类型

  利用该类型,我们可以构建应用内购买内容包(In-App Purchase Content)和空工程。

  如图,使用应用内购买内容包,可以帮助我们构建具有内置收费功能的应用:

 

  我们可以根据需要选用不同的工程模板,这可以大大减少工作量。

 

 

 

3. 应用剖析

  在创建HelloWorld的过程中,生成了很多文件(展开Xcode左边的项目导航视图可以看到),如图:

 

  导航视图下有HelloWorld、HelloWorldTests、HelloWorldUITests和Products四个组。

  其中HelloWorld组中放置的是HelloWorld项目工程的重要代码,而HelloWorldTests组中放置的是HelloWorld程序的单元测试代码,HelloWorldUITest组中放置的是自动测试UI与交互的测试代码,Products组中放置的是编译之后的工程文件。

 

  下面,咱们重点介绍一下HelloWorld组中的项目内容。

 

  在HelloWorld组中,有两个类AppDelegate和ViewController,两个界面布局文件Main.storyboard和LaunchScreen.xib,以及一个组Supporting Files。

  Main.storyboard文件是故事板文件(下篇重点介绍),LaunchScreen.xib是应用启动界面的xib文件。故事板文件和xib文件比较类似。

 

  我们主要的编码工作就是在AppDelegate和ViewController这两个类中进行的,它们的类图如图所示:

 

  AppDelegate是应用委托对象,它继承了UIResponder类,并实现了UIApplicationDelegate委托协议。

  UIResponder类可以使子类AppDelegate具有处理相应事件的能力,而UIApplicationDelegate委托协议使AppDelegate能够成为应用程序委托对象,这种对象能够响应应用程序的生命周期。

  相应地,AppDelegate的子类也可以实现这两个功能。

 

  ViewController类继承自UIViewController类,它是视图的控制器类,在工程中扮演着根视图和用户事件控制器类的角色。

 

  AppDelegate类是应用程序委托对象,这个类中继承的一系列方法在应用生命周期的不同阶段会被回调,其定义如下:

 

  启动HelloWorld时,首先会调用上图画圈的application:didFinishLaunchingWithOptions方法,其它方法我们后续再详细介绍。

 

  在项目导航视图中,我们可以看到还有Images.xcassets文件,它可以放置工程的图片。

  Supporting Files组只有一个Info.plist文件,该文件是工程属性描述文件,其中保存着工程的属性设置。

  Products组是工程要生车功能的产品包。

 

说明:

  在访问资源文件时,文件夹和组是有区别的,文件夹中的资源在访问时是需要将文件夹作为路径的。

  如果icon.png文件放在image文件夹下,则访问它的路径是“image/icon.png”;如果image是组,则访问它的路径是“icon.png”。

 

 

 

4. 最后再扯个犊子

  没有结尾总觉得不好看。。。

 

  如果本文对您有帮助,不要忘记戳一下右下角的大拇指哦,呵呵。😄