Apache flex AdobeFlex:希望DropDownList自定义呈现程序以十六进制显示值,并以十六进制显示所选值
我有一些数据,我希望以十进制存储,但在s:DropDownList中以十六进制显示。我已经开发了自定义渲染器,下拉列表以十六进制显示数字,但当选择数字时,它以十进制显示。我希望数字存储为十进制,但无论是在下拉列表中还是选择时,都始终以十六进制显示。我该怎么做 自定义渲染器:Apache flex AdobeFlex:希望DropDownList自定义呈现程序以十六进制显示值,并以十六进制显示所选值,apache-flex,actionscript,flex4,flash-builder,Apache Flex,Actionscript,Flex4,Flash Builder,我有一些数据,我希望以十进制存储,但在s:DropDownList中以十六进制显示。我已经开发了自定义渲染器,下拉列表以十六进制显示数字,但当选择数字时,它以十进制显示。我希望数字存储为十进制,但无论是在下拉列表中还是选择时,都始终以十六进制显示。我该怎么做 自定义渲染器: <?xml version="1.0" encoding="utf-8"?> <s:ItemRenderer xmlns:fx="http://ns.adobe.com/mxml/2009"
<?xml version="1.0" encoding="utf-8"?>
<s:ItemRenderer xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:mx="library://ns.adobe.com/flex/mx"
xmlns:s="library://ns.adobe.com/flex/spark">
<s:Label text="{makeLabel(data)}"/>
<fx:Script>
<![CDATA[
public function makeLabel(data:Object):String {
var x:int = data as int;
var ret:String = x.toString(16);
if (ret.length < 2) {
ret = '0' + ret;
}
return ret.toUpperCase() + 'H';
}
]]>
</fx:Script>
</s:ItemRenderer>
测试存根:
<?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">
<fx:Script>
<![CDATA[
import mx.collections.ArrayCollection;
[Bindable]
public var dp:ArrayCollection = new ArrayCollection([9, 10, 11, 12]);
]]>
</fx:Script>
<s:DropDownList x="72" y="43" dataProvider="{dp}" itemRenderer="HexListRenderer"/>
</s:Application>
您可以使用DropDownList.labelFunction
<?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">
<fx:Script>
<![CDATA[
import mx.collections.ArrayCollection;
[Bindable]
public var dp:ArrayCollection = new ArrayCollection([9, 10, 11, 12]);
public function makeLabel(data:Object):String {
var x:int = data as int;
var ret:String = x.toString(16);
if (ret.length < 2) {
ret = '0' + ret;
}
return ret.toUpperCase() + 'H';
}
]]>
</fx:Script>
<s:DropDownList x="72" y="43" labelFunction="makeLabel" dataProvider="{dp}" itemRenderer="HexListRenderer"/>
</s:Application>