`
wangleifire
  • 浏览: 509184 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

Flex 4的十大变化

    博客分类:
  • FLEX
阅读更多

Flex 4的十大变化

作者 Jon Rose 译者 张龙 发布于 2009年7月26日 下午10时31分

社区
Java
主题
RIA ,
Web 2.0 ,
富客户端/桌面
标签
Adobe ,
Adobe集成运行时/AIR ,
Flex ,
Flash

本周Adobe发布了Flex 4(Gumbo)的首个官方beta版。该版本包含了众多的变化。本文从较高层次审视了这个流行RIA框架的最新版,讨论了其所发生的主要变化。

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的变化。

作者简介

Jon Rose是Gorilla Logic, Inc. (位于科罗拉多州的博尔德)的一名企业软件咨询师和Flex业务主管。他还是知名的企业软件社区InfoQ.com的编辑。另外,他是DrunkOnSoftware.com 的主办人之一,这是一个面向那些爱豪饮的朋友的视频网站。他的客户有小公司,也有政府部门。爱解决难题的天性使其致力于开发高质量的软件。你可以通过其博客 了解他。

分享到:
评论

相关推荐

    flex4 实战 flex4 in action

    在Flex 4中,最重要的变化之一是组件模型的改变,引入了Spark组件架构,它与原有的MX组件架构并行存在,但更注重设计和性能。Spark组件库提供了一套全新的UI组件,这些组件基于Flex 4的皮肤ning机制,允许开发者创建...

    Flex 布局变化时的动画效果解析 简单版

    在Flex布局发生变化时,例如元素的增删、大小调整或排列顺序改变,我们可能希望添加动画效果来平滑过渡,提高用户体验。这篇博客“Flex布局变化时的动画效果解析 简单版”可能是作者对如何在Flex布局中实现动态变换...

    FLEX4_Flex4教程 - FLEX4从入门到精通,挺不错的值得一看

    5. **数据绑定**:Flex4的数据绑定功能使得UI元素可以直接与后台数据源关联,当数据源发生变化时,UI会自动更新,反之亦然。这对于实现响应式界面至关重要。 6. **Flex Builder/Flash Builder**:Adobe Flex ...

    Flex 4 高级编程 Flex 4 高级编程

    4. **骨骼动画(Skinning and States)**:Flex 4 强化了组件的皮肤机制,通过定义不同状态(如normal、hover、down等),可以实现组件在不同交互下的动态变化,增强了用户体验。 5. **数据绑定和依赖注入**:Flex ...

    Flex3与flex4的区别

    Flex4最显著的变化之一是引入了全新的组件和外观架构,称为Spark。这一架构不仅提高了性能,还增强了设计的灵活性。Spark组件被设计为更加模块化,允许开发者更容易地自定义组件的外观和行为。相比之下,Flex3中的...

    Flex4 一学就会 (Hello Flex4)

    Flex4,全称为Adobe Flex 4,是一款由Adobe公司开发的开源框架,主要用于构建富互联网应用程序(Rich Internet Applications,简称RIA)。Flex4以其强大的组件库、灵活的样式系统和优化的图形渲染引擎,极大地提升了...

    Flex4 经典帮助文档

    在Flex4中,最重要的变化之一是引入了Spark组件模型,它替代了原有的 Halo 组件模型。Spark组件模型提供了更现代、可自定义的设计,允许开发者创建更加美观且交互性更强的用户界面。Spark组件库包括了一系列基本和...

    flex4 学习全部资料

    Flex4是一种强大的富互联网应用程序(RIA)开发框架,由Adobe公司推出,主要用于构建交互性强、视觉效果丰富的Web应用。在本资源包中,你将找到关于Flex4学习的所有必要资料,包括安装指南、API文档、学习文档以及...

    Flex4实战代码

    Flex4,全称为Adobe Flex 4,是Adobe公司推出的一款用于构建富互联网应用程序(RIA)的框架,基于ActionScript 3.0编程语言和Flash Player或Adobe AIR运行时环境。这个压缩包文件包含了多个章节的实战代码,涵盖了...

    flex4 学习资料

    Flex4是一种基于ActionScript 3.0的开源框架,用于构建富互联网应用程序(RIA),它在Adobe Flex 3的基础上进行了重大升级,提供了更多的功能和性能优化。本学习资料集全面覆盖了Flex4的基础与进阶知识,是学习Flex4...

    Flex4开发实践PPT

    Flex4,全称为Adobe Flex 4,是Adobe公司推出的一款强大的富互联网应用程序(RIA)开发框架,主要用于构建具有丰富用户体验的Web应用。本PPT详细讲述了Flex4的开发实践,旨在帮助开发者从基础到实践全面掌握这一技术...

    flex4学习资料

    Flex4学习资料是一份关于Adobe Flex 4技术的资源集合,主要关注源码解析和工具应用。Flex 4是Adobe Flash Platform的一部分,用于构建富互联网应用程序(RIA)。它基于ActionScript 3.0编程语言和Flex框架,提供了一...

    flex 4 学习资料

    基于flex4技术从零开发flex博客系统 : 1 开发环境配置与hello world(1) - 豆豆网 flex+blazeDs与Ext+dwr比较_蓝色幻想_百度空间 基于blazeDS的flex4与spring的程序实例步骤 - dreamming_now的专栏 - CSDN博客 在...

    [Flash Builder 4 and Flex 4 Bible] Flex 4 宝典 配套代码

    Flex 4,也被称为Gumbo,是Adobe Flex框架的一个重大更新,它引入了许多新特性,提高了开发人员构建富互联网应用程序(RIAs)的效率。Flash Builder 4是用于开发Flex和ActionScript应用的主要集成开发环境(IDE),...

    Flex4学习文档

    Flex4是Adobe公司推出的一款用于构建丰富互联网应用程序(RIA)的开发工具。它允许开发者使用MXML(一种基于XML的标记语言)和ActionScript(一种基于ECMAScript的编程语言)来创建跨平台的交互式应用程序。Flex 4...

    Effortless Flex 4 Development

    《Effortless Flex 4 Development》是一本由Larry Ullman撰写的专注于Flex 4开发技术的书籍。这本书旨在帮助读者轻松地掌握Flex 4的开发技能,为那些希望深入理解并应用Flex 4进行应用程序设计与开发的读者提供了一...

    Flex4教程 FLEX4API

    FLEX4从入门到精通,挺不错的值得一看

    Flex3与Flex4对比

    ### Flex3与Flex4对比分析 #### 一、概述 随着技术的发展,Adobe Flex平台也在不断进化以满足日益增长的应用需求。本文旨在详细介绍Flex3与Flex4之间的主要区别,特别是Flex4相较于Flex3的新功能与改进之处。通过...

    flex4自定义组件皮肤

    Flex4是一种基于ActionScript3和Flash Player的开源框架,用于构建富互联网应用程序(RIA)。它提供了丰富的组件库,包括MX和Spark两个主要组件集。在Flex4中,自定义组件皮肤是提升应用视觉效果和用户体验的重要...

Global site tag (gtag.js) - Google Analytics