Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/actionscript-3/6.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Actionscript 3 Flex 4在运行时更改主应用程序背景色_Actionscript 3_Flash_Apache Flex_Actionscript_Styles - Fatal编程技术网

Actionscript 3 Flex 4在运行时更改主应用程序背景色

Actionscript 3 Flex 4在运行时更改主应用程序背景色,actionscript-3,flash,apache-flex,actionscript,styles,Actionscript 3,Flash,Apache Flex,Actionscript,Styles,在Flex4中,是否可以在运行时更改的背景色?我已经看到了如何使用MX版本的应用程序组件(而不是spark版本)实现这一点的示例 我无法将backgroundColor属性绑定到变量并对其进行修改。但是,我认为应该使用组件的styleManager属性来执行此更改 有人能解释一下怎么做吗 谢谢您的时间。您可以试一下 FlexGlobals.topLevelApplication.setStyle("backgroundColor", 0xff0000); // that would turn

在Flex4中,是否可以在运行时更改
的背景色?我已经看到了如何使用MX版本的应用程序组件(而不是spark版本)实现这一点的示例

我无法将
backgroundColor
属性绑定到变量并对其进行修改。但是,我认为应该使用组件的
styleManager
属性来执行此更改

有人能解释一下怎么做吗

谢谢您的时间。

您可以试一下

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
如果背景颜色没有改变,这意味着您的一个组件可能正在指定背景颜色。

您可以用

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

如果背景颜色没有改变,这意味着您的一个组件可能正在指定背景颜色。

我建议您执行以下操作:

视频教程将逐步介绍如何在Flex4中使用CSS和皮肤,这是更改视觉组件的主要方法

应用程序仍具有背景色样式:


更好的方法

<?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>

@命名空间s“library://ns.adobe.com/flex/spark";
@名称空间mx“library://ns.adobe.com/flex/mx";
s |应用{
背景颜色:#中交;
}
最好还是把CSS拉到它自己的文件中,用一个

<fx:Style source="myStyle.css"/>

我建议您完成以下步骤:

视频教程将逐步介绍如何在Flex4中使用CSS和皮肤,这是更改视觉组件的主要方法

应用程序仍具有背景色样式:


更好的方法

<?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>

@命名空间s“library://ns.adobe.com/flex/spark";
@名称空间mx“library://ns.adobe.com/flex/mx";
s |应用{
背景颜色:#中交;
}
最好还是把CSS拉到它自己的文件中,用一个

<fx:Style source="myStyle.css"/>


谢谢。这就是我正在尝试的,但它不会改变背景颜色。我在一个
creationComplete
事件处理程序中使用了它。@spryno724我试过了,它也很管用,使用Flex 4.6.0这里可以:)yah skinning很棒,但有时可能有点棘手,很酷,这只是一个建议,绝对不是必要的。刚刚发现,当风格、脚本和布局都在某种程度上分离时,在大型项目中效果更好,但这完全取决于项目。感谢您简单地提出想法,但不要把它们强加给我。我无法告诉你有多少次我看到开发人员,即使是这样,试图把他们的想法推给其他人,不管他们是否知道具体情况,仅仅因为“这是标准方式”、“最佳实践”,甚至“不愚蠢”。提出一个简单的建议,而不是强词夺理的建议,实际上是一种新鲜空气。再次感谢;)非常感谢。这就是我正在尝试的,但它不会改变背景颜色。我在一个
creationComplete
事件处理程序中使用了它。@spryno724我试过了,它也很管用,使用Flex 4.6.0这里可以:)yah skinning很棒,但有时可能有点棘手,很酷,这只是一个建议,绝对不是必要的。刚刚发现,当风格、脚本和布局都在某种程度上分离时,在大型项目中效果更好,但这完全取决于项目。感谢您简单地提出想法,但不要把它们强加给我。我无法告诉你有多少次我看到开发人员,即使是这样,试图把他们的想法推给其他人,不管他们是否知道具体情况,仅仅因为“这是标准方式”、“最佳实践”,甚至“不愚蠢”。提出一个简单的建议,而不是强词夺理的建议,实际上是一种新鲜空气。再次感谢;)