0

我需要一个类似于 NumericStepper 的 Flex 3 控件,但它可以显示任意字符串。这种控制存在吗?如果没有,您对创建它有什么建议,或者您会推荐参考资料?

为方便起见,我将其称为 TextStepper。我希望这是一种紧凑的方式来显示用户可以通过单击向上/向下按钮循环浏览的字符串选择列表。紧凑意味着控件没有下拉或弹出方面:更改所选索引的唯一方法是单击向上/向下按钮(更新文本输入值)。值循环意味着我真的想将底层 dataProvider 视为循环缓冲区。因此,向上/向下单击以模方式修改 selectedIndex。

4

2 回答 2

0

TextInput我通过将 a 覆盖在 a 上(绝对定位)创建了其中一个(作为 MXML 组件),NumericStepper以便TextInput覆盖NumericStepper.

dataProvider 是一个ArrayCollection字符串,其值NumericStepper用于访问 ArrayCollection 中的索引。

的 change 事件将NumericStepper的文本更改为TextInputdataProvider 的索引 n 处的任何内容。我为组件提供了一个可编辑的属性,该属性将其设置TextInput为可编辑并将新字符串插入到当前索引处的 dataProvider 中。

于 2010-06-26T12:56:52.330 回答
0

这个想法是使用valueFormatFunction

<?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" xmlns:local="*">

    <local:StringStepper horizontalCenter="0" verticalCenter="0" width="200">
        <local:dataProvider>
            <s:ArrayCollection>
                <fx:String>Hello!</fx:String>
                <fx:String>I love you.</fx:String>
                <fx:String>Won't you tell me your name?</fx:String>
            </s:ArrayCollection>
        </local:dataProvider>
    </local:StringStepper>

</s:Application>

StringStepper 的来源:

package
{
import mx.collections.ArrayCollection;
import mx.events.CollectionEvent;

import spark.components.NumericStepper;

public class StringStepper extends NumericStepper
{
    public function StringStepper()
    {
        enabled = false;
        valueFormatFunction = defaultValueFormatFunction;
        valueParseFunction = defaultValueParseFunction;
    }

    private var _dataProvider:ArrayCollection;

    public function get dataProvider():ArrayCollection
    {
        return _dataProvider;
    }

    public function set dataProvider(value:ArrayCollection):void
    {
        if (_dataProvider == value)
            return;

        if (_dataProvider)
            _dataProvider.removeEventListener(CollectionEvent.COLLECTION_CHANGE,
                dataProvider_collectionChangeHandler);

        _dataProvider = value;
        commitDataProvider();

        if (_dataProvider)
            _dataProvider.addEventListener(CollectionEvent.COLLECTION_CHANGE,
                dataProvider_collectionChangeHandler);
    }

    /**
     * Same event as for <code>value</code>.
     */
    [Bindable("valueCommit")]
    public function get selectedItem():Object
    {
        return _dataProvider && value <= _dataProvider.length - 1 ? _dataProvider[value] : null; 
    }

    public function set selectedItem(value:Object):void
    {
        if (!_dataProvider)
            return;

        value = _dataProvider.getItemIndex(value);
    }

    private function defaultValueFormatFunction(value:Number):String
    {
        return _dataProvider && value <= _dataProvider.length - 1 ? _dataProvider[value] : String(value);
    }

    private function defaultValueParseFunction(value:String):Number
    {
        if (!_dataProvider)
            return 0;

        var n:int = _dataProvider.length;
        for (var i:int = 0; i < n; i++)
        {
            var string:String = _dataProvider[i];
            if (string == value)
                return i;
        }
        return 0;
    }

    private function commitDataProvider():void
    {
        if (!_dataProvider)
        {
            minimum = 0;
            maximum = 0;
            enabled = false;
            return;
        }

        enabled = true;
        minimum = 0;
        maximum = _dataProvider.length - 1;
    }

    private function dataProvider_collectionChangeHandler(event:CollectionEvent):void
    {
        commitDataProvider();
    }

}
}
于 2010-06-26T10:08:41.673 回答