3

我正在使用带有 flex 4 sdk 的 Flash builder,并且正在尝试创建一个组件具有圆角DateField的组件。TextInput

我尝试了以下不起作用的代码:

<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" minWidth="1024" minHeight="768"
    xmlns:components="components.*">

    <fx:Style>
        @namespace s "library://ns.adobe.com/flex/spark";
        @namespace mx "library://ns.adobe.com/flex/halo";
        @namespace components "components.*";

        .roundedTI
        {
            corner-radius: 10;
            borderStyle: solid;   
        }

    </fx:Style>

    <mx:DateField textInputStyleName="roundedTI"/> 

</s:Application>

社区可以帮助我纠正我的代码中的任何可见错误,或者将我指向一个替代指南或教程来演示如何做到这一点?

4

1 回答 1

5

使用 Flex 4,一切都在皮肤中。CSS 主要用于将一个皮肤应用于一个组件或组件类,而在 Flex 3 中,它用于设置大量属性。然而,很酷的是,您可以在 CSS 中定义任意样式属性值,并且可以通过getStyleSkin 访问它!

因此,他们不再拥有cornerRadius财产。相反,您必须创建一个“DateFieldSkin”,并通过 css 选择器将其应用于您的组件。默认的 DateField 外观使用DropDownSkin. 这是解决此问题的代码:

日期字段皮肤

<?xml version="1.0" encoding="utf-8"?>
<s:Skin
    xmlns:fx="http://ns.adobe.com/mxml/2009"
    xmlns:s="library://ns.adobe.com/flex/spark">

    <s:states>
        <s:State name="normal"/>
        <s:State name="disabled"/>
    </s:states>

    <!--- @private -->
    <s:Rect id="border" left="0" right="0" top="0" bottom="0"
        radiusX="{getStyle('cornerRadius')}" radiusY="{getStyle('cornerRadius')}">
        <s:stroke>          
            <!--- @private -->
            <s:SolidColorStroke id="borderStroke" color="0x5380D0" />
        </s:stroke>
        <s:fill>
            <!--- @private -->
            <s:SolidColor id="bgFill" color="0xFFFFFF"/>
        </s:fill>
    </s:Rect>
</s:Skin>

示例应用程序

<?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/halo"
    minWidth="1024" minHeight="768">

    <fx:Style>
        @namespace s "library://ns.adobe.com/flex/spark";
        @namespace mx "library://ns.adobe.com/flex/mx";

        .roundedTI
        {
            corner-radius: 10;
            borderStyle: solid;
            borderSkin: ClassReference("DateFieldSkin");
        }

    </fx:Style>

    <mx:DateField textInputStyleName="roundedTI"/>

</s:Application>

您还可以将半径值硬编码到皮肤中,或者做一些更加动态和优化的事情。这只是一个开始。

让我知道这是否有效,兰斯

于 2010-02-15T21:29:30.280 回答