0

コードを使用してパノラマアイテムを追加する際に問題が発生しました。

これが機能するテストxamlです。

<controls:Panorama x:Name="pano">
    <controls:Panorama.Title>...</controls:Panorama.Title>
    <controls:Panorama.Background>...</controls:Panorama.Background>
    <local:TestPanoramaItem ...></local:HoroscopePanoramaItem>
    <local:TestPanoramaItem ...></local:HoroscopePanoramaItem>
    <local:TestPanoramaItem ...></local:HoroscopePanoramaItem>
</controls:Panorama>

TestPanoramaItemは、PanoramaItemから継承するクラスであり、xamlではすべて正常に機能します。ここで、パノラマアイテムをコードで並べ替えたいと思います。

編集:これからxamlからアイテムを削除しました

「pan1、pan2、pan3、...」のような静的文字列でデフォルトの順序を作成し、OnNavigatedToHandler(MainPage内)では次のようなコードを使用します。

protected override void OnNavigatedTo(NavigationEventArgs e)
        {
            String[] order = App.Order.Split(',');
            App.items.Clear();
            foreach (String o in order)
            {
                switch (o)
                {
                    case "pan1": App.items.Add(App.pan1); break;
                    case "pan2": App.items.Add(App.pan2); break;
                    case "pan3": App.items.Add(App.pan3); break;
                    ...
                }
            }
            pano.Items.Clear();

            foreach (TestPanoramaItem ti in App.items)
                pano.Items.Add(ti);
            base.OnNavigatedTo(e);
        }

初めて呼び出された(これはMainPageにあります)すべてが正常に見えます。パノラマは動作します。アイテムの順序を変更できる設定に移動するメニューボタンがあります。設定ページのOnNavigateFromハンドラーで、App.Order静的文字列を更新します。その後、メインページのOnNavigatedToが再度呼び出され、すべてが正常に実行されます(例外はありません)が、パノラマを移動できず、パノラマアイテムのレイアウトが壊れています。

ヘルプや解決策はありますか?

4

1 に答える 1

3

問題は、あなたが私たちと共有していないコードの一部にあるようです。
問題を示す可能な限り最小の完全な例を作成してみてください。

また、質問のコードTestPanoramaItemとの間で混乱が生じているようです。HoroscopePanoramaItem

標準のPanoramaItemを問題なく動的に再配置できます。
以下は、デフォルトのパノラマテンプレートに基づいています。

Mainpage.xaml

<Grid x:Name="LayoutRoot" Background="Transparent">
    <controls:Panorama Name="myPano" Title="my application">
        <controls:Panorama.Background>
            <ImageBrush ImageSource="PanoramaBackground.png"/>
        </controls:Panorama.Background>
    </controls:Panorama>
</Grid>

<!--Panorama-based applications should not show an ApplicationBar but this is just for testing-->
<phone:PhoneApplicationPage.ApplicationBar>
    <shell:ApplicationBar IsVisible="True" IsMenuEnabled="True">
        <shell:ApplicationBarIconButton IconUri="/Images/appbar_button1.png" Text="Button 1" Click="ApplicationBarIconButton_Click"/>
    </shell:ApplicationBar>
</phone:PhoneApplicationPage.ApplicationBar>

MainPage.xaml.cs

    protected override void OnNavigatedTo(System.Windows.Navigation.NavigationEventArgs e)
    {
        myPano.Items.Clear();

        if (new Random().Next(1, 2) == 1)
        {
            myPano.Items.Add(App.pan1);
            myPano.Items.Add(App.pan2);
            myPano.Items.Add(App.pan3);
        }
        else
        {
            myPano.Items.Add(App.pan1);
            myPano.Items.Add(App.pan3);
            myPano.Items.Add(App.pan2);
        }

        base.OnNavigatedTo(e);
    }

    private void ApplicationBarIconButton_Click(object sender, EventArgs e)
    {
        NavigationService.Navigate(new Uri("/Page1.xaml", UriKind.Relative));
    }

App.xaml.cs

public static PanoramaItem pan1
{
    get { return new PanoramaItem { Header = "first item" }; }
}
public static PanoramaItem pan2
{
    get { return new PanoramaItem { Header = "second item" }; }
}
public static PanoramaItem pan3
{
    get { return new PanoramaItem { Header = "third item" }; }
}
于 2010-12-20T11:20:10.853 に答える