App Programming Guide for iOS -> 期望的应用行为(一)

每个新Xcode项目都为能正确的运行在iOS模拟器上或者设备上进行了配置。但是只是简单的运行在设备上并不意味着你的应用已经准备好在App Store上销售。每个应用要求有一定量的定制来确保为用户提供良好的体验。自定义的范围能包含从为应用提供一个图标,到制定关于应用如何呈现和如何使用信息的架构级决策。本章描述的行为,是所有应用都期望处理的,并且你应该在计划阶段就开始考虑。

提供所需的资源

每个你创建的应用必须有下面一系列的资源和源数据,这样它才能在iOS设备上正确显示:

  • 一个information property-list(信息属性列表)文件。Info.plist文件包含关于应用的源数据,系统使用这些来与应用进行交互。Xcode根据项目的配置和设置自动为你创建这个文件。如果你想直接查看或者修改这个文件的内容,你可以在项目的Info选项卡中进行。关于编辑这个文件以及你应该包含什么键的建议,参见The Information Property List File。
  • 应用要求的功能声明。每个应用必须声明运行所需的硬件能力或者功能。App Store使用这些信息确定在特定设备上用户能否运行你的应用。你能在项目的Info选项卡的Required device capabilities条目中编辑应用的需求列表。关于如何配置这个键,详见Declaring the Required Device Capabilities。
  • 一个或多个图标。系统在用户设备的主屏幕上显示你的应用图标。系统也在Setting应用或显示搜索结果的时候使用其他版本的图标。关于如何指定应用图标的信息,详见App Icons。
  • 一个或多个启动图片。当应用被启动,系统显示一张临时的图片,直到应用能够显示它的用户界面为止。这张临时图片就是应用的启动图片,它给用户提供一个即时反馈,让用户感觉到应用已经启动并很快就会完成准备。你起码要为你的应用提供一张启动图片,并且你或许需要为特定的屏幕提供额外的启动图片。关于创建启动图片的信息,详见App Launch (Default) Images。

这些资源是所有应用都需要的,但不是唯一你应该包含的资源。默认情况下,有很多键Xcode并没有包含在应用的Info.plist文件里。一旦你合并特定的功能到你的应用,很多额外的键就会很重要。例如,应用使用麦克风就应该包含NSMicrophoneUsageDescription键,并向用户提供关于应用会如何使用它的信息。

应用程序束(Bundle)

但你构建iOS应用的时候,Xcode把它打包成一个bundle(束)。一个束是一个在文件系统中的目录,它把相关的资源分组放在一起。一个iOS应用程序束包含应用的可执行文件和支持资源文件,例如应用图标、图片文件、以及本地化内容。表1-1罗列了一个典型iOS应用程序束的内容,出于演示目的,这个束被称为MyApp。这个例子仅用于说明目的。表中所列的某些文件或许不会出现在你的应用程序束中。

表1-1 一个典型的应用程序束

