2013-01-23 17 views
17

Wiążę ItemsSource z mojego MenuItem do ObservableCollection w moim ViewModel. Tu jest mój XAML:Jak dynamicznie powiązać i statycznie dodać MenuItems?

<MenuItem Header="_View" 
      ItemsSource="{Binding Windows}"> 
    <MenuItem.ItemContainerStyle> 
    <Style> 
     <Setter Property="MenuItem.Header" 
       Value="{Binding Title}" /> 
    </Style> 
    </MenuItem.ItemContainerStyle> 
</MenuItem> 

Ta część działa świetnie, ale teraz chcę też dodać kilka statycznych elementów menu do samego widoku MenuItem, oddzielonych separatorem. Coś w tym stylu, chociaż wiem, że to nie zadziała, ponieważ nie mogę ustawić przedmiotów dwukrotnie.

<MenuItem Header="_View" 
      ItemsSource="{Binding Windows}"> 
    <MenuItem.ItemContainerStyle> 
    <Style> 
     <Setter Property="MenuItem.Header" 
       Value="{Binding Title}" /> 
    </Style> 
    </MenuItem.ItemContainerStyle> 
    <Separator /> 
    <MenuItem Header="item 1" /> 
    <MenuItem Header="item 2" /> 
</MenuItem> 

Na razie stworzyliśmy obejść dodając kolejny poziom do MenuItem takiego:

<MenuItem Header="_View"> 
    <MenuItem Header="Windows" 
      ItemsSource="{Binding Windows}"> 
    <MenuItem.ItemContainerStyle> 
     <Style> 
     <Setter Property="MenuItem.Header" 
       Value="{Binding Title}" /> 
     </Style> 
    </MenuItem.ItemContainerStyle> 
    </MenuItem> 
    <MenuItem Header="Load Layout" /> 
    <MenuItem Header="Save Layout" /> 
</MenuItem> 

Działa to dobrze, ale raczej nie chciałbym mieć podmenu jeśli to w ogóle możliwe . Aha, i wolałbym to zrobić w Xaml zamiast kodu z tyłu. Jakieś pomysły?

+0

Być może używać CompositeCollection do "ujednolicenia" Państwa zbierania z maszyny wirtualnej przy użyciu zdefiniowanej kolekcji XAML. –

Odpowiedz

35

W tym celu można użyć CompositeCollection, można łączyć różne kolekcje i dodawać statyczne elementy do xaml.

Przykład:

Xaml:

<Window x:Class="WpfApplication8.MainWindow" 
     xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
     xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 
     Title="MainWindow" Height="233" Width="143" Name="UI"> 
    <Window.Resources> 
     <CollectionViewSource Source="{Binding ElementName=UI, Path=Windows}" x:Key="YourMenuItems"/> 
    </Window.Resources> 

    <Grid DataContext="{Binding ElementName=UI}"> 
     <Menu Height="24" VerticalAlignment="Top"> 
     <MenuItem Header="_View" > 
       <MenuItem Header="Windows"> 
        <MenuItem.ItemsSource> 
         <CompositeCollection> 
          <CollectionContainer Collection="{Binding Source={StaticResource YourMenuItems}}" /> 
          <MenuItem Header="Menu Item 1" /> 
          <MenuItem Header="Menu Item 2" /> 
          <MenuItem Header="Menu Item 3" /> 
         </CompositeCollection> 
        </MenuItem.ItemsSource> 
        <MenuItem.ItemContainerStyle> 
         <Style> 
          <Setter Property="MenuItem.Header" Value="{Binding Title}"/> 
         </Style> 
        </MenuItem.ItemContainerStyle> 
       </MenuItem> 
      </MenuItem> 
     </Menu> 
    </Grid> 
</Window> 

Kod

public partial class MainWindow : Window 
{ 
    private ObservableCollection<MyObject> _windows = new ObservableCollection<MyObject>(); 

    public MainWindow() 
    { 
     InitializeComponent(); 
     Windows.Add(new MyObject { Title = "Collection Item 1" }); 
     Windows.Add(new MyObject { Title = "Collection Item 2" }); 
    } 

    public ObservableCollection<MyObject> Windows 
    { 
     get { return _windows; } 
     set { _windows = value; } 
    } 
} 

public class MyObject 
{ 
    public string Title { get; set; } 
} 

Wynik:

enter image description here

+0

Do czego służy element '{Binding ElementName = UI}'? – Pyritie

+0

co jeśli wiążę dane 'Menu' ItemsSource (nie jeden z jego MenuItems)? Nie mogłem uruchomić 'ItemContainerStyle' do pracy, ponieważ ustawiłem' Menu.ItemContainerStyle' i to jest złe ... – JobaDiniz

Powiązane problemy