Flex 4 中是否可以在运行时更改背景颜色<s:Application>
?我已经看到了如何使用应用程序组件的 MX 版本而不是 spark 版本的示例。
我无法将backgroundColor
属性绑定到变量并对其进行修改。但是,我认为我应该使用styleManager
组件的属性来执行此更改。
谁能解释如何做到这一点?
感谢您的时间。
Flex 4 中是否可以在运行时更改背景颜色<s:Application>
?我已经看到了如何使用应用程序组件的 MX 版本而不是 spark 版本的示例。
我无法将backgroundColor
属性绑定到变量并对其进行修改。但是,我认为我应该使用styleManager
组件的属性来执行此更改。
谁能解释如何做到这一点?
感谢您的时间。
我建议你通过这个:
http://help.adobe.com/en_US/flex/using/WS2db454920e96a9e51e63e3d11c0bf69084-7fee.html
视频教程逐步介绍了在 Flex 4 中使用 CSS 和皮肤,这是更改视觉组件的主要方法。
应用程序仍然具有 backgroundColor 样式:http: //help.adobe.com/en_US/FlashPlatform/reference/actionscript/3/spark/components/Application.html
<?xml version="1.0" encoding="utf-8"?>
<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/mx" minWidth="955" minHeight="600"
creationComplete="application1_creationCompleteHandler(event)">
<s:layout>
<s:HorizontalLayout/>
</s:layout>
<fx:Script>
<![CDATA[
import mx.events.FlexEvent;
protected function application1_creationCompleteHandler(event:FlexEvent):void
{
setStyle('backgroundColor',0xCCCCCC);
}
]]>
</fx:Script>
<s:Button click="setStyle('backgroundColor','0xff0000');" label="turn red"/>
<s:Button click="setStyle('backgroundColor','0x0000ff');" label="turn blue"/>
<s:Button click="setStyle('backgroundColor','0x00ff00');" label="turn green"/>
</s:Application>
更好的方式去 IMO
<?xml version="1.0" encoding="utf-8"?>
<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/mx" minWidth="955" minHeight="600">
<s:layout>
<s:HorizontalLayout/>
</s:layout>
<fx:Style>
@namespace s "library://ns.adobe.com/flex/spark";
@namespace mx "library://ns.adobe.com/flex/mx";
s|Application{
backgroundColor:#CCCCCC;
}
</fx:Style>
<s:Button click="setStyle('backgroundColor','0xff0000');" label="turn red"/>
<s:Button click="setStyle('backgroundColor','0x0000ff');" label="turn blue"/>
<s:Button click="setStyle('backgroundColor','0x00ff00');" label="turn green"/>
</s:Application>
最好还是将 CSS 拉出到它自己的文件中,然后用
<fx:Style source="myStyle.css"/>
你可以试试
FlexGlobals.topLevelApplication.setStyle("backgroundColor", 0xff0000); // that would turn it into bright red
FlexGlobals.topLevelApplication.setStyle("backgroundAlpha", 1); // Sometimes background color is ignored when background alpha is zero
如果背景颜色没有改变,这意味着您的组件之一可能正在指定背景颜色。