`
bzhang
  • 浏览: 256445 次
  • 性别: Icon_minigender_1
  • 来自: 大连
社区版块
存档分类
最新评论

使用Flash,Flex Builder和AS3创建自适应的用户界

    博客分类:
  • FLEX
阅读更多

一、概述
1.1 关于作者
James O’Reilly,Adobe认证专家,SynergyMedia公司(一家位于纽约的Flash咨询和培训公司)的首席技术官(CTO)。他的Blog(jamesor.com)中收集了许多他本人关于Flash和Flex开发的经验和思考。

随着用户体验需求的提高,越来越多的开发者在思考和探索如何在web中实现如同桌面应用那样丰富体验的方法。而本文正是关于这方面的内容,它将要告诉你如何创建动态的、自动根据屏幕范围调整显示大小的图形用户界面。

众所周知,液体(liquid)是一个分子的集合体,这些分子互相自由的运动并且紧密结合不分离。而在web开发中,“自适应页面”就如同 “liquid”一样,自适应页面中的内容将自动而独立的调整大小来适应不同的web浏览器窗口的或者其他给定的宽度,而让整个页面看起来就想专门为这个 大小而设计的一样。这和“定宽页面”形成很鲜明的对比。所谓“定宽页面”,是指按照特定的宽度来设计的页面,多出来的地方则直接用空白或其他背景填充。如 今,自适应页面在很多地方已经渐渐地被定宽页面所代替。

不管自适应页面的前途如何,很多用户依旧希望自己所使用的桌面应用具有一个能够自适应的界面,这让能使应用程序界面看起来更人性化。当你打开一个应用程序并改变它的大小,你希望看到所有的图形化界面的内容能自动排列来适应新的大小,而不是出现空白或显示不完整。

为了表述得更清楚,图1显示了两个Gaim(一种及时通讯工具)的消息窗口的截图。你可以看到,无论如何改变Gaim的大小,界面都会自动的适应窗 口的大小。用户已经渐渐了习惯了桌面应用中的自适应大小功能。而目前,越来越多的桌面应用已经有了基于web的RIA(rich internet application 富网络应用)实现,因此,相信大部分用户都希望RIA能看起来和用起来如同桌面应用一样。
fig01.gif
图1,两种不同大小下的Gaim及时消息窗口
1.2 看看我们要做的东西
在 此教程中,我将通过Flash中Stage对象的一些特性,来创建一个自适应的应用界面。我将做一个简单的、传统的图片库作为列子,这个例子可以放在网页 上以供浏览查看。当然,将这个例子中将在一个新的浏览器窗口中探出来,可以令其看起来更象是一个桌面应用而不是网页的一部分。

这个图片库将包含三个部分:头部,主体和底部。头部部分将包含应用的名称和一些按钮,包括让用户改变背景的按钮,以及在“原始大小”和“最合适大小 ”之间切换的按钮。主体部分允许用户查看所选择的图片。底部部分包含一个有多张图片的队列提供给用户选择要查看的图片。总之,我们要做的东西,你肯定在曾 经在哪儿看见过的,或者你也许已经做过类似的东西。

fig02.jpg
图2,在改大小的窗口中的非拉伸界面

在图2中,图片库被设置成具有一个不可以拉的伸界面,在这个情况下,无论怎么拉伸窗口,应用程序的界面看起来都没有错误。如果不使用非拉伸界面而让 应用程序跟随显示窗口直接拉伸,在浏览器窗口被拉伸到一个和原始SWF文件的长宽比不一样的大小的时候,应用程序的界面看起来就是扭曲的,如图3所示。
fig03.jpg
图3,应用程序界面的大小和浏览器窗口一样的例子

这些情况会让用户感觉很不友好。如果应用程序使用如图2的不可拉伸界面,用户将无法把窗口拉得更大一些。假如用户的显示器有1600 x 1200或者更高的分辨率,而只能看到如此小的一个图片,是很令人郁闷的。同样,如果一个应用程序的界面一拉伸就变得扭曲和比例失衡,也同样难以给用户留 下好的印象。

看看图4,我们想要做的就是这样的。如同桌面应用一样,使用浏览器打开的应用程序可以自动的根据浏览器的大小而从新调整大小。用户会很乐意的使用这样的应用程序,并将其拉伸到最适合自己使用的大小。用户甚至可能忘记自己使用的是一个从浏览器中打开的应用程序。
fig04.jpg
图4,应用程序自适应浏览器窗口

1.3 读者需求
如果需要测试本教程中的例子,你需要下面的软件和文件:

Flash Professional 9 ActionScript 3.0 Preview
http://labs.adobe.com/technologies/flash9as3preview/

Flex Builder 2
http://www.adobe.com/go/devcenter_flex_try

例子文件
liquid_gui_source.zip (ZIP, 60 KB)
http://download.macromedia.com/pub/developer/liquid_gui_source.zip

知识准备:
需要了解AS3和熟悉AS3语法

二、准备开始
用Flash创建自适应的GUI有4个基本的方面。在本文中,我将创建一个拥有自适应界面的例子程序来详细的介绍这4个基本方面的内容:

1,确定应用程序的界面划分,确定如何调整其大小;
2,将HTML页面设置为100%显示内容;
3,将Flash影片设置为不可以自己改变大小;
4,添加内容让应用程序可以自己什么时候需要改变大小以及如何改变大小。

2.1 确定应用程序的界面划分
我要做的图片库有三个很区分很明确的划分。三个部分的调整大小的方式也都各自不相同。头部和底部只在横向上有大小的调整,而主体部分在横向和纵向上都将会有调整。从布局上来说,只有底部是一直锁定在窗口在最下面,而头部和主体部分都有固定的x坐标和y坐标。

头部可以分成3个小部分:标题,一组按钮和背景图片。背景图片将通过改变宽度来适应窗口的大小,而标题和按钮部分,在改变大小的时候不会受到任何影响。

主体部分可以分成两个部分:一个空的影片剪辑(MovieClip,以下简称MC)用来加载和显示图片,和一个背景填充。背景填充部分需要自动的修 改长和宽来适应窗口。图片容器MC需要通过一些计算将图片居中的显示出来,并根据用户的设置,将图片显示为原始大小或者最合适的大小。

最后,底部也是由两部分组成:一组缩略图和背景填充。背景填充通过改变宽度来适应窗口的宽度,而缩略图组是不受大小调整的影响的。实际上,很多正式 的软件中的缩略图组中,可能有非常多的缩略图,而需要一些按钮或者滚动条来帮助用户可以滚动浏览,不过这个和我们今天要讲的内容没有大的关系,这里就不考 虑照样的情况了

2.2 在HTML页面中将应用程序的显示设置为100%
自适应的界面中很重要的一点,使需要应用程序能够100%的填满浏览器窗口的高度和宽度。

为了让应用程序完全填满浏览器窗口,窗口页面的margin属性必须设置为0,margin的默认值是10,如果没有将其设置为0,应用程序的周边将有10象素的空白。在镶嵌应用程序的页面中加入下面的代码:

body, html {margin:0;}

要让SWF填充整个浏览器窗口的方法非常简单,只用在SWF的发布设置中稍微修改一下即可。

在Flash9预览版中打开FLA文件,选择“文件 ->发布设置”。确保HTML(.html)的复选框是选中的。然后点击HTML标签。在尺度下拉菜单重选择“百分比”,然后输入宽度和高度都为100。这样,SWF将在浏览器窗口中满屏填充。

下面的两个发布属性可以通过修改Object和embed标签的属性来修改,不过在发布设置面板中的HTML标签中,也可以设置:

1,从缩放弹出菜单中选择“不缩放”;
2,在影片对齐选项中,水平方向选择左,垂直方向上选择顶部。

一般来说,我更喜在影片中使用AS来设定这两个参数,这样在Flash编辑环境下的测试中,就可以让播放器使用这两个属性来达到最需要的效果。

2.3 将Flash影片设置为不要自动改变内容的大小
要使用AS代码来设置上面说的到两个属性,可以通过设置Stage对象的两个属性来实现:

  1. Stage .scaleMode = “noScale” ;
  2. Stage .align = “TL” ;

scaleMode属性表示不自动拉伸flash影片,而align属性设置为TL表示影片以左上角为对齐点(top and left)。

2.4 如何让应用程序知道什么时候需要调整大小
使用AS代码来禁止SWF文件自动调整大小的目的是要所有的大小按照我们自己的需要来调整。

本文下面的部分将具体的讲述怎么来创建这个图片库,并将分成四个版本来制作。每个版本将比其前一个版本更复杂和完善。

版本1,创建一个基本的框架来监听窗口的调整大小事件;
版本2,创建继承MovieClip类的用户界面,处理调整大小时间并将其放在一个图形界面容器中;
版本3,通过实现自定义的IResizable接口来实现多态的调整大小;
版本4,图片库的其他一些特性和实现方式。

三、打基础
在这一部分,我们将通过两个方式来编写这个应用程序。第一种方法是通过Flash9预览版开发,可以做到尽量的简单。随后,将通 过AS3编程,在Flash9预览版和Flex Builder2里面实现更复杂的功能。我将用Flash来制作资源库,用Flex builder来编写代码和编译SWF文件。

版本1

打开Flash9预览版,在舞台上创建三个MC,分别用来包含三个部分:顶部,主体和底部。将三个MC放在不同的层里面,顶部在最上,底部第二层, 主体在最下。将主体部分放在最下面的原因是,如果加载的图片大小超过了主体部分能显示的范围,将会被顶部和底部遮住。分别将MC的实例名称命名为 “header_mc”“body_mc”“footer_mc”。

在时间轴上,加入下面的代码:

  1. import flash.display .StageScaleMode ;
  2. import flash.display .StageAlign ;
  3. import flash.events .Event ;
  4.  
  5. stage .scaleMode = StageScaleMode.NO_SCALE ;
  6. stage .align = StageAlign.TOP_LEFT ;
  7. stage .addEventListener ( Event.RESIZE , resizeHandler) ;
  8.  
  9. // 初始化调整大小事件
  10. resizeHandler ( null ) ;
  11.  
  12. function resizeHandler ( event:Event) :void
  13.  
  14. {
  15. var sw:Number = stage .stageWidth ;
  16. var sh:Number = stage .stageHeight ;
  17. header_mc.width = body_mc.width = footer_mc.width = sw;
  18. body_mc.height = sh-header_mc.height -footer_mc.height ;
  19. footer_mc.y = sh-footer_mc.height ;
  20. }

上面的代码实现了下面几个内容:首先,通过代码将SWF设置成不可以自动随浏览器窗口改变大小。其次,将作坐标点的原点设置为左上角。然后,创建了一个监听器,当舞台的大小发生改变的时候触发事件。在用户改变窗口大小的时候,Resize事件将会被触发多次。

版本2

现在,我们已经有了一个最简单的版本。下面我们将使用Flex Builder2来将其中引入更多的和更复杂的功能。除了是用flex builder2的actionscript工程构造以外,版本2和版本1没有其他的区别。

在Flex Builder中,选择File -> New -> ActionScript Project。在对话框中,输入工程名称LiquidGUI_v2并选择使用默认的路径。Flex Builder将自动的创建HTML模板用来测试,因此你不需要担心和考虑HTML设置的问题。

然后,将版本1中的FLA文件重命名蔚library.fla,并将其放置于LiquidGUI_v2工程路径下的assets文件夹内。在 Flash中打开此FLA文件,并将舞台上所有的原件和你创建出来的层删除掉。在库中,将3个部分的MC的连接类名称分别改为 HeaderBG,BodyBG和FooterBG。在Flash9预览版中,将不再使用连接标识符(linkage identifier),而是使用了连接类(linkage class)。

现在,这个FLA文件的库中应该有3个MC,而舞台上没有任何东西。使用Flash9预览版的ActionScript3.0将此FLA文件发布为SWF文件,并将此SWF文件保存中assets文件夹内。
fig05.jpg
图5,Flash9的发布设置中AS3编译设置

应用程序的主类文件已经被创建名为LiquidGUI_v2.as。此类将继承Sprite类。在Flex Builder中打开此文件并用下面的代码代替:

  1. package
  2. {
  3. import flash.display .Sprite ;
  4. import flash.display .StageAlign ;
  5. import flash.display .StageScaleMode ;
  6. import flash.events .Event ;
  7. //
  8. public class LiquidGUI_v2 extends Sprite
  9. {
  10. public static var ow:Number = 550 // 初始舞台高度
  11. public static var oh:Number = 400 // 初始舞台宽度
  12. public static var hh:Number = 54 ;   // 顶部高度
  13. public static var fh:Number = 75 ;   // 底部高度
  14. public static var hfh:Number = 129 ; // 顶部和底部的高度
  15. // 顶部代码
  16. [ Embed( source=“assets/library.swf” , symbol=“HeaderBG” ) ]
  17. private var HeaderBG:Class ;
  18. private var _header:Sprite;
  19. // 主体部分代码
  20. [ Embed( source=“assets/library.swf” , symbol=“BodyBG” ) ]
  21. private var BodyBG:Class ;
  22. private var _body:Sprite;
  23. // 底部代码
  24. [ Embed( source=“assets/library.swf” , symbol=“FooterBG” ) ]
  25. private var FooterBG:Class ;
  26. private var _footer:Sprite;
  27. /**
  28. * 构造器
  29. */
  30. public function LiquidGUI_v2 ( )
  31. {
  32. // 让播放器不要自动拉伸
  33. stage .scaleMode = StageScaleMode.NO_SCALE ;
  34. // 让播放器将左上角作为舞台的坐标原点
  35. stage .align = StageAlign.TOP_LEFT ;
  36. // 设置改变大小事件的监听器
  37. stage .addEventListener ( Event.RESIZE , onResize ) ;
  38. // 创建主体部分并将其添加到显示列表中
  39. _body = new BodyBG ( ) ;
  40. addChild ( _body) ;
  41. // 创建底部并将其添加到显示列表中
  42. _footer = new FooterBG ( ) ;
  43. addChild ( _footer) ;
  44. // 创建顶部并将其添加到显示列表中
  45. _header = new HeaderBG ( ) ;
  46. addChild ( _header) ;
  47. // 设置位置
  48. _body.y = _header.height ;
  49. // 初始化位置设置
  50. onResize ( null ) ;
  51. }
  52. /**
  53. * onResize
  54. * 大小改变的监听器的事件处理器。
  55. * @param   event
  56. */
  57. public function onResize ( event:Event) :void
  58. {
  59. // 获取新的舞台大小
  60. var sw:Number = stage .stageWidth ;
  61. var sh:Number = stage .stageHeight ;
  62. // 将各部分的大小调整到新的值
  63. _header.width = _body.width = _footer.width = sw;
  64. _body.height = sh-hfh;
  65. _footer.y = sh-fh;
  66. }
  67. }
  68. }

大部分的代码和版本1中的代码是差不多的。LiguidGUI_v2.as类既是主类,也是应用程序的入口。

在这个类中,我定义了一些全局变量,这些变量在应用程序的整个生存周期中都一直有效并不会被改变。因此我将其定义成静态变量以便调用。

接下来的代码是将一个外部的SWF文件作为扩展的库文件直接导入到当前的应用程序中来:

  1. [ Embed( source=“assets/library.swf” , symbol=“FooterBG” ) ]

上    面的代码申明了在当前的应用程序中使用什么符号来引用需要嵌入的SWF文件。在申明了嵌入符号后,需要将此符号名称定义成一个类,如下:

  1. private var FooterBG:Class ;

在此应用程序中,一旦FooterBG被定义成了一个类,你可以使用new关键字来实例化这个类。在我的例子中不打算使用时间轴,因此我将这里的对象类型定义为Sprite,如下:

  1. private var _footer:Sprite;

_footer = new FooterBG ();

在创建了FooterBG类的实例后,必须将其加入到显示队列中才能显示出来。因此这里需要用到Sprite的addChild()方法:

  1. addChild ( _footer) ;

最终,实现一个onResize方法来作为事件对象的处理器。

四、快完成了
前两个版本都是基本内容的实现。现在需要创建调整大小事件的处理器。

版本3

在版本3中,我将要创建一个名为LiquidGUI_v3的新工程,不过你也可以直接在版本2的项目上继续做。在本版3中,我将减少主类中的功能, 因为主类实际上并不需要知道如何去调整每个部分的大小。主类的功能是计算和设置每个部分的位置并将告诉每个部分其应该的大小,然后由每个部分自己来调整显 示大小。因此,主类中在调整大小时处理的,仅仅是_footer的y坐标。而其他的部分,只要设置好了就不用再修改。

首先,创建一些文件夹来放置需要编写的类文件。这些文件夹的名字同类的包定义路径要吻合。关于AS3类的包定义,请查看其他相关手册。

我这里使用的包名称为com.jor。在com目录内创建一个名称为jor的目录,是“James O’Reilly”的简称。然后需要创建了一些不同的目录来放置不同的类。在这里,我创建了两个不同的目录:“controls”和 “examples”。在examples目录中,我创建了一个目录名称为“liquidgui”,然后在其中创建了一个目录名称为“ui”。目录结构如 下:

LiquidGUI_v3/
LiquidGUI_v3/assets/
LiquidGUI_v3/bin/
LiquidGUI_v3/com/jor/examples/liquidgui/ui
LiquidGUI_v3/bin/html-template/

然后,为三个不同的部分创建三个继承Sprite的类:

LiquidGUI_v3/com/jor/examples/liquidgui/ui/HeaderUI.as
LiquidGUI_v3/com/jor/examples/liquidgui/ui/BodyUI.as
LiquidGUI_v3/com/jor/examples/liquidgui/ui/FooterUI.as

每一个部分用一个独立的类来实现,而每个类需要在内部实现自己的调整大小的方法,因此需要在每个类中定义一个名称为setSize()方来,用来调 用以调整大小。现在,我创建一个接口,让每一个需要调整大小的类都来实现这个接口。我将这个接口命名为IResizable.as,然后写入下面的代码:

GeSHi Error: GeSHi could not find the language language (using path /www/users/tangbin.cn//wp-content/plugins/codesnippet/lib/geshi/) (code 2)

创建接口比创建类要容易得多,因为接口中是没有代码的。关于AS3中接口的更多介绍,请查看相关手册。

每个部分的类中都需要实现这个接口。打开HeaderUI.as并加入下面的代码:

  1. package com.jor .examples .liquidgui .ui
  2. {
  3. import com.jor .examples .liquidgui .IResizable ;
  4. import flash.display .Sprite ;
  5. public class HeaderUI extends Sprite implements IResizable
  6. {
  7. public static var _instance:HeaderUI;
  8. private var _parent :Sprite;
  9. // 背景资源
  10. [ Embed( source=“/assets/library.swf” , symbol=“HeaderBG” ) ]
  11. private var HeaderBG:Class ;
  12. public var bg:Sprite;
  13. // 顶部资源
  14. [ Embed( source=“/assets/library.swf” , symbol=“HeaderTitle” ) ]
  15. private var HeaderTitle:Class ;
  16. public var title:Sprite;
  17. public function HeaderUI ( p:Sprite)
  18. {
  19. _parent = p;
  20. // 创建并添加背景到显示队列
  21. bg = new HeaderBG ( ) ;
  22. addChild ( bg) ;
  23. // 创建并添加顶部到显示队列
  24. title = new HeaderTitle ( ) ;
  25. addChild ( title) ;
  26. title.x = 23 ;
  27. }
  28. public static function getInstance ( p:Sprite) :HeaderUI
  29. {
  30. if ( _instance == null )
  31. _instance = new HeaderUI ( p) ;
  32. return _instance;
  33. }
  34. public function setSize ( w:Number , h:Number ) :void
  35. {
  36. bg.width = w;
  37. }
  38. }
  39. }

这是HeaderUI类的代码。在开始的几行中,你可以看到此类继承了Sprite类并实现了IResizable接口。后面的代码则显示界面和实现了setSize()方法。

另外两个类,BodyUI和FooterUI,类似的加入下面的代码:

  1. package com.jor .examples .liquidgui .ui
  2. {
  3. import com.jor .examples .liquidgui .IResizable ;
  4. import flash.display .Sprite ;
  5. public class BodyUI extends Sprite implements IResizable
  6. {
  7. public static var _instance:BodyUI;
  8. // 背景资源
  9. [ Embed( source=“/assets/library.swf” , symbol=“BodyBG” ) ]
  10. private var BodyBG:Class ;
  11. public var bg:Sprite;
  12. // 私有内容
  13. private var _parent :Sprite;
  14. public function BodyUI ( p:Sprite)
  15. {
  16. _parent = p;
  17. bg = new BodyBG ( ) ;
  18. addChild ( bg) ;
  19. }
  20. public static function getInstance ( p:Sprite) :BodyUI
  21. {
  22. if ( _instance == null )
  23. _instance = new BodyUI ( p) ;
  24. return _instance;
  25. }
  26. public function setSize( w:Number , h:Number ) :void
  27. {
  28. bg.width = w;
  29. bg.height = h;
  30. }
  31. }
  32. }
  33.  
  34. package com.jor .examples .liquidgui .ui
  35. {
  36. import com.jor .examples .liquidgui .IResizable ;
  37. import flash.display .Sprite ;
  38. public class FooterUI extends Sprite implements IResizable
  39. {
  40. public static var _instance:FooterUI;
  41. // UI对象的私有引用
  42. [ Embed( source=“/assets/library.swf” , symbol=“FooterBG” ) ]
  43. private var FooterBG:Class ;
  44. public var bg:Sprite;
  45. private var _parent :Sprite;
  46. public function FooterUI ( p:Sprite)
  47. {
  48. _parent = p;
  49. __configUI ( ) ;
  50. }
  51. private function __configUI ( ) :void
  52. {
  53. bg = new FooterBG ( ) ;
  54. addChild ( bg) ;
  55. }
  56. public static function getInstance ( p:Sprite) :FooterUI
  57. {
  58. if ( _instance == null )
  59. _instance = new FooterUI ( p) ;
  60. return _instance;
  61. }
  62. public function setSize ( w:Number , h:Number ) :void
  63. {
  64. bg.width = w;
  65. }
  66. }
  67. }

最后,你需要修改一下主类来使用上面写的这几个类。代码如下:

  1. package
  2. {
  3. import flash.display .Sprite ;
  4. import flash.display .StageAlign ;
  5. import flash.display .StageScaleMode ;
  6. import flash.events .Event ;
  7. import com.jor .examples .liquidgui .ui .BodyUI ;
  8. import com.jor .examples .liquidgui .ui .FooterUI ;
  9. import com.jor .examples .liquidgui .ui .HeaderUI ;
  10. public class LiquidGUI_v3 extends Sprite
  11. {
  12. public static var hh:Number = 54 ;    // 顶部的高度
  13. public static var fh:Number = 75 ;    // 底部的高度
  14. public static var hfh:Number = 129 // 顶部和底部高度之和
  15. private var _header:HeaderUI;
  16. private var _body:BodyUI;
  17. private var _footer:FooterUI;
  18. public function LiquidGUI_v3 ( )
  19. {
  20. // 不拉伸显示
  21. stage .
分享到:
评论

相关推荐

    Eclipse3.5集成Flex_Builder3或Flash_Builder4

    - 重新启动Eclipse,即可使用Flex3功能。 #### 四、注意事项 - 在安装Flex Builder 3插件时,确保关闭所有浏览器和其他与Flash相关的应用程序,避免冲突导致安装失败。 - 如果在安装过程中出现错误提示,检查日志...

    汉化 Flex Builder 3 帮助文档

    "汉化 Flex Builder 3 ...Flex Builder 3 帮助文档汉化是非常必要的,它可以帮助开发者更方便地使用 Flex Builder 3,提高开发效率。本文详细介绍了汉化 Flex Builder 3 帮助文档的步骤,希望能够帮助更多的开发者。

    flex builder 3 plugin part6

    Flex Builder 3是一款由Adobe公司推出的专门用于开发Flex应用程序的集成开发环境(IDE),它基于Eclipse平台,为创建富互联网应用(RIA)提供了强大的工具支持。本篇将重点介绍Flex Builder 3插件的第六部分,即在...

    FlexBuilder运行项目报Flex Builder cannot locate the required version of Flash Player

    标题 "FlexBuilder运行项目报Flex Builder cannot locate the required version of Flash Player" 描述了一个常见的问题,即在使用FlexBuilder开发Flex应用程序时,由于找不到合适的Flash Player版本,导致项目无法...

    Flex builder4.0注册码 Flex builder 3.0注册码 Flex builder4.0下载地址

    尽管Flex Builder 3.0相较于4.0版本而言,技术上可能略显陈旧,但对于部分用户而言,它依然具有使用价值,尤其是在某些特定项目中,3.0版本可能更加稳定或兼容性更好。因此,合法获取并使用其注册码同样是必要的。 ...

    Flex Builder 3序列号

    在探讨“Flex Builder 3序列号”的相关内容时,我们首先需要了解Flex Builder 3这款软件的基本情况及其在软件开发领域中的应用。 ### Flex Builder 3简介 Flex Builder 3是Adobe公司推出的一款专为开发Flex应用...

    Adobe Flex Builder 3.0官方使用教程

    第六章是关于如何使用MXML和CSS来设计和构建Flex用户界面。我们将介绍各种UI组件,如按钮、文本框、列表等,并讨论如何使用这些组件来创建直观且响应式的界面。 #### 七、添加视图状态(Chapter 7) 在第七章中,...

    FlexBuilder+3+中文教程

    通过这个中文教程,开发者将能够逐步掌握FlexBuilder 3的使用,熟练地创建和部署富互联网应用程序,同时也能深入理解Flex的开发理念和实践技巧。无论是初学者还是有一定基础的开发者,都能从中获益。

    FlexBuilder 3 中文教程.rar

    FlexBuilder 3是一款由Adobe公司推出的集成开发环境(IDE),专为构建富互联网应用程序(RIA)而设计,尤其是基于Adobe Flash Player和Adobe AIR的应用。这个IDE是基于Eclipse平台,提供了一整套工具来帮助开发者...

    flexbuilder3注册码,总之我试过没有问题

    对于需要构建复杂Web应用的开发者来说,结合使用FlexBuilder 3和LiveCycle Data Services能够极大地提高开发效率和应用性能。 ### 结语 使用正确的注册码对于保障软件的正常使用至关重要。在获取和使用注册码的...

    Flex Builder3的安装过程

    现在你可以开始创建和管理Flex项目,利用其丰富的代码编辑器、调试工具以及集成的Flash Player模拟器进行开发工作。 在压缩包中的"Flex安装过程"文件,可能包含了更详细的图文步骤和注意事项,对于初学者来说,这是...

    使用FlexBuilder3制作并导出AIR1.0正式版应用

    综上所述,这个主题涵盖了使用FlexBuilder3开发AIR 1.0应用程序的基本流程,包括从项目创建、代码编写、配置、测试到打包发布的关键步骤,同时也涉及到压缩包内文件的作用和结构。通过这样的实践,开发者可以创建...

    Flex Builder3正式版下载+注册码

    Flex Builder3,作为Adobe公司推出的专为Flex框架设计的集成开发环境(IDE),在Web应用程序开发领域占据了一席之地,尤其在Flash平台上的RIA(Rich Internet Applications)开发中发挥着举足轻重的作用。 ### Flex ...

    flex builder 4 help

    《Flex Builder 4 Help》这个英文文档是Flex Builder 4用户的重要参考资料,它详细阐述了如何使用该IDE进行Flex开发。下面,我们将深入探讨其中的关键知识点: 1. **Flex SDK和Flash Player**:Flex Builder 4基于...

    Adobe Flex Builder 3 注册码

    Flex Builder 3 支持多种语言,如 ActionScript 3.0,并且能够创建复杂的 Rich Internet Applications (RIA)。 #### 二、注册码的重要性 对于 Adobe Flex Builder 3 这样的专业软件来说,注册码是授权用户合法使用...

    配置Flex Builder 3.2来集成Flex 3.4 SDK

    [http://www.adobe.com/cfusion/entitlement/index.cfm?e=flex3sdk](http://www.adobe.com/cfusion/entitlement/index.cfm?e=flex3sdk) 下载完成后,解压文件到一个易于访问的位置,例如`D:\Program Files\Adobe\...

    flexbuilder3 的一个小实例

    在本实例中,我们将探讨如何使用FlexBuilder3来创建一个简单的"Hello, World!"程序,这通常是学习新开发工具的第一步。 首先,让我们了解FlexBuilder3的基础。它是一个集成开发环境(Integrated Development ...

    flex builder中文教程

    7. **图形和动画**:介绍如何在Flex应用中创建和控制动画,以及使用绘图API创建自定义图形。 8. **状态管理**:探讨如何使用状态管理来改变应用在不同条件下的外观和行为。 9. **调试和测试**:教授如何使用Flex ...

    FlexBuilder2帮助文档

    在压缩包中包含的五个FlexBuilder2文档可能是用户手册、编程指南、API参考、教程和示例代码等资源,这些文档对于深入理解和使用FlexBuilder2至关重要。以下是可能涵盖的一些关键知识点: 1. **FlexBuilder2界面**:...

Global site tag (gtag.js) - Google Analytics