文件 例子 描述
App executable MyApp 可执行文件包含应用的编译代码。应用的可执行文件的名字和应用的名字就多了一个.app扩展名。
该文件是必须的。
The information property list file Info.plist Info.plist文件包含app的配置数据。系统使用这些数据来决定如何和应用进行交互。
这个文件是必须的,且必须命名为 Info.plist。更多信息,参见The Information Property List File.
App icons Icon.png
Icon@2x.png
Icon-Small.png
Icon-Small@2x.png
图标在设备的主屏幕上代表的是你的应用。其他图标被系统用在了合适的地方。文件名带有@2x的图标适用于带有Retina显示器的设备。
应用图标是必须的。关于特定的图标图片文件的信息,参见App Icons。
Launch images Default.png
Default-Portrait.png
Default-Landscape.png
当应用启动的时候,系统使用这个文件作为临时的背景。一旦应用准备好显示它自己的用户界面的时候,它会被移除。
起码要有一张启动图片。关于特定启动图片的信息,参见App Launch (Default) Images。
Storyboard files (or nib files) MainBoard.storyboard Storyboard包含应用显示在屏幕上的视图和视图控制器。在storyboard中的视图被呈现它们的视图控制器组织。storyboard还识别将用户从一组视图带到另一组视图的转换(称为segue)。
当你的项目创建的时候,Xcode设置了一个名为main storyboard的文件。你可以通过分配一个不同的值到 Info.plist文件中的UIMainStoryboardFile键来改变这个名字。应用使用nib文件代替storyboard可以通过将UIMainStoryboardFile键替换为NSMainNibFile键,并把这个键指定为主nib文件实现。
使用storyboard(或nib文件)是可选的,但是建议使用。
Ad hoc distribution icon iTunesArtwork 如果你正在临时分发你的应用,那么就需要包含一个512 x 512像素版本的应用图标(icon)。这个图标通常由App Store从你提交到iTunes Connect中的资料中提供。但是,因为应用是临时分发,不经过App Store,所以你的图标必须存在于你的应用程序束中。iTunes使用这个图标来表示你的应用。(如果你的应用通过这种方式分发,那么你指定的文件应该和你想将要提交到App Store中的一致。)
这个图标的名字必须是iTunesArtwork,并且不能有扩展名。这个文件必须用于临时发布,但是可以没有这个图标。
Settings bundle Settings.bundle 如果你想通过Settings应用公开自定义应用首选项(preferences),你必须要包含设置束(settings bundle)。这个束包含属性列表(property list)数据和定义应用首选项的其他资源文件。Settings应用使用这个束中的信息来组合应用所需的元素界面。
这个束是可选的。更多关于首选项和定制一个设置束的信息,参见Preferences and Settings Programming Guide。
Nonlocalized resource files sun.png
mydata.plist
非本地化(nonlocalized)资源包括应用使用的图片、声音文件、电影、以及自定义数据文件。所有这些文件应该位于应用程序束的顶层位置。
Subdirectories for localized resources en.lproj
fr.lproj
es.lproj
本地化资源必须位于特定语言(language-specific)项目目录中,它的名字由一个ISO 639-1语言所写加上.lproj后缀组成。(例如, en.lproj, fr.lproj, 以及 es.lproj目录包含本地化的英语、法语、以及西班牙语的资源。)
一个 iOS应用应该是国际化的,并且为它支持的每种语言提供一个 (语言.lproj)目录。除了提供应用的自定义资源本地化版本,你还可以通过在特定语言项目目录中放置同名文件来本地化应用图标、启动图片、以及Settings图标。
更多信息,参见 Internationalizing Your App。

注意:iOS应用程序束不能包含一个名为Resources的自定义目录。

更多关于iOS应用程序束结构的信息,参见Bundle Programming Guide。关于如何从你的束中加载资源文件,参见Resource Programming Guide。

属性列表(property list)文件信息

在编译的时候,Xcode使用来自项目的General、Capabilities、以及Info选项卡中的信息为应用产生一个信息属性列表(Info.plist)。Info.plist文件是个结构化的文件,它包含关于应用配置的关键信息。它会被App Store和iOS用来确定应用的功能,以及定位关键资源。每个应用都必须包含这个文件。

尽管Info.plist文件通过Xcode提供了所有必须条目的默认值,但是大多数引用需要一些更改或添加。只要有可能,使用General和Capabilities选项卡来指定应用配置信息。这些选项卡包括了大多数应用可用的一般性配置选项。如果你在这两个选项卡中没有看到特定的选项,那就使用Info选项卡。

