写点什么

Flex 移动 skin–第 3 部分:多平台开发

  • 2011-08-21
  • 本文字数:10496 字

    阅读完需:约 34 分钟

在关于创建 Flex 移动皮肤系列文章的第二部分里,我们讨论了屏幕密度(DPI)对组件皮肤以及移动应用布局所带来的影响。 我还展示了如何使用缩放应用,特定密度的位图,以及CSS 元媒介查询以调整和适应多种DPI 值。

除了屏幕尺寸,屏幕密度以及外形差异以外,Flex 移动应用开发者必须在着重于各个平台之间的不同点。 除了Android 系统以外,Flex4.5.1 以及Flash Builder4.5.1 还支持两个目标为Flex Mobile 项目的平台:苹果的iOS 以及黑莓的TabletOS。 这些平台都有各自独特的外观,用户体验,UI 图案,以及人机接口规范(HIG)。

Flex 4.5 中的移动主题并不会偏向于任何一个特定的平台。 就像 Spark 那样,移动主题具有中性的外观以及感觉,其设计元素可以工作于各个平台。 根据您的需求以及客户的需求,可以利用 CSS 样式快速而自由地改变应用程序的外观,或者您还可以使用更加高级的机制,比如自定义皮肤,FXG,或者特定于平台的皮肤,与其它原本的应用程序结合使用,从而获得更多的控制余地。

要求

为了满足本文条件,你需要下列软件和文件。

Flash Builder

范例文件

mobile-skinning-part3

必备知识

要求熟悉 ActionScript、CSS 和 Flex skin。应该在完成本教程之前阅读本系列的第 1 部分第 2 部分

显著的平台差异

AIR 所支持的每一个平台均具有独特的特点,特质以及挑战。 Flex 4.5.1 占据了这些挑战中的一部分,并且让用户可以在必需的时候添加新的,特定于平台的行为。 本部分将简单地涵盖那些将会影响应用程序的可视化设计以及行为设计的平台之间的主要不同点。

硬件按钮

Android 上的 AIR 添加了对 Android 硬件上键盘按钮的支持:主页键,返回键,菜单键以及搜索键。 这些按钮可以是实实在在的硬件按钮,也可以是通过触摸屏显示出来的按钮。 某些设备制造商可能会忽略搜索按钮。

Android 上的返回按钮用于导航回到上一个活动,即便该活动并非当前应用程序的一部分。

iOS 设备以及黑莓的 PlayBook 并不具备这样的返回按钮。 相反,iOS 和 PlayBook 的一个典型的应用可以在屏幕的左上方放置一个返回的软按键。 对于这两个平台,返回键的导航功能是局限在每个应用程序本身的。

Android 上的菜单按钮将会打开一个选项菜单(即是 Flex 4.5 上的 ViewMenu 移动组件)。 选项菜单中会显示一个可用于当前活动的命令(作为按钮)列表。

在 iOS 中功能最接近的组件应该就是活动表了。 活动表能以列表的形式显示当前活跃或者当前已选择的条目的可用活动。

黑莓的 PlayBook 配备有一个触控的边框,应用程序可以通过该边框显示一个包含任意控件的容器。

Android 上的搜索按钮通常使用在应用程序上下文的数据搜索当中。 比如,一个联系人应用程序就需要提供一个文本搜索功能,以筛选联系人的数据信息。 Android 上的搜索操作对于所有应用程序均具有一致的外观和感觉。 iOS 与黑莓的 Tablet 操作系统均不具备针对于特定应用程序的搜索 UI 设计元素。

可用的屏幕面积

Android 2.x 以及 iOS 在应用程序顶部仅显示有一个状态栏,当应用程序进入全屏模式时,该状态栏便会隐藏。

在 Android 3.x Honeycomb 当中,屏幕底部的状态栏总是可见的,无论是否处于全屏状态下。

对于黑莓 PlayBook 上的应用程序,默认均运行在全屏模式下。 从右上角滑下便可以显示系统状态栏,但这并不会重设 AIR 应用程序窗口的大小。

活版印刷

AIR 中所使用的默认 sans serif 设备字体会根据设备的不同而有所不同。 PlayBook 将使用 Myriad Pro,而 iOS 则使用 Helvetica,Android 使用 Droid Sans。

