SpinnerListコントロールの途中にあるアイテムのクリックをどのように検出しますか?
つまり、典型的な状況 - ユーザーが SpinnerList をスクロールして、必要なアイテムが真ん中に来てからクリックしたときですか?
イベント ハンドラーを追加するとclick
、次のスクリーンショットに示すように、ユーザーがアイテムをクリックして真ん中に表示されるという状況も誤って検出されます。
以下は私のテストケースコードです。
何か提案はありますか?また、カスタムを使用してSpinnerListItemRenderer
そこにクリック ハンドラーを追加しようとしましたが、上記の問題は変わりません。
メイン.mxml:
<?xml version="1.0" encoding="utf-8"?>
<s:ViewNavigatorApplication
xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark"
firstView="views.MainHomeView">
</s:ViewNavigatorApplication>
ビュー/MainHomeView.mxml:
<?xml version="1.0" encoding="utf-8"?>
<s:View xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark"
title="How to detect a click?">
<fx:Script>
<![CDATA[
import mx.collections.ArrayList;
private function handleClick(event:Event):void {
trace('selectedItem: ' + _list.selectedItem);
}
]]>
</fx:Script>
<s:SpinnerListContainer>
<s:SpinnerList id="_list"
click="handleClick(event)"
typicalItem="45"
dataProvider="{new ArrayList([1,5,6,10,15,30])}"
wrapElements="false"/>
</s:SpinnerListContainer>
</s:View>