对于Xcode没有提供自定义配置界面的选项,你必须使用Xcode属性列表编辑器来直接提供合适的键和值。在Info选项卡的Custom iOS Target Properties部分包含了所有在Info.plist文件中的条目的摘要。默认情况下,Xcode显示期望功能的可读描述,但每个功能实际上对应Info.plist文件中的唯一键。很多键是可选的且很少用到,但这里有几个键需要你在定义一个新项目的时候考虑:

  • 在Info选项卡中声明应用所需的功能。Required device capabilities部分包含了应用运行所需的关于设备级别功能的信息。App Store使用这个条目提供的信息来确定应用的功能,并且阻止不支持应用要求的功能的设备安装它。更多信息,参见Declaring the Required Device Capabilities。
  • 要求持续Wi-Fi连接的应用必须声明。如果应用通过网络和服务器对话,你必须添加Application uses Wi-Fi条目到项目的Info选项卡。这个条目对应Info.plist文件的UIRequiresPersistentWiFi键。将此键设置为YES,阻止iOS在长时间不活动的时候关闭Wi-Fi连接。此键推荐所有使用网络和服务器进行通信的应用使用。
  • Newsstand应用必须自己声明。包含UINewsstandApp键来表明应用提供了来自Newsstand应用的内容。
  • 定义了自定义文档类别的应用必须声明这些类型。使用Info选项卡中的Document Types部分来为你支持的文档格式指定icons和UTI信息。系统使用这个信息来识别能处理特定文件类型的应用。更多关于向你应用添加文档支持的信息,参见 Document-Based App Programming Guide for iOS。
  • 应用能声明任何它支持的自定义URL方案。使用Info选项卡中的URL Types部分来指定应用处理的自定义URL方案。应用能使用自定义URL方案来彼此通信。更多关于如何实现折现功能的信息,参见Using URL Schemes to Communicate with Apps。
  • 应用必须为访问用户数据和某些应用功能提供目的字符串(有时候被称为“使用描述”)。当应用访问用户数据或者设备功能涉及到隐私内容的时候,iOS提示用户并代表应用请求许可。应用必须通过在Info.plist文件中定义目的字符串来向用户解释为什么它要请求访问。如果你试图在没有提供相应的目的字符串就访问,应用推出。需要用户许可的数据和功能在表1-2中描述。目标字符串在Information Property List Key Reference的Cocoa Keys章节被描述。

关于你能在Info.plist文件中包含的键与值的具体信息,参见Information Property List Key Reference。

声明所需的设备功能

所有应用必须声明它们运行所需的特定设备功能。Xcode在项目的Info选项卡中包含一个Required device capabilities条目并用最小需求填充。你能给这个条目添加值来指定应用的额外需求。 Required device capabilities条目在Info.plist文件中对应UIRequiredDeviceCapabilities键。

UIRequiredDeviceCapabilities键的值可以是数组也可以是字典,它们包含包含识别特定应用所需功能(或特定的禁止)的额外的键。如果你使用数组指定键的值,存在的键表示这个功能是必需的;不存在的键表示这个功能不是必需的,且应用可以在没有它们的时候仍可运行。如果你使用自店,字典中的每个键必需有一个布尔值来表示这个功能是必需的还是被禁止的。值true表示这个功能是必需的,值flase表示这个功能必须不能出现在设备中。如果给定的功能对于应用是可选的,不要包含字典的对应键。

可以包含在UIRequiredDeviceCapabilities键的值的具体信息,参见Information Property List Key Reference。

应用图标(icon)

每个应用必须提供图标用来在设备的主屏幕上和App Store中显示。应用实际上可以为不同情况指定多个不同的图标。例如,当现实搜索结果时应用要提供一个小图标,而对Retina显示器则提供高分辨率的图标。

新Xcode项目包含一个访问应用图标图片的图片资源入口。想要添加图标,分配合适的图片文件到项目的图片资源中。在构建的时候,Xcode添加相应的键给你的Info.plist文件,并在应用束中放置图片。

关于设计应用图标的信息,包括这些图标的尺寸,参见iOS Human Interface Guidelines。

应用启动图片

当系统第一次在设备上启动应用的时候,它会在屏幕上临时显示一张静态的启动图片。这个图片是你的应用启动图片,它是一个你在Xcode项目中指定的资源。启动图片提供给一个即时反馈,表明你的应用已经启动,正在准备初始化用户界面。当应用窗口配置完毕并且准备好显示的时候,系统会用这个窗口来替换启动图片。

当最近的应用的用户界面快照可用时,系统会使用这个快照而不是启动图片。当应用从前台转换到后台的时候,系统会的到应用用户界面的快照。当应用返回到前台的时候,只要有可能,它就会使用这个图片代替启动图片。在用户杀死了应用进程或者有太长时间没有使用的情况下,系统会丢弃这个快照而再次使用启动图片。

新Xcode项目包含一个访问应用启动图片的图片资源入口。想要添加启动图片,分配合适的图片文件到项目的图片资源中。在构建的时候,Xcode添加相应的键给你的Info.plist文件,并在应用束中放置图片。

关于设计应用启动图片的信息,包括这些图标的尺寸,参见iOS Human Interface Guidelines。

(未完待续......)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,794评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,050评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,587评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,861评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,901评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,898评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,832评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,617评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,077评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,349评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,483评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,199评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,824评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,442评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,632评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,474评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,393评论 2 352

推荐阅读更多精彩内容