为了清晰起见,即使在不同的设备上使用相同的字体尺寸以及相同的 DPI,其字体度量也会因为所使用的字体不同而有所不同。 在给定的面积中,用户所能够放置的文本总量会因为屏幕尺寸以及平台的不同而有所不同(参见图 1)。

左图为黑莓的 PlayBook(横向, cropped),中图为苹果 iPod 第四代(portrait),右图为三星 Galaxy S(纵向)使用了 Flex 移动主题的默认样式。

图 1,左图为黑莓的 PlayBook(横向, cropped),中图为苹果 iPod 第四代(portrait),右图为三星 Galaxy S(纵向)使用了 Flex 移动主题的默认样式。

在各个平台上,单行的文本内容通常会中央上升(也就是说,不包括文本高度的下行字母)。移动主题里的皮肤还会使用中央上升。

软键盘

全部三个平台的纵向以及横向情况下均支持使用软键盘。

然而,许多 Android 手机拥有一个固定的硬件键盘而不是软键盘(例如,摩托罗拉 Droid Pro),而其它的一些 Android 手机具备可选的硬件键盘,可开启用于取代软键盘。

Android 手机还允许使用第三方的软键盘。 比如,Swype 和 SwiftKey 键盘便可以与 AIR 无缝集成。

软键盘的尺寸随着平台,设备,甚至设备方位的不同而有所差异。 但无论设备的方位如何,全部三个平台所使用的软键盘均与屏幕底部的边缘对齐。

默认情况下,当软键盘被激活或停用时,在 Flash Builder 中所创建的 Flex 移动项目均会自动配置以缩小或扩大应用程序的高度。

文本输入

在 Android 和黑莓的 PlayBook 平台中,AIR 应用程序的 TextField 以及新的 StyleableTextField 控件中的文本输入均可正常工作。

然而,这些控件在 iOS 中的实现却是一个特例。 为了能在 iOS 中获得功能齐全的纠错和文本选择功能,文本编辑将会包含在一个原生的覆盖于屏幕最上方的控件之中。 当在 iOS 中编辑 TextField 和 StyleableTextField 内容时,该技术会带来一些限制,包括:

  • 在编辑时是不支持 Restrict 属性的。 限制操作将在退出 TextField 之后才可以使用。
  • 在进入或者退出可编辑的 TextField 时,由于空白和短划线字符较小,可能会导致多行文本回流。
  • 文本无法被父级容器所指定的 scrollRect 属性剪切。
  • 键盘事件将不会被触发。
  • 原生的清除按钮(带有 X 标记的灰色圆圈)总会出现在 TextInput 当中,并且这是不可配置的。

颜色的深浅

在苹果 iOS 和黑莓 Talblet OS 中,AIR 均支持 32 位色。 而在 Android 中,AIR 在使用 RGB565 时受限于 16 位颜色。

人机界面规范

每个平台供应商都具有其独特的人机接口规范(HIG),称为 UI 规范。

以下这些规范将有助于用户创建出外观和使用感受都与那些本土程序类似的 Flex 移动应用程序。

特定平台的综述

关于特定的平台,我仅仅触及到表面的问题。 想获取关于该主题的更多信息,您可以浏览 www.androidpatterns.com* 以及 pttrns.com* ,这两个网址将持续更新它们的 UI 模式目录。

在 AIR 允许设计者和开发者以通用的运行时来创建应用程序的同时,设计应用程序中很重要的一点是,您必须清楚何时以及如何将特定于平台的不同点考虑在内。 Flex 移动项目为您提供了一个选择范围,从在所有平台上使用单一的 UI,到为每个所支持的平台重新设计 UI。

创建特定平台的外观和样式

4.5.1 版本的 Flex 和 Flash Builder 为您在项目中定义和使用特定平台的样式和外观提供了基本工具。

使用 CSS 媒体查询

在关于创建 Flex 移动外观系列的第二部分中,我讨论了如何在 CSS 媒体查询中使用自定义的媒体功能 application-dpi来设置特定的 DPI 样式,比如字体大小和填充值。 4.5 版本的 Flex 提供了一个额外的自定义媒体功能:os-platform。 此项功能允许开发人员指定特定于平台的样式。 下面是一个简单的例子,设置一个默认的 ActionBar chromeColor的数值,以及特定于 Android 以及特定于 IOS 的数值 :

