通过代码将项目添加到全景

时间:2010-12-19 17:05:49

标签: c# windows-phone panorama-control

我在通过代码添加全景项时遇到问题。

这是测试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主页,一切正常(没有例外),但我无法移动全景,并且全景项目布局中断。

任何帮助或解决方案?

1 个答案:

答案 0 :(得分:3)

问题似乎是您未与我们分享的代码的一部分 尝试创建演示问题的尽可能小的完整示例。

您问题的代码中TestPanoramaItemHoroscopePanoramaItem之间似乎也存在一些混淆。

我可以毫无问题地动态重新排列标准的PanoramaItem 以下内容基于默认的Panorama模板:

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" }; }
}