WP7 ListPicker - DataSource から生成されたときにモデル内で選択された項目をマークするにはどうすればよいですか?

StackOverflow https://stackoverflow.com/questions/9369491

質問

私は持っています Menu 多くのものが含まれるオブジェクト (DataContext として設定) Options (Menu.Options), 、これには、 Name (Option.Name) そして多くの Options (Option.Options). 。コレクションはすべてタイプのものです ObservableCollection<T>.

メニューは XML ファイルからロードされるため、オプションと値の量は異なる場合があります。

視覚的にわかりやすくするために、関連する XAML を次に示します。

<ListBox ItemsSource="{Binding Path=Options}">
    <ListBox.ItemTemplate>
        <DataTemplate>
            <StackPanel>
                <!-- Title -->
                <TextBlock Text="{Binding Path=Name}" TextWrapping="Wrap" Style="{StaticResource PhoneTextExtraLargeStyle}" />
                <!-- Selection -->
                <toolkit:ListPicker ItemsSource="{Binding Path=Options}" SelectionChanged="ListPicker_SelectionChanged">
                    <toolkit:ListPicker.ItemTemplate>
                        <DataTemplate>
                            <TextBlock Text="{Binding Path=Name}" />
                        </DataTemplate>
                    </toolkit:ListPicker.ItemTemplate>
                    <toolkit:ListPicker.FullModeItemTemplate>
                        <DataTemplate>
                            <TextBlock Text="{Binding Path=Name}" />
                        </DataTemplate>
                    </toolkit:ListPicker.FullModeItemTemplate>
                </toolkit:ListPicker>
            </StackPanel>
        </DataTemplate>
    </ListBox.ItemTemplate>
</ListBox>

私には方法があります ListPicker_SelectionChanged SelectionChanged イベントで、データバインドされたモデル内の現在の選択を何らかの方法でマークしたいと考えています。各 ListPicker は実行時に生成されるため、メソッドに指定されたパラメーターのみを使用してこれを行う必要があります。したがって、実際のコントロール名を指定することはできません (私の知る限り)。

考えられる選択肢は 2 つあります。

1) 持つこと CurrentSelection 内部 Menu.Option, 、ListPicker で最後に選択した項目への参照を置くことができます。

2) Selected の属性 Option.Option. 。ただし、ここでの欠点は、新しい要素を選択するときにすべての要素の選択が解除されることです。

のオブジェクトツリーを閲覧してみました sender, 、しかし、私が見つけたものは何でも、 ItemsHost, 、アクセスできません (プライベート/保護されています)。

解決策を得る方法はありますか?

役に立ちましたか?

解決

オプション 1 の方が優れており、ListPicker.SelectedItem で TwoWay バインディングを使用します。

<phone:PhoneApplicationPage 
    x:Class="StackOverflowWP7.SO9369491"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:phone="clr-namespace:Microsoft.Phone.Controls;assembly=Microsoft.Phone"
    xmlns:shell="clr-namespace:Microsoft.Phone.Shell;assembly=Microsoft.Phone"
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
    xmlns:toolkit="clr-namespace:Microsoft.Phone.Controls;assembly=Microsoft.Phone.Controls.Toolkit"
    xmlns:local="clr-namespace:StackOverflowWP7.SO9369491_"
    mc:Ignorable="d" d:DesignWidth="480" d:DesignHeight="768"
    FontFamily="{StaticResource PhoneFontFamilyNormal}"
    FontSize="{StaticResource PhoneFontSizeNormal}"
    Foreground="{StaticResource PhoneForegroundBrush}"
    SupportedOrientations="Portrait" Orientation="Portrait"
    shell:SystemTray.IsVisible="True">
    <phone:PhoneApplicationPage.DataContext>
        <local:Menu>
            <local:Menu.Options>
                <local:Option Description="Size">
                    <local:Option.Options>
                        <local:Option local:Description="Large" />
                        <local:Option local:Description="Regular" />
                    </local:Option.Options>
                    <local:Option.CurrentSelection>
                        <local:Option local:Description="Regular" />
                    </local:Option.CurrentSelection>
                </local:Option>
            </local:Menu.Options>
        </local:Menu>
    </phone:PhoneApplicationPage.DataContext>
    <!--LayoutRoot is the root grid where all page content is placed-->
    <Grid x:Name="LayoutRoot" Background="Transparent">
        <Grid.RowDefinitions>
            <RowDefinition Height="Auto"/>
            <RowDefinition Height="*"/>
        </Grid.RowDefinitions>

        <!--TitlePanel contains the name of the application and page title-->
        <StackPanel x:Name="TitlePanel" Grid.Row="0" Margin="12,17,0,28">
            <TextBlock x:Name="ApplicationTitle" Text="MY APPLICATION" Style="{StaticResource PhoneTextNormalStyle}"/>
            <TextBlock x:Name="PageTitle" Text="page name" Margin="9,-7,0,0" Style="{StaticResource PhoneTextTitle1Style}"/>
        </StackPanel>

        <!--ContentPanel - place additional content here-->
        <Grid x:Name="ContentPanel" Grid.Row="1" Margin="12,0,12,0">
            <ListBox ItemsSource="{Binding Path=Options}">
                <ListBox.ItemTemplate>
                    <DataTemplate>
                        <StackPanel>
                            <!-- Title -->
                            <TextBlock Text="{Binding Path=Description}" TextWrapping="Wrap" Style="{StaticResource PhoneTextExtraLargeStyle}" />
                            <!-- Selection -->
                            <toolkit:ListPicker ItemsSource="{Binding Path=Options}"
                                                SelectedItem="{Binding CurrentSelection, Mode=TwoWay}" >
                                <toolkit:ListPicker.ItemTemplate>
                                    <DataTemplate>
                                        <TextBlock Text="{Binding Path=Description}" />
                                    </DataTemplate>
                                </toolkit:ListPicker.ItemTemplate>
                                <toolkit:ListPicker.FullModeItemTemplate>
                                    <DataTemplate>
                                        <TextBlock Text="{Binding Path=Description}" />
                                    </DataTemplate>
                                </toolkit:ListPicker.FullModeItemTemplate>
                            </toolkit:ListPicker>
                        </StackPanel>
                    </DataTemplate>
                </ListBox.ItemTemplate>
            </ListBox>
        </Grid>
    </Grid>

</phone:PhoneApplicationPage>

コードビハインドは次のとおりです

namespace StackOverflowWP7
{
    using Microsoft.Phone.Controls;

    public partial class SO9369491 : PhoneApplicationPage
    {
        // Constructor
        public SO9369491()
        {
            InitializeComponent();

        }

    }

}

namespace StackOverflowWP7.SO9369491_
{
    using System.Collections.ObjectModel;
    using System.Linq;

    public class Menu : Option
    {
        public Menu()
            : base("Main Menu")
        {
        }
    }

    public class Option
    {
        public Option() {}

        public Option(string Name, params string[] choices)
        {
            this.Description = Name;
            foreach (var choice in choices)
            {
                this._options.Add(new Option(choice));
            }
        }

        public string Description { get; set; }

        private ObservableCollection<Option> _options = new ObservableCollection<Option>();
        public ObservableCollection<Option> Options { get { return _options; } }

        private Option _CurrentSelection;

        public Option CurrentSelection
        {
            get { 
                return _CurrentSelection; 
            }
            set
            {
                if (_options.Contains(value))
                {
                    _CurrentSelection = value;
                }
                else
                {
                    _CurrentSelection = _options.FirstOrDefault((o) => o.Description == value.Description);
                }
            }
        }

    }

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