`
prec
  • 浏览: 65404 次
  • 性别: Icon_minigender_1
  • 来自: 互联网
最近访客 更多访客>>
社区版块
存档分类
最新评论

Flex编译CSS资源与国际化

阅读更多

1)      编译CSS资源

 

文件浏览器(Navigator)中,在标准的Flex CSS文件上点击右键,点击Compile CSS to SWF即可完成编译CSS的任务。

在程序中可以用StyleManager.loadStyleDeclarations()来读出已编译好的CSS文件中的内容。

具体操作如下:

              // 读取Style

                        private function loadStyle():void

              {

                              var eventDispatcher:IEventDispatcher = StyleManager.loadStyleDeclarations("xxx.swf");

                    eventDispatcher.addEventListener(StyleEvent.COMPLETE, completeHandler);

}

然后,

              // 读取完毕的处理

                        private function completeHandler(event:StyleEvent):void

                        {

                              // 具体的处理内容

                              ………………

                              super.initialized = true;

              }

做好了这两个函数后,在要调用的页面编辑它的preinitialize属性,指向loadStyle(),如:

<mx:Application xmlns:mx=http://www.adobe.com/2006/mxml layout="absolute" preinitialize="loadStyle()">

 

2)      编译locale文件

 

为了国际化的需要,我们需要使用locale文件或国际化相关技术。

最简单的方法是本地化编译,即编译不同的语言版本,然后使用Application Server来判定客户使用的是哪种语言,并自动指向对应的swf文件。

具体做法如下:

在项目上点击右键,选择Properties

                            然后选择Flex Compiler,在Additional Compiler arguments下面已经配置好语言包了,默认为-locale en_US

                            这时我们可以用一个locale目录来简单定制我们额外设置(当然不包括Flex内部控件的语言)的语言设置。

                            比如改为:-locale=en_US -source-path+=g:\flexproj\locale\{locale}。这样在g盘的flexproj目录下建立一个locale目录。

然后目录下放置包含我们要扩展的语言文件的文件夹就可以了。比如g:\flexproj\locale\en_US

注意:locale下面的目录名应该和-locale=设置的名称一致。

那么这样,我们就可以使用额外的语言设置了。

例:

Additional Compiler arguments配置为

-locale+=en_US -source-path+=g:\flexproj\testgoufang\locale\{locale}

然后在对应的locale目录下添加国际化资源文件,如图:

这一部分跟struts相似。

里面的内容为键=值的形式,如:

Title=测试项目

User=用户名

Password=密码

…………

…………

 

使用的时候可以通过[ResourceBundle]元数据标签来绑定locale文件,如:

<mx:Metadata>

                              [ResourceBundle("strings")]

</mx:Metadata>

即绑定上文提到的strings.properties文件,然后我们可以通过ResoueceManager来读出其中的内容,比如:

var Title : String = resourceManager.getString("strings", 'Title');

或者绑定到控件:

[Bindable]

private var Title:String;

…………

Title = resourceManager.getString("strings", 'Title');

…………

<mx:Label text="{Title}"/>

 

上面对针对国际化而使用locale文件的方式做了一个简单的介绍,不过问题还是很多,比如Flex控件的国际化,动态国际化用上面的方法都无法做到。也就是说如果我使用Flex的控件,就必须在程序中指定,或者额外挂在国际化的xxx. Properties文件来进行国际化,并且,只能静态编译多个版本,然后让Application Server根据不同的语言来定位不同版本的SWF文件来进行,这是很不方便的。其实Flex是可以做到的。

 

下面我们来看比较复杂的定制国际化方案:

 

首先,了解一些背景,Flex内部的国际化文件/库只支持两个版本,一个是en_US,另一个是ja_JP。也就是说,开发者在编译Flex项目的时候在Additional Compiler arguments下配置locale=zh_CN是一定会报错的。

原因是因为zh_CN库,Flex是没有提供的。

那么应该怎么办呢,答案是:自己来构建一个。

事实上,在Flexsdk中已经提供了所有国际化文本的源码,我们可以通过这些源码来进行核心的国际化功能。

我们可以在sdk的目录下找到对应的源码文件夹,如:

D:\Program Files\Adobe\Flex Builder 3\sdks\moxie\frameworks\projects\framework\bundles\en_US

这样我们可以根据这个原型的复制品来制作其他语言包。

比如,我们来制作一个中文语言包:

首先,先在bundles下创建en_US的副本,然后将副本更名为zh_CN,然后把zh_CN下面的具体内容翻译成中文。

sdk下输入

 

bin\compc -locale=zh_CN -source-path=frameworks/projects/framework/bundles/zh_CN/src -include-resource-bundles=collections,containers,controls,core,effects,formatters,logging,SharedResources,skins,states,styles,validators

-output=frameworks/locale/zh_CN/framework_rb.swc

 

则会将Flexcollections,containers,controls,core,effects,formatters,logging,SharedResources,skins,states,styles,validators模块的语言源文件编译成frameworks/locale/zh_CN/framework_rb.swc的语言库文件,这样,在Additional Compiler arguments下配置locale=zh_CN就不会报错了。

 

此外,语言文件也可以像CSS文件一样编译成SWF文件:

mxmlc -locale= zh_CN

-source-path=locale/{locale} -allow-source-path-overlap=true -include-resource-bundles=collections,containers,controls,core,effects,myResources,skins,styles -output=Resources_ zh_CN.swf

 

编译后的文件更小,效率会更高。

 

Flex中动态使用国际化

 

之前我们所讲都是通过Application Server跟据不同的语言来定位不用的SWF文件来实现国际化的。现在,我们来讲一下,如何在Flex中,动态指定国际化语言。

 

首先,我们应通过Additional Compiler argumentslocale选项来指定多个语言:

-locale=zh_CN,en_US我们也可以这样-locale+=zh_CN因为en_US为默认语言。

然后,我们可以在程序中指定语言顺序链

resourceManager.localeChain = [ "zh_CN", "en_US" ];

这样我们通过resourceManager.localeChain = [0];就可以选择zh_CN了。

在外部,我们可以通过html-template目录下对index.template.html进行修改,来达到动态更换语言的目的,当然,这也需要Application Server的支持,不过,不再是定位到不同的SWF文件了,比如下面的JS脚本:

 

AC_FL_RunContent(

                  "src", "${swf}",

                  "FlashVars", "localeChain=zh_CN",

                  "width", "${width}",

                  "height", "${height}",

                  "align", "middle",

                  "id", "${application}",

                  "quality", "high",

                  "bgcolor", "${bgcolor}",

                  "name", "${application}",

                  "allowScriptAccess","sameDomain",

                  "type", "application/x-shockwave-flash",

                  "pluginspage", "http://www.adobe.com/go/getflashplayer"

);

我们可以利用JSP或者ASP.NET动态替换红色的部分,来动态的更换语言

当然,我们也可以引用编译的文件,只需要把红色的部分改为:

 

"FlashVars", "resourceModuleURLs=Resources_zh_CN.swf&localeChain= zh_CN ",

 

这样就可以了。

 

分享到:
评论

相关推荐

    flex css skin

    3. **编译和运行**:将CSS文件包含在Flex项目的资源目录下,并重新编译项目。运行应用后,你应该能看到组件的外观已经根据CSS规则改变。 在提供的压缩包文件“FlashSkinForFlex”中,可能包含了一个演示项目,展示...

    Flex 编译参数选项

    Flex是一种开源的、基于ActionScript和MXML的框架,用于构建富互联网应用...由于未提供实际的文档内容,以上只是基于Flex编译参数的一般性解释。对于具体细节和示例,建议阅读原文档或访问提供的博客链接获取完整信息。

    flex——cssLoader

    CSSLoader可以与Flex的MXML组件一起使用,也可以与ActionScript组件结合。同时,它可以配合Flex的响应式设计,实现不同屏幕尺寸和设备的样式适配。 综上所述,Flex CSSLoader是Flex开发中的一个重要工具,它允许...

    flex css Aeon

    标题中的“flex css Aeon”可能是指一个使用Flex布局和CSS技术构建的项目,而“Aeon”可能是项目名称或者是特定的设计概念。在这个场景下,我们可以深入探讨Flex布局和CSS的相关知识。 1. **Flex布局(Flexbox)**...

    flex css动态加载

    首先,Flex CSS(也称为Flexbox)是CSS3弹性盒模型,它为处理容器内元素的布局提供了一种现代化的方法。Flexbox主要设计用于单一方向的布局,如水平或垂直排列,它解决了以往CSS布局模式(如浮动和定位)中的一些...

    JW flv player flex修改源码并编译

    在本文中,我们将深入探讨如何对JW FLV Player进行源码修改并使用Flex和Ant进行编译。JW FLV Player是一款流行的开源Flash视频播放器,它支持FLV格式和其他多种视频格式,广泛应用于网站媒体播放。让我们一步步了解...

    flex css iCandySource

    标题中的“flex css iCandySource”提示我们讨论的主题与使用Flex框架和CSS技术来设计一个名为“iCandy”的项目有关。Flex是Adobe开发的一个开源SDK,主要用于构建富互联网应用程序(RIA),尤其是基于Flash Player...

    css.rar_css VC_css bison_flex

    本项目是一个基于VC(Visual C++)编译环境的简单CSS解析器原型,它利用了两个强大的开源工具:Bison和Flex。 **Bison** 是一款语法分析器生成器,它根据文法定义文件(通常以`.y`为扩展名)生成C或C++代码。这个...

    FLEX_人力资源管理

    在“FLEX_人力资源管理”项目中,我们可以推测开发者使用了Flex技术来构建用户界面,提供了丰富的交互性和可视化效果。同时,结合ILOG Elixir的优化算法,可能实现了高效的人力资源分配、排班、任务调度等功能。 ...

    flex 4.6Css

    使用方法: 引入: add silvergreen-2.1.swc to libs 使用(SWC方案): 在IDE(如:Flash Builder)里面,增加一个编译参数: ... &lt;fx:Style source="com\ksria\flex\silvergreen\spark\style.css" /&gt;

    flex css FlexraysGrey

    2. `.flexProperties`:这是另一个与 Adobe Flex 开发相关的文件,它可能包含有关 Flex 项目的配置信息,比如编译选项等。在与 CSS Flexbox 结合的场景下,这可能表示项目结合了传统 Flex 平台和现代浏览器的 ...

    flex 卸载flash 安装编译版10flash

    在本文中,我们将深入探讨如何卸载Flash,然后安装编译版的Flash Player 10,这对于开发者进行Flex应用开发至关重要。 首先,我们来了解为何要卸载Flash。Flash Player是一款广泛使用的浏览器插件,用于播放多媒体...

    flex css DiscoType

    标题中的“flex css DiscoType”可能是指一种使用CSS(层叠样式表)和Flex布局来创建动态、炫酷效果的方法,可能类似于早期网页动画中的Disco效果。在现代Web开发中,Flex布局允许开发者轻松地处理元素的排列、对齐...

    eclipse下tomacat的配制flex编译的配制方法.pdf

    ### Eclipse 下 Tomcat 的配置与Flex编译配置详解 #### 一、Eclipse 下 Tomcat 的配置 **准备工作** 为了确保Eclipse与Tomcat能够顺利地集成在一起,并且支持JavaEE应用,首先需要进行以下几项准备工作: 1. **...

    Flex3与Flex4对比

    - **CSS外观和样式设计**:Flex3与Flex4均提供了CSS样式的设计支持,使得开发者可以更加方便地调整界面的外观。 - **高级文本处理**:这是Flex4引入的新特性之一,它通过提供文本布局框架来改善文本的处理方式,提高...

    flex css SummerSky

    标题中的"flex css SummerSky"很可能是指一个与前端开发相关的项目,该项目可能专注于使用Flex CSS布局来设计一个名为"SummerSky"的界面或组件。在Web开发中,Flex CSS(通常指的是CSS Flexible Box,简称Flexbox)...

    Flex3与flex4的区别

    其次,Flex4中的CSS字体选择器现在需要命名空间,这与Flex3不同。为了适应这一变化,开发者需要在CSS中添加命名空间声明。此外,Flex4中MX组件的默认主题已更改为Spark主题,这可能会影响应用程序的外观和感觉。不过...

    Flex3.Style.Explorer.V3.0.Beta

    SWF文件是Flex编译后的结果,它是Flash Player能够理解和执行的二进制格式。在Flex3.Style.Explorer.V3.0.Beta.swf中,包含了这个Style Explorer工具的全部功能和界面,用户可以通过Flash Player或者兼容的浏览器...

    flex4需要编译的基本库

    SWC文件是Adobe Flex中的库打包格式,包含了编译后的ActionScript类、资源和元数据。这个特定的SWC可能包含了与Flash Player交互、数据绑定、事件处理和组件相关的类库,使得开发者能够更方便地处理数据和展示动态...

    Flex万年历记事本_flex源码

    3. **Flex Builder/Flash Builder**:这个项目可能是在Adobe Flex Builder或Flash Builder集成开发环境中创建的,这两个工具提供了强大的调试、编译和部署功能,帮助开发者高效地构建Flex应用。 4. **数据绑定**:...

Global site tag (gtag.js) - Google Analytics