質問

1週間ほど髪を引き裂いてきました。今すぐ助けを求めます...

駅を出る次の列車を表示する小さなアプリをコーディングしています。通常、次の列車の時間だけが表示されますが、設定ボタンをクリックすると、アプリケーションウィンドウが拡大し、列車と時間とともにデータグリッドが表示されます。その状態で閉じるボタンをクリックすると、「開始」状態に戻るか、そうする必要があります。

問題は、データグリッドが消えることですが、アプリケーションウィンドウは同じサイズのままです。元のサイズに戻るはずです。

VBoxをCanvasまたはPanelに置き換えて、さまざまなアプローチを試してきましたが、どれも機能しませんでした。設計モードでは、状態を切り替えるときにすべてが期待どおりに機能します。

状態を使用するのはこれが初めてなので、基本的な何かを見逃している可能性があります。

ここにコードサンプルがあります-StartとPrefsの2つのビューステートを使用しています。

<mx:WindowedApplication xmlns:mx="http://www.adobe.com/2006/mxml" 
creationComplete="init();" 
cornerRadius="12"
currentState='Start' width="350" height="250">
<mx:states>
    <mx:State name="Start">
        <mx:AddChild>
            <mx:VBox id="box_parent" width="100%" height="100%" verticalGap="2">
                <mx:Label text="Next Train Leaves At" textAlign="center" width="100%"/>
                <mx:Label text="--:--" width="100%" height="100" fontSize="64" id="timetext" textAlign="center" fontWeight="bold"/> 
                <mx:HBox width="100%" height="25" id="hbox1">
                    <mx:Button label="Prefs"
                        id="buttonPrefs"
                        click="currentState='Prefs'"/>
                    <mx:Spacer width="70%" id="spacer1"/>
                    <mx:Button 
                        label="Next"
                        click="findNextTrain()" id="buttonNext"/>   
                </mx:HBox>      
            </mx:VBox>      
        </mx:AddChild>
        <mx:SetProperty name="layout" value="vertical"/>
        <mx:SetProperty name="width" value="350"/>
        <mx:SetProperty name="height" value="220"/>
    </mx:State>
    <mx:State name="Prefs" basedOn="Start">
        <mx:AddChild relativeTo="{box_parent}" position="lastChild">
            <mx:DataGrid height="80%" width="100%" dataProvider="{trains}" id="traindata" editable="false">
                <mx:columns>
                    <mx:DataGridColumn headerText="Station" dataField="stationid"/>
                    <mx:DataGridColumn headerText="Leave" dataField="leave"/>
                </mx:columns>
            </mx:DataGrid>
        </mx:AddChild>
        <mx:RemoveChild target="{buttonPrefs}"/>
        <mx:SetProperty target="{box_parent}" name="height" value="500"/>
        <mx:AddChild relativeTo="{spacer1}" position="before">
            <mx:Button label="Close" click="currentState='Start'"/>
        </mx:AddChild>
        <mx:SetProperty name="height" value="570"/>
    </mx:State>
</mx:states>

<mx:transitions> 
    <mx:Transition fromState="*" toState="*"> 
        <mx:Resize target="{this}" duration="500"/> 
    </mx:Transition> 
</mx:transitions> 
</mx:WindowedApplication>
役に立ちましたか?

解決

Flexの状態をMXMLで提供される値にリセットする方法をまだ見つけていません。必要な値をプログラムでリセットする必要があります。提供されているサンプルコードの場合、次をWindowedApplicationタグに追加することにより、開始状態に戻すときにアプリケーションの高さをリセットできます

currentStateChange="if(currentState == 'Start') this.height = 220"

これは、現在の状態を変更した後にディスパッチされたイベントを処理して、新しい現在の状態がStartかどうかを確認し、ウィンドウの高さを設定するようにWindowedApplicationタグに指示します。

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top