0

これは、ここで尋ねられた質問に似ています。カスタム イベント「ShopEvent」をディスパッチしていますが、「Type Coercion failed: cannot convert flash.events::Event@81ecb79 to com.events.ShopEvent」というエラーが表示されます。

注: 親カスタム コンポーネント (3 番目のコード スニペット) からエラーがスローされます。そこに詳細を追加しました。

これは私のカスタム イベントです。最初の定数を参照してください。カスタム コンポーネントにイベント名をコピーして貼り付けました。

package com.events
{
    import flash.events.Event;

    public class ShopEvent extends Event
    {

        public static var MENU_SELECTED:String = "menuSelected";
        public static var SUBMENU_SELECTED:String = "submenuSelected";
        public static var ITEM_SELECTED:String = "itemSelected";
        public static var NAV_NEXT:String = "navNext";
        public static var NAV_PREVIOUS:String = "navPrevious";
        public static var NAV_LAST:String = "navLast";
        public static var NAV_FIRST:String = "navFirst";
        public static var CLOSE:String = "close";

        public var menuIdx:int;
        //public var menuType:String;
        public var menuId:int;
        public var menuName:String;
        public var itemId:int;
        public function ShopEvent(type:String, bubbles:Boolean=false, cancelable:Boolean=false)
        {
            super(type, bubbles, cancelable);
        }
    }
}

カスタム コンポーネント。メタデータ タグを確認します。イベントは正しく登録されました

<?xml version="1.0" encoding="utf-8"?>
<s:Group xmlns:fx="http://ns.adobe.com/mxml/2009" 
         xmlns:s="library://ns.adobe.com/flex/spark" 
         xmlns:mx="library://ns.adobe.com/flex/mx" width="72" height="82"
         mouseChildren="false"
         creationComplete="init()"
         click="onClick()"
         buttonMode="true">
    <s:layout>
        <s:VerticalLayout horizontalAlign="center"/>
    </s:layout>
    <fx:Script>
        <![CDATA[
            import com.events.ShopEvent;

            import mx.controls.Image;
            public var menuId:int;

            [Bindable]
            public var menuText:String;
            [Bindable]
            public var bmp:Bitmap;

            private function init():void{
                //img.addChild(bmp);
            }
            private function onClick():void{
                var e:ShopEvent = new ShopEvent(ShopEvent.MENU_SELECTED);
                e.menuId = menuId;
                e.menuName = menuText;
                dispatchEvent(e);
            }

        ]]>

    </fx:Script>
    <fx:Metadata>
        [Event(name="menuSelected", type="com.events.ShopEvent")]
    </fx:Metadata>
    <fx:Declarations>
        <!-- Place non-visual elements (e.g., services, value objects) here -->
    </fx:Declarations>
    <s:Label text="{menuText}" fontWeight="bold" fontSize="12" width="44"/>
    <mx:Image id = "img" width="57" height="47" source="{bmp}"/>

</s:Group>

親カスタム コンポーネント。これは、上記のカスタム コンポーネントの親コンポーネントです。menuSelected イベントをリッスンし、単にイベントをリスナーにルーティングします。metadata タグを確認します。イベント登録はきちんと行われています。

ただし、エラーが発生しています

           menus[i].addEventListener( ShopEvent.MENU_SELECTED,function(e:ShopEvent):void{dispatchEvent(e);});

私の知る限り、コードに問題はありません。それに何か問題がありますか?

アップデート

驚くべきことに、shopwevent の「新しい」インスタンスを作成すると問題は解決しますが、残念ながら、イベント オブジェクトのすべてのプロパティを閉じる必要があります。これがフレックスの制限ではないことを願っています。

                menus[i].addEventListener( ShopEvent.MENU_SELECTED,function(e:ShopEvent):void{dispatchEvent(new ShopEvent(ShopEvent.MENU_SELECTED));});

完全なコード

<?xml version="1.0" encoding="utf-8"?>
<s:Group xmlns:fx="http://ns.adobe.com/mxml/2009" 
         xmlns:s="library://ns.adobe.com/flex/spark" 
         xmlns:mx="library://ns.adobe.com/flex/mx"
         width="720" height="605"
         creationComplete="init()" xmlns:shop="UI.shop.*" xmlns:hasu="UI.shop.hasu.*"
         >
    <fx:Declarations>
        <!-- Place non-visual elements (e.g., services, value objects) here -->
    </fx:Declarations>
    <fx:Metadata>
        [Event(name="navNext", type="com.events.ShopEvent")]
        [Event(name="navPrevious", type="com.events.ShopEvent")]
        [Event(name="menuSelected", type="com.events.ShopEvent")]
        [Event(name="submenuSelected", type="com.events.ShopEvent")]
        [Event(name="itemSelected", type="com.events.ShopEvent")]
        [Event(name="close", type="com.events.ShopEvent")]
    </fx:Metadata>

    <fx:Script>
        <![CDATA[
            import com.events.ShopEvent;

            private const MAX_SLOTS:int = 6;

            public var menus:Vector.<ShopMenuItemView>;
            public var itemSlots:Vector.<ShopItemSlotView> = new Vector.<ShopItemSlotView>(MAX_SLOTS);

            private function init():void{
                trace("BEGIN:UI.shop.hasu.ShopView.init");
                initSlots();
            }

            private function initSlots():void{

                for (var i:int = 0;i<itemSlots.length;i++){
                     var slot:ShopItemSlotView = new ShopItemSlotView();
                    itemSlots[i] = slot; 
                    itemSlotsContainer.addElement(slot);
                }
            }

            public function initMenus():void{
                trace("BEGIN:UI.shop.hasu.ShopView.initMenus");
                for (var i:int = 0;i < menus.length;i++){
                    menuContainer.addElement(menus[i]);
                    menus[i].addEventListener(ShopEvent.MENU_SELECTED,function(e:ShopEvent):void{dispatchEvent(e);});
                    //menus[i].addEventListener( ShopEvent.MENU_SELECTED,function(e:ShopEvent):void{dispatchEvent(new ShopEvent(ShopEvent.MENU_SELECTED));});
                }
            }



        ]]>
    </fx:Script>

    <s:layout>
        <s:VerticalLayout />
    </s:layout>
    <s:VGroup name="top">
        <hasu:ShopPlayerAttributesView id="attribsComp"/>
        <s:Group id="menuContainer" name="menus">
            <s:layout>
                <s:HorizontalLayout />
            </s:layout>
        </s:Group>
    </s:VGroup>
    <s:Group>
        <s:layout>
            <s:HorizontalLayout />
        </s:layout>
        <s:Button label="&lt;" />
        <s:Group id = "itemSlotsContainer" name="items">
            <s:layout>
                <s:TileLayout requestedColumnCount="3" requestedRowCount="3"/>
            </s:layout>
        </s:Group>
        <s:Button label="&gt;" />
    </s:Group>
</s:Group>
4

4 に答える 4

2

カスタム イベント クラスの clone() メソッドを上書きする必要があります。イベントは、伝播中に何度か複製される可能性があります。

于 2012-02-16T08:24:00.590 に答える
1

ジャックの答えは正しいです。これは、flex のドキュメントに記載されています。

サブクラスで Event.clone() メソッドをオーバーライドする必要があります。clone() メソッドは、 type プロパティとクローンの新しいプロパティを設定することにより、イベント オブジェクトのクローン コピーを返します。通常、clone() メソッドを定義して、new 演算子で作成されたイベント インスタンスを返します。

詳細については、イベントセクションからサブクラスを作成するのイベント操作を参照してください。

新しい flex/as3 開発者がカスタム イベントを理解するのに適した場所 カスタム イベントのディスパッチ

注: リンクは Flex 4.6 のドキュメントを指していますが、カスタム イベント部分はバージョンに依存しません (Flex 3 以前のバージョンでは mxml 部分のみが異なる場合があります)。

于 2012-03-02T04:40:32.790 に答える
-1

ディスパッチするイベントはタイプ flash.events.Event からのもので、リスナーが期待するイベントはタイプ com.events.ShopEvent からのものです。

これは単にエラー メッセージの意味です。

于 2012-02-16T07:53:46.043 に答える