[英]WP7 ListPicker - How to mark selected item in model when generated from DataSource?
我有一個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>
我在SelectionChanged事件上有一個ListPicker_SelectionChanged
方法,我想以某種方式在數據綁定模型中標記當前選擇。 我需要僅使用提供給該方法的參數來完成此操作,因為每個ListPicker都是在運行時生成的。 所以我不能指定實際的控件名稱(據我所知)。
我可以看到兩個可能的選擇:
1)要在Menu.Option
擁有一個CurrentSelection
,我可以在其中放置對該ListPicker的最后選擇的項目的引用
2)在Option.Option
上具有Selected
屬性。 但是,這里的缺點是確保在選擇一個新元素時取消選中所有元素。
我曾嘗試瀏覽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 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.