复制代码
ActionBar { chromeColor: #000000; }
@media (os-platform: "Android")
{
ActionBar { chromeColor: #999999; /* dark gray */ }
}
@media (os-platform: "IOS")
{
ActionBar { chromeColor: #6DA482; /* blue */ }
}

此示例代码使用了来自移动主题的默认 ActionBarSkin 皮肤类,并改变了 chromeColor 属性。 您可以使用同样的技术来完全替代特定于平台的默认外观。

主题的使用

为特定于平台的外观使用 CSS 的主要缺点是,无论何种平台,所有的外观及其附属文件都将被编译到您的应用程序中。 这是必要的,因为 CSS 媒体查询是在运行时,而不是编译时,进行计算的。 最终的结果是生成一个更大的二进制文件(APK,BAR,或者 IPA 类型的文件),该文件会增加下载时间和并添加到程序历史记录。

获取特定于平台的外观和样式的另一种方式是,分别为每一个平台编辑应用程序,通过每次改变 theme 编辑器参数来覆盖不同的主题。 这将赋予您特定于平台的样式,而不会增大应用程序的二进制文件尺寸。

请注意:在单一的项目中,4.5.1 版本的 Flash Builder 没有内置对每个平台编译器参数的支持。 您有三种选择:

  • 创建您自己的编译脚本
  • 对于每个平台,每当创建项目时都要手动修改参数。
  • 将您的项目重构到共享相同基础项目和 / 或库的多个项目当中。

第三个选项提供了最大程度的控制,为您提供更多用来添加特定平台操作的选择(例如,iOS 和黑莓 Talblet os 中屏幕上的返回按钮)。

如果您选择以这种方式来使用主题的话,请选择一个最适合您的工作流程的构建选项。

想获取更多关于 Flex 4.x 中主题支持的信息,请参阅 Flex 说明文档中关于主题的部分内容

ActionBar 样式教程

通常情况下,对外观做出改变的最简单方法是使用 CSS 样式。 对于这个例子,我将详细叙述之前展示的 ActionBar 示例样式,以加入更多一些特定于平台的细节。

我正在为虚拟业务评测启动开发一个名为 _holr!_ 的应用程序。 他们希望 ActionBar 看起来能够像那些在三个平台上的本地应用程序一样,但是他们没有预算将金钱花在自定义皮肤上。

在本教程中,我将展示每个平台的 CSS 示例。 请记住,那些样式应该定义在应用程序 MXML 文件中的 ``内嵌标签或者外部文件中。

我将从以下由 Flex 移动项目向导中的基于视图的应用程序模版所创建的应用程序 MXML 开始:

复制代码
<?xml version="1.0" encoding="utf-8"?>
<s:ViewNavigatorApplication
xmlns:fx=http://ns.adobe.com/mxml/2009
xmlns:s="library://ns.adobe.com/flex/spark"
firstView="views.holrHomeView">
<fx:Style>
@namespace s "library://ns.adobe.com/flex/spark";
</fx:Style>
<s:navigationContent>
<s:Button label="Back"/>
</s:navigationContent>
<s:actionContent>
<s:Button label="Save"/>
</s:actionContent>
</s:ViewNavigatorApplication>

理想情况下,如果我的目标是要获取一个二进制文件,那么当在 Android 中运行时,我将会添加一些逻辑来压缩 ActionBar 中的返回按钮。 而对于这一个样式示例,我将不会对它做任何的改变,从而避免事情复杂化。

Android

该移动主题很好地反映了当今 Android 应用程序的外观。 平面式的按钮非常适合工作。 我所要做的就是改变 chromeColor的属性,以使客户端签名呈现红颜色(参见图 2)。 由于我将在所有平台上使用同样的颜色,所以不需要在媒体查询中捆绑这项规则。

复制代码
s|ActionBar
{
chromeColor: #990000;
}

在 Android(240 DPI) 上的 holr!

图 2.在 Android(240 DPI) 上的 holr!

默认情况下,ActionBar 中的标题是左对齐的。 如果您想将标题居中(见图 3),您可以将titleAlign:center添加到ActionBar样式规则中。

图 3.  在 Android(240DPI)中的 holr!,并且 titleAlign=center

图 3. 在 Android(240DPI)中的 holr!,并且 titleAlign=center

苹果 iOS

适用于 iOS 的 ActionBar 样式变得有点复杂。 标题是居中对齐的,并且该按钮具有独特的形状和一些非零填充。 幸运的是,ActionBar 的defaultButtonAppearance样式包含正常和倾斜两种选择。

将 ActionBar 的defaultButtonAppearance样式设置为beveled(倾斜),自动设置几个样式的参数值,包括斜角按钮,导航与活动类周围的填充,以及中心标题对齐(见图 4)等。如果想要查看用于defaultButtonAppearance=beveled的所有设置,您可以在目录 4.5.1/frameworks/projects/mobiletheme/defaults.css 中找到移动主题的 defaults.css 文件,并查看.beveled样式名称选择器的使用方法。

复制代码
@media (os-platform: "IOS")
{
s|ActionBar
{
defaultButtonAppearance: beveled;
}
}

图 4. 在苹果 ipod touch 第四代上的 holr!  (320 DPI)

图 4. 在苹果 ipod touch 第四代上的 holr! (320 DPI)

黑莓的 Tablet os(平板电脑操作系统)

为黑莓所设计的 ActionBar 样式可能会更加复杂一点。 我说这话的原因是,RIM 公司利用他们自己以 MovieClip 为基础的组件提供了独有的 Flash UI 框架。 虽然在这个例子中可以集成原生的 RIM 组件,但是我将坚持使用 Flex。

RIM 在他们内置的应用程序顶部使用了一种类似于 ActionBar 的容器。 这些应用程序中的大部分都使用一种通过透明的 ActionBar 显示的背景图像或者纹理。 像 IOS 一样,RIM 也采用了中心对齐的标题。 然而,RIM 的标题使用了一种正常的字体粗细,而不是粗体。

RIM 在 ActionBar 两侧使用了圆形按钮。 然而不同于 iOS,RIM 公司并没有使用一个箭头式的返回按钮(见图 5)。

PlayBook 拥有一块实际 DPI(分辨率)为 170 的屏幕。这已经足够高了,Flex 团队为 160DPI 分类所选择的字体大小要比 RIM 推荐的小一点点。 在这个例子中,我会对字体尺寸进行一些调整作为补充。 为了获取包括字体尺寸数值更新在内的全套样式,请下载 defaults_BlackBerry_PlayBook.css 示例文件。

您可以无比接近 RIM 的外观并且亲自感受它,但是您必须覆盖一些来自于使用先进 CSS 选择器的移动主题的 CSS 规则。

复制代码
@media (os-platform: "QNX")
{
s|ActionBar
{
defaultButtonAppearance: beveled;
}
s|ActionBar #titleDisplay
{
fontSize: 22;
fontWeight: normal;
}
s|ActionBar.beveled s|Group#navigationGroup s|Button
{
/* use the rounded button instead of the arrow button */
skinClass: ClassReference("spark.skins.mobile.BeveledActionButtonSkin");
}
s|ActionBar.beveled s|Group#actionGroup s|Button,
s|ActionBar.beveled s|Group#navigationGroup s|Button
{
fontSize: 16;
fontWeight: normal;
}
}

图 5. 在黑莓的 PlayBook (160 DPI) 上的 holr!

图 5. 在黑莓的 PlayBook (160 DPI) 上的 holr!

最终的应用程序文件看起来像下面这样:

复制代码
<?xml version="1.0" encoding="utf-8"?>
<s:ViewNavigatorApplication xmlns:fx="http://ns.adobe.com/mxml/2009" xmlns:s="library://ns.adobe.com/flex/spark" firstView="views.holrHomeView">
<fx:Style>
@namespace s "library://ns.adobe.com/flex/spark";
@namespace s "library://ns.adobe.com/flex/spark";
s|ActionBar { chromeColor: #990000; }
@media (os-platform: "IOS")
{
|ActionBar { defaultButtonAppearance: beveled; }
}
@media (os-platform: "QNX") {
s|ActionBar { defaultButtonAppearance: beveled; }
s|ActionBar #titleDisplay { fontSize: 24; fontWeight: normal; }
s|ActionBar.beveled s|Group#navigationGroup
s|Button {
/* use the rounded button instead of the angled back button */
skinClass:ClassReference("spark.skins.mobile.BeveledActionButtonSkin");
}
s|ActionBar.beveled s|Group#actionGroup s|Button, s|ActionBar.beveled
s|Group#navigationGroup s|Button
{ fontSize: 20; fontWeight: normal; }
global { fontSize: 20; }
}
</fx:Style>
<s:navigationContent>
<s:Button label="Back"/>
</s:navigationContent>
<s:actionContent>
<s:Button label="Save"/>
</s:actionContent> </s:ViewNavigatorApplication>

一条关于高级 CSS 选择器的快速注解:移动主题会使用styleNameID选择器来将样式从具体的 ActionBar 皮肤组件中区分出来。 我这样做是为了避免无意中改变 ActionBar 内容组中其他组件的样式。 例如,我不想让 ActionBar 中的按钮与标题文本具有同样的字体尺寸值。 我真的希望标题使用更大的文本以便凸显出来。

样式总结

改变内置的移动主题的样式是非常简单的。 虽然特定于平台为 ActionBar 修改样式会更加复杂,但是归功于defaultButtonAppearancetitleAlign 风格,这并不是太困难。

移动主题覆盖教程

现在,轮到最困难的部分了。 这里的第二篇教程将会帮助您打下基础,从而为 Flex 移动项目创建您自己的主题。

如果您愿意的话,可以跳过主要教程,直接查看我的 iOS 主题示例。 这个主题仅仅是一种概念的证明,但它确实可以表现出 Flex 更换皮肤功能有多么强大。

为了简洁起见,下面的教程会介绍如何创建一个使用移动主题作为基本主题的主题覆盖。 在一般情况下,Flex4 主题作者应该为桌面项目的 Spark 主题或者移动应用程序的移动主题创建一些覆盖。 许多重要的样式特性仅仅在使用一些指定主题名称时才适用。 例如,chromecolor只在 Spark 和移动主题中才适用。 如果您创建并使用了一个独立的主题,并且参考了 CSS 或 MXML 中的chromeColor,编译器便会记录到一个错误。

阶段 1:创建一个主题项目

创建自定义主题的第一步是创建一个库项目。 这个项目将输出您可以通过任何兼容项目重复使用的主题 SWC 文件。

  1. 选择 File(文件) > New(新建) > Flex Library Project(Flex 库项目)。
  2. 为该项目键入一个名称;例如,键入mobiletheme_ios
  3. 在 Configuration(配置)项目栏中,选择 Mobile Library(移动库)来包含一个 mobilecomponents.swc 文件(见图 6)。 图 6. 创建一个移动库

图 6.创建一个移动库
4. 点击下一步。 既然您想扩展该移动主题,便需要添加它的 swc 文件以便扩展类以及从该主题中引用其他的附属文件。
5. 点击添加 SWC。
6. 在 Add SWC 对话框中 (见图 7), 输入在 SDK 中的移动主题 swc 文件路径:/path/to/Adobe Flash Builder 4.5/sdks/4.5.1/frameworks/themes/Mobile/mobile.swc
7. 点击 “OK”。 图 7. 添加移动主题 swc

图 7.添加移动主题 swc

一旦被添加到构建路径库树中,该 swc 文件便会被扩展。
8. 双击链接类型(见图 8)。 图 8. mobile.swc 的连接类型。

图 8. mobile.swc 的连接类型。
9. 选择 External(外部)作为连接类型(见图 9),并点击 OK。 图 9. 将连接类型改为 External(外部)。

图 9. 将连接类型改为 External(外部)。

这一步是必需的,如此的话,从移动主题 SWC 所添加的附属文件将不会被编译到自定义主题当中。 默认的移动项目配置(参见 /path/to/4.5.1/frameworks/airmobile-config.xml)会默认添加移动主题 SWC。 之后,当创建 Flex 移动项目时,您就不必单独添加移动主题 SWC 了。
10. 双击源附件中的 mobile.swc
11. 设置文件路径为 /path/to/Applications/Adobe Flash Builder 4.5/sdks/4.5.1/frameworks/projects/mobiletheme/src ,并单击"OK"(见图 10)。 图 10. 改变源路径

图 10. 改变源路径

对移动主题中诸如类的 Go To Definition 功能的支持是必需的。 在添加了该 SWC 后,Flash Builder 最初使用的路径是不正确的。
12. 单击"完成"以创建项目。

阶段 2:为主题的开发配置库项目

现在您已经有了一个项目,但还需要几个步骤将它配置为一个主题。

  1. 在项目根目录下创建一个 defaults.css 文件(不是主 src 文件夹,而是项目文件夹本身)。 这个文件将会为该主题定义样式规则。
  2. 选择 Project (项目)> Properties(属性)。
  3. 在 Flex Library Compiler(Flex 库编译器)页面的 Additional Compiler Arguments(附加编译器参数)中添加: ```

-include-file defaults.css …/defaults.css.

复制代码
4. 点击 "OK"。
这样便完成了一个主题 SWC 的基本设置了。 在 defaults.css 中定义样式并添加其他皮肤类之后,在该项目的 bin 文件夹中的 SWC 文件可以通过两种方式被用作主题覆盖:
- 在 Flex 编译器属性页面将 -theme+=/path/to/theme.swc 添加到 Additional Compiler Arguments(附加编译器参数)中。
- 通过选择 Project (项目)> Properties (属性)> Flex Theme(Flex 主题)来导入主题 SWC。
如果您正在创建主题,为了获得更加醒目的导入体验,您可以将元数据以及预览图像连同自己主题的 SWC 或者 CSS 文件一起添加。 想获取更多关于主题创建的信息,请参见 [创建主题](http://help.adobe.com/zh_CN/Flex/4.0/UsingFlashBuilder/WS9E4C4475-896E-43a2-9461-497F2F85D424.html#WS4F7FCF53-3891-4b51-A63E-F83C695B325C)。
### 第三阶段:创建一个 Flex 移动项目
在建立该主题之后,并且在创建皮肤之前,我将会设立一个项目来测试我的主题,正如我在开发主题时那样。 在这个项目中,我使用了一些技巧来使我的主题在迭代上更容易一些。
1. 选择 File(文件) > New(新建) > Flex Mobile Project(Flex 移动项目)。 键入一个项目名称,使用默认设置,然后点击 " 下一步 "。
2. 单击 "Add Project(添加项目)",并添加您的主题项目。
3. 单击 Finish(完成),Flash Builder 将会创建该项目。
4. 选择 Project (项目)> Properties(属性).
5. 在 Flex 编译器属性页,添加`-theme+=/<theme project name>/bin/<theme project name>`.swc 到 Additional Compiler Arguments(附加编译器参数)。 这个参数会将应用主题覆盖到该项目。
6. 点击 "OK"。
7. 在主题项目中,将一个名为 ThemeClasses 的类添加到默认包。
8. 在移动的项目的主应用程序 MXML 文件中,在一个`<fx:Script>`标签中添加一个对这个类的引用。 只需一个诸如`ThemeClasses`的简单声明便已足够了。
您可能在想为什么我不使用项目属性对话框中的 Flex 主题的属性页来设立一个主题呢。 简短的回答是,Flash Builder 中的主题功能主要是设计用来导入预建的无法改变的主题。 正如我对主题项目进行的增量更改,我希望重新编译移动项目。 当主题项目发生改变时,这些步骤是让 Flash Builder 重新编译移动项目所必需的。
### 第 4 阶段:创建外观和样式
这一阶段占据了这项工作的主体。 在关于创建 Flex 移动皮肤系列的 [Part 1](http://www.adobe.com/cn/devnet/flex/articles/mobile-skinning-part1.html) 和 [Part 2](http://www.infoq.com/cn/news/2011/07/mobile-skinning-part2) 中,我已经详细介绍了移动换肤开发过程。总括来说,其过程如下: 总括来说,其过程如下:
1. 创建 graphic assets(图形资源),如 FXG。
2. 创建一个新的基于 MobileSkin 的皮肤,或者继承一个现有的移动主题皮肤。
3. 定义`hostComponent` 属性。
4. 指定 FXG assets。
5. 适当地支持移动主题样式(比如,`chromeColor` )。
6. 在该主题的 defaults.css 文件中指定 Css 样式规则。 对于您计划想要支持的每个组件,请指定不会被 DPI 影响的自定义`skinclass`和样式数值。
7. 使用`application-dpi`媒体查询功能来指定额外的 CSS 样式规则,从而筛选针对每个 DPI 字体尺寸以及填充样式。
8. 为每个主机组件重复这些步骤。
由于在先前的文章里已经介绍过这个过程,所以这里我将跳过一些细节内容。 如果您到目前为止都跟随这本指导的步骤,那么将可以从前一个指导中将 CSS 示例复制到主题库项目的 defaults.css 文件中。 当您运行移动项目的时候,它将从主题中拾取样式规则。
### 概念验证:iOS 主题
我所创建的 iOS 主题很大程度上依赖基于 MobileSkin 基类以及 Flex 4.5 移动主题默认皮肤中的自定义皮肤。
由于这些主题将要用于任意类型的项目,所以我没有使用特定于平台的查询功能来筛选基于平台的样式规则。 这为我在 Android 或者黑莓 Tablet OS 应用上根据需要使用自己的 iOS 主题提供了很大的灵活性。
为了测试 Flash Builder 4.5.1 下的 iOS 主题,请下载 mobiletheme\_ios\_usage.fxp 示例文件,并遵循以下的指导:
1. 选择 File(文件) > Import Flash Builder Project(导入 Flash Builder 项目)。
2. 导航至 mobiletheme\_ios\_usage.fxp,并选中该文件。
3. 点击完成。
4. 选中 mobiletheme\_ios\_usage 项目,然后点击 Run 按钮(或者选择 Run(运行) > Run As(运行为) > Mobile Application(移动应用程序))。 Flash Builder 将会自动为您创建一个运行配置。
5. 对于 Target Platform(目标平台),请选中苹果 iOS。
6. 对于 Launch Method(运行方法),请选择 On Desktop(在桌面上)。
7. 选中一个用于仿真的 iOS 设备。
8. 点击运行(参见图 11)。 ![图 11. 应用程序运行在第四代 iPod 上的概念验证。](http://wwwimages.adobe.com/www.adobe.com/content/dam/Adobe/en/devnet/flex/articles/mobile-skinning-part3/fig11.jpg " 图 11. 应用程序运行在第四代 iPod 上的概念验证。")
** 图 11.** 应用程序运行在第四代 iPod 上的概念验证。
为了将该项目打包并部署在 iOS 设备上,用户需要设置一个苹果开发者账户。 更多信息,请阅读 Andrew Shorten's 的文章 [Using Flash Builder 4.5 to package applications for Apple iOS devices\*](http://www.adobe.com/devnet/air/articles/packaging-air-apps-ios.html)。
要了解更多关于移动皮肤设置以及我所做过的概念验证工作,请访问我的博客文章 [Example: iOS Theme for Flex Mobile Projects\*](http://blogs.adobe.com/jasonsj/2011/06/ios-theme-for-flex-mobile-projects-proof-of-concept.html)。
## 下一步要做的事情
在您编译了移动应用程序以后,请考虑将其应用到哪一个特定于平台的模式当中。 随着智能手机以及 tablet 市场的持续发展以及多样化,AIR 和 Flex 将会为移动应用的开发提供强大的跨平台方法。更多关于使用 Adobe Flash 平台进行移动开发的内容,请访问 [The Mobile and Devices Developer Center\*](http://www.adobe.com/devnet/devices.html)。
[![Creative Commons Attribution-Noncommercial-Share Alike 3.0 Unported License](http://cookbooks.adobe.com/resources/images/license_creative_commons.png)](http://creativecommons.org/licenses/by-nc-sa/3.0/)+[![Adobe Commercial Rights](http://cookbooks.adobe.com/resources/images/license_adobe.jpg)](http://www.adobe.com/communities/guidelines/ccplus/commercialcode_plus_permission.html)
本文遵守 [知识共享—署名 - 非商业性使用 - 相同方式共享 3.0 Unported License (Creative Commons Attribution-Noncommercial-Share Alike 3.0 Unported License)](http://creativecommons.org/licenses/by-nc-sa/3.0/) 许可条件。 适合本文包含的代码范例、但超越本许可条件范围的其它许可条件能够在 [Adobe](http://www.adobe.com/communities/guidelines/ccplus/commercialcode_plus_permission.html) 中查到。
** 查看原文:**[Flex 移动 skin – 第 3 部分: 多平台开发](http://www.adobe.com/cn/devnet/flex/articles/mobile-skinning-part3.html)
2011-08-21 22:222327

评论

发布
暂无评论
发现更多内容

付费会员之我见(43/100)

hackstoic

商业模式

组件解析:基础组件button的实现

独来独往

大前端 低代码 可视化 组件化 低代码平台

GitHub标星139K的:“嵌入式Linux系统开发教程”

收到请回复

Java Linux 程序员 嵌入式 #运维

借我 1 小时,与 1000 人一起参与开源

腾源会

开源 腾源会

寻找海量数据集用于大数据开发实战(维基百科网站统计数据)

程序员欣宸

大数据 数据集 8月月更

Go-Excelize API源码阅读(十三)—— GetSheetVisible、SetSheetFormatPr

Regan Yue

Go 开源 源码解析 8月日更 8月月更

五分钟给你的 gRPC 服务加上 HTTP 接口

万俊峰Kevin

Go 微服务 gRPC web开发 go-zero

阿里云鲍文乐:基于事件的自动化运维最佳实践

阿里云弹性计算

事件 自动化运维 CloudOps

圣庭医疗联合创始人谷红仓:高通量基因测序在药物研发和靶向治疗中的应用

阿里云弹性计算

HPC 高性能计算 生命科学 基因测序

【React源码系列】React Context原理,为什么我建议尽可能少的使用React Redux管理状态 审核中

爱切图的木子老师

react源码 react context react redux

【LeetCode】课程表Java题解

Albert

LeetCode 8月月更

迄今为止最完整的DDD实践

阿里技术

DDD 经验分享

什么是文件存储?与对象存储有什么区别?

wljslmz

文件存储 8月月更

AntDB基于WAL日志的DML数据闪回实现

亚信AntDB数据库

AntDB 国产数据库 AISWare AIDB

Promise.allSettled 的 Polyfill 处理

汪子熙

JavaScript Promise Async 8月月更 web编程

少儿编程是智商税吗?不花钱让孩子赢在起跑线!

博文视点Broadview

云原生(二十) | 深入了解Kubernetes(k8s)Service

Lansonli

云原生 k8s 8月月更

悟了,应该都了解分布式架构下负载均衡器吧

知识浅谈

负载均衡 8月月更

直播商城系统——直播和电商的合理有效结合

开源直播系统源码

软件开发 直播系统源码 直播带货系统 直播商城系统 直播app系统

基于CC2530(ZigBee)设计的景观照明控制系统+配套手机APP

DS小龙哥

8月月更

腾讯发布第二季度财报,腾讯云数据库收入同比增长超过30%

科技热闻

CSS

武师叔

8月月更

计算机网络(二、物理层)

计算机网络 8月月更

Web登录很简单?开玩笑!

TimeFriends

8月月更

预约直播 | 基于预训练模型的自然语言处理及EasyNLP算法框架

阿里云大数据AI技术

深度学习 阿里云 算法框架

开源一夏 | 使用 JavaScript 将文本转换为文件

海拥(haiyong.site)

JavaScript GitHub 开源 前端 8月月更

我做了个《联机桌游合集: UNO+斗地主+五子棋》无需下载,点开即玩!叫上朋友,即刻开局!不看广告,不做任务,享受「纯粹」的游戏!

HullQin

CSS JavaScript html 前端 8月月更

低代码实现探索(四十八)后端服务

零道云-混合式低代码平台

3 分钟温故知新 RxJS 【创建实例操作符】

掘金安东尼

前端 函数式编程 8月月更

应用缺少POI数据,如何开发地点深度信息?

HarmonyOS SDK

设备管理|风机的日常运行与维护

PreMaint

企业设备管理 预测性维护 设备健康管理 风机的日常运维

Flex移动skin–第3部分:多平台开发_Java_Jason San Jose_InfoQ精选文章