1. 集成Adobe Catalyst
Flex 4的一个主要特性就是提供了对Adobe Catalyst(Adobe新的设计工具,用于创建富Internet应用而无需编写代码)集成的支持。Catalyst改变了开发者与设计者协作的方式,因为它清楚地知道应用开发者与设计者之间工作方式的显著差异。这样开发者与设计者都能专注于自己所擅长的领域,凭借Catalyst,无论开发者还是设计者都能按照自己所习惯的方式进行工作。Flex 4中的很多变化都是围绕着Flex与Catalyst的集成进行的。请查看Adobe Catalyst站点以了解其详细信息。
2. Spark组件架构
Flex的每个版本都包含了完整的组件库,其中含有用于构建应用的通用组件,如数据表格、按钮及布局容器等等。Flex 4的底层组件架构名为Spark,而在Flex 3中则叫做Halo。为了支持Catalyst,Flex 4更新了底层的组件模型以达到松耦合的目的。
在新的Spark组件模型中,核心逻辑、皮肤以及布局都被分开了,这样我们就能单独处理其中任意一部分而又不会影响到其他部分。Spark组件模型构建于 Halo组件模型之上,这意味着Spark扩展了Halo的核心基类UIComponent,这样我们就能以增量的方式使用Flex 4,同时还能将Flex 3组件应用在Flex 4应用中。
除此以外,Flex 4还对效果(effect)进行了增强。现在可以将效果应用在任意的对象和类型上,这么做提升了其灵活性。Flex 4的效果由新的“spark.effects”包实现。就像新的组件库一样,Flex 4的效果也被重新实现了,但却并没有对Flex 3的效果进行任何变更,这么做的目的是为了保持向后兼容。请查看Chet Haase所写的关于Flex 4效果的文章或是其博客以更多地了解Gumbo Effect。
请阅读白皮书以更多地了解Spark架构。
3. MXML 2009
MXML基于XML,构建于Flash Player所用的编程语言——ActionScript 3之上。MXML用于对用户界面和支持工具(比如说IDE,现在是Catalyst了)的视图区域进行布局。MXML 2009包含了大量更新以对不同的行为(核心、皮肤和布局)进行解耦,同时还提供了新的组件库。现在Flex 4的组件在其自己的包中(spark.components)得以实现,同时又没有对Flex 3的组件进行任何变更,为此MXML 2009专门提供了一个新的命名空间以提供支持。
下面的应用声明示例展示了如何使用该命名空间以及如何为Spark和Halo组件定义命名空间:
<s:Application
xmlns:fx=" http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark"
xmlns:mx="library://ns.adobe.com/flex/halo">
这样,我们就可以通过下面的代码声明Flex 4的Button:
<s:Button label="My Flex 4 Button" />
下面的代码声明了Flex 3的Button:
<mx:Button label="My Flex 3 Button" />
请浏览MXML 2009规范以深入了解其变化。
4. 对View States的改进
Flex 2将状态(states)概念引入到了Flex框架中,这样我们就可以通过简单的状态改变来管理视图组件的变化。Flex 4改进了视图状态(view states)以简化其语法,这样我们就能更轻松地使用他们了。新语言属性includeIn和excludeFrom就是简化语法的一个例子,我们可以设定组件的这两个属性值以响应状态变化(参见下面的代码示例)。
<!-- Given the states A,B,C -->
<m:states>
<m:State name="A"/>
<m:State name="B"/>
<m:State name="C"/>
</m:states>
<!-- This button will appear in only states A and B -->
<Button label="Click Me" includeIn="A, B"/>
<!-- This button will appear in states A and B -->
<Button label="Button C" excludeFrom="C"/>
请点击这里以进一步了解View States的变化。
5. FXG支持
Flash Player的核心是个绘图引擎。Adobe在Flash Player 10中引入了FXG,现在又将其引入到了Flex中。FXG是个声明式的图形格式,可以在工具间传递内容,这意味着设计者可以在Catalyst或CS4 Illustrator中创建内容,接下来Flex应用开发者就可以将其导入并使用而无需修改任何内容。
请阅读FXG规范以了解更多细节信息。
6. 皮肤增强
Spark组件模型最大的变化在于对皮肤的颠覆性改造,现在皮肤可以控制组件的所有可视化部分,同时还将逻辑封装到了组件核心之外。这样我们就可以对组件的可视化部分进行独立修改而不会影响到底层的核心逻辑。
来看看PanelSkin.mxml皮肤文件吧,Panel容器的默认皮肤代码如下:
<?xml version="1.0" encoding="utf-8"?>
<s:SparkSkin xmlns:fx=" http://ns.adobe.com/mxml/2009" xmlns:s="library://ns.adobe.com/flex/spark" alpha.disabled="0.5">
<fx:Metadata>
<![CDATA[
/**
* @copy spark.skins.default.ApplicationSkin#hostComponent
*/
[HostComponent("spark.components.Panel")]
]]>
</fx:Metadata>
<fx:Script>
/* Define the skin elements that should not be colorized.
For panel, border and title backround are skinned, but the content area and title text are not. */
static private const exclusions:Array = ["background", "titleField", "contentGroup"];
/**
* @copy spark.skins.SparkSkin#colorizeExclusions
*/
override public function get colorizeExclusions():Array {return exclusions;}
/* Define the content fill items that should be colored by the "contentBackgroundColor" style. */
static private const contentFill:Array = ["bgFill"];
/**
* @inheritDoc
*/
override public function get contentItems():Array {return contentFill};
</fx:Script>
<s:states>
<s:State name="normal" />
<s:State name="disabled" />
</s:states>
. . . . .
<s:Rect left="1" right="1" top="31" height="1">
<s:fill>
<s:SolidColor color="0xC0C0C0" />
</s:fill>
</s:Rect>
<!-- layer 5: text -->
<!-- Defines the appearance of the PanelSkin class's title bar. -->
<s:SimpleText id="titleField" lineBreak="explicit"
left="10" right="4" top="2" height="30"
verticalAlign="middle" fontWeight="bold">
</s:SimpleText>
<s:Group id="contentGroup" left="1" right="1" top="32" bottom="1">
</s:Group>
</s:SparkSkin>
由于该皮肤文件唯一的作用就是控制Panel容器的可视化外观,因此设计者可以修改组件的样式而无需编辑其源代码,也不必了解组件的内部行为。更为重要的是,设计者可以按照自己熟悉的方式来使用Catalyst。
请点击这里深入了解Gumbo的皮肤组件。
7. 更新的布局组件
熟悉Flex开发的人可能会注意到Flex 3中的大多数容器都已经不在Gumbo组件库中了。这是由于布局已经被解耦了,现在我们需要通过代理(delegtion)来处理他们。因为大多数 Flex 3容器仅仅就是为了提供不同的布局样式(比如说用于水平布局的HBox,用于垂直布局的VBox等等),因此现在他们已经没什么用了。
下面的示例表明Flex开发者现在也可以定义布局了。该示例利用Group类来管理按钮,Group是个新的Spark类,用于管理其中的内容条目。布局的结果就是两个并排放置的按钮,就像是使用Flex 3中的HBox的结果一样。
<s:Group width="400" height="400">
<s:layout>
<s:HorizontalLayout paddingLeft="5" paddingTop="5" />
</s:layout>
<s:Button label="Button 1" />
<s:Button label="Button 2" />
</s:Group>
来自Adobe的Ryan Stewart对新的布局机制进行了深入分析。
8. Flash Builder 4
Flash Builder 4(之前叫做Flex Builder)是面向应用开发者的最新的Eclipse IDE。该新版本带有众多更新,包括条件调试断点、更多的重构工具并支持FlexUnit 4。一如往常,它还包括MXML、ActionScript 3、可视化设计器以及Flex性能与内存分析器(只有专业版才有该性能分析器)。
除此之外,该最新版还提供了高级的数据管理特性以简化数据为中心应用的开发。这包括客户端的数据管理特性,它可以处理CRUD操作以及在大集合中进行滚动。
请点击这里来深入了解该IDE。
9. 编译器性能
几乎每个Flex 3开发者心中都有一个痛——糟糕的编译器性能。基于此,Gumbo的一个主要目标就是改进Flex 4中的编译器性能。虽然官方尚未发布性能基准,但来自Adobe的Peter Donovan根据自己所作的一些试验对其进行了测试,结果表明新的编译器性能提升了25%。他说要想将性能提升3到4倍只能进行重新设计。当然了,每个企业级Flex应用的开发者都希望今年底Flex 4正式发布时能实现这一点。
请阅读Peter Donovan的文章来深入了解相关信息。
10. 新的文本功能
Flash应用(无论是Flex还是非Flex应用)的一个主要议题就是高效处理文本的能力。在Flash Player 10中,Adobe引入了全新的文本引擎以支持RIA的需要(多语言、打印以及键盘快捷键等等)。Gumbo引入了大量新的文本类(RichText、 SimpleText等等)以在Flex框架中提供更健壮的文本支持。除此以外,Adobe正在全力开发新的Text Layout Framework以赋予ActionScript 3开发者利用Flash Player文本引擎的能力。请点击这里以深入了解Text Layout Framework。
如你所见,Flex 4代表了该流行的RIA平台的巨大进步。请查看Matt Chotin的文章《What's new in Flex 4 SDK beta》来深入了解Flex 4 SDK的变化。
分享到:
相关推荐
Flex4与Flex3之间的主要区别在于其引入的新组件和外观架构——Spark,以及在布局管理、状态使用、效果实现等方面的改进。虽然从Flex3迁移到Flex4需要一些调整,但总体来说,Flex4提供了一系列增强功能,旨在提高开发...
本文旨在详细介绍Flex3与Flex4之间的主要区别,特别是Flex4相较于Flex3的新功能与改进之处。通过对比分析,帮助开发者更好地理解两者之间的差异,从而根据项目需求选择最适合的技术栈。 #### 二、功能区别 ##### 1...
这个"Flex3样式设计工具4in1.rar"是一个压缩包,包含了多个与Flex3样式设计相关的工具和资源,帮助开发者更有效地管理及定制应用的外观。 1. **Flex3 Component Explorer**:这是一个组件浏览器,允许开发者查看和...
flex3 4 注册机 flex3 4 注册机 flex3 4 注册机 flex3 4 注册机 flex3 4 注册机 flex3 4 注册机 flex3 4 注册机 flex3 4 注册机 flex3 4 注册机
Flex3 可以与 Java 后台进行通信,并与 FusionCharts 结合使用,实现数据可视化。下面是 Flex3 的详细介绍: 一、Flex 简介 Flex 是一个高效、免费的开源框架,用于构建具有表现力的 Web 应用程序。这些应用程序...
Flex3虽然现在已被Flex4、Flex SDK 4.x和Adobe Animate CC等更新版本取代,但其基本原理和技术在现代RIA开发中仍然具有参考价值,特别是对于理解Flex框架的演进历程和ActionScript 3.0编程有重要的历史意义。...
7. **Services和Remoting**:Flex4支持与各种后端服务进行通信,包括AMF(Action Message Format)、SOAP、REST等,开发者可以方便地集成XML、JSON或自定义数据格式,实现数据的交换和处理。 8. **图形和动画**:...
总的来说,Flex4与Java的结合使得开发者可以充分利用两者的优点,创建出既美观又功能强大的Web应用。对于初学者,理解这两个平台的交互机制,熟练掌握AMF通信或RESTful服务的使用,将是迈进RIA开发领域的重要一步。...
本书将带领读者深入学习Flex 4的构建环境Flash Builder,讲解如何创建项目、编写ActionScript代码、设计用户界面以及与服务器端数据交互。书中涵盖的主题可能包括MXML和ActionScript的混合编程、使用数据服务、图形...
为了满足生成详细知识点的要求,我们将从Flex3软件的基本介绍入手,探讨其注册码的相关概念与获取途径,以及在使用此类软件时可能遇到的问题及解决方案。 ### Flex3简介 Flex3是一款由Adobe公司开发的开源框架,...
Flex3开发指南 flex3基础教程
4. **布局管理器**:Flex3支持各种布局管理器,如垂直布局、水平布局、网格布局等,方便开发者调整组件在容器中的位置和大小。 二、Flex3游戏开发 1. **游戏架构**:在Flex3中开发游戏,通常需要理解游戏循环、...
Flex 3和Flex 4是两个重要的版本,它们在生命周期管理上有显著的区别,对于开发者来说理解这一概念至关重要。这篇博客文章可能详细解析了Flex 3和4在组件生命周期上的差异。 首先,让我们了解一下Flex组件生命周期...
1. **Spark和MX组件**:Flex3有两种组件集,MX组件是早期的,而Spark组件在Flex4引入,提供更好的性能和设计灵活性。在Flex3中,两种组件可以混用。 2. **绘图API**:通过Graphics API,开发者可以直接在舞台上绘制...
#### 一、Flex 3 概念与特性 - **Flex**:由Adobe Systems开发的一种开源框架,用于构建跨浏览器和跨平台的RIA(Rich Internet Applications)应用程序。 - **Flex 3**:Flex 3作为Flex系列中的一个重要版本,提供...
这个"flex4.5.1.chm"文件是一个完整的Flex 4 API文档,它是开发人员的重要参考资料,包含了大量的类库、函数、事件和接口的详细说明。 1. **Flex SDK**:Flex Software Development Kit (SDK) 是一个免费的开放源...
Flex3学习指南是一份专为初学者设计的资源,旨在帮助他们掌握Adobe Flex 3这一强大的富互联网应用程序(RIA)开发框架。Flex 3在Web应用开发领域具有广泛的影响力,尤其在创建交互式、图形丰富的用户界面方面表现...
Flex4与Java通信是开发富互联网应用程序(RIA)时的一项重要技术,允许前端用户界面与后端业务逻辑之间进行高效的数据交换。在本实例中,我们探讨了三种Flex4与Java交互的方式:通过RemoteObject、HTTPService以及...
4. **调整目录结构**:可能需要修改Flex的源码目录和库目录名称,以避免与Java源码目录冲突。 5. **处理集成后的错误**:更改目录结构后,可能需要更新配置文件,例如调整编译路径和类路径,以解决新的错误。 6. **...
目录: 第1篇 基础知识篇 第1章 走进Flex世界 第2章 Flex基础知识 第3章 语言基础 第4章 数据基础 第5章 Flex事件驱动 第2篇 视觉设计篇 第6章 Flex皮肤设计 ... 第21章 Flex与Java EE通信