2013-01-23 7 views
17

私は自分のMenuItemのItemsSourceをViewModelのObservableCollectionにバインドします。ここに私のXAMLは次のとおりです。どのように動的にバインドし、静的にMenuItemを追加しますか?

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

この部分は素晴らしい作品が、今私はまた、セパレータで分離された同じビューのMenuItemにいくつかの静的のMenuItemを追加します。私はアイテムを2回設定することができないので、これがうまくいかないことは分かっていますが、このようなものです。

<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> 

これは正常に動作しますが、全く可能であれば私はむしろ、サブメニューを持っていないと思います。今、私はこのようなのMenuItemに別のレベルを追加することによって、周りの仕事を作成しているために

<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> 

。ああ、私はまた、コードの背後にあるxamlでこれを行うことを好むだろう。何か案は?

+0

たぶん、あなたはあなたの "統一" するCompositeCollectionを使用することができますXAMLで定義されたコレクションを持つVMからのコレクション。 –

答えて

35

CompositeCollectionを使用すると、さまざまなコレクションを組み合わせてxamlに静的な項目を追加できます。

例:

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> 

コード

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

結果:

enter image description here

+0

'{Binding ElementName = UI}'の内容は何ですか? – Pyritie

+0

データバインディング 'Menu' ItemsSource(そのMenuItemsの1つではない)はどうですか?私は 'Menu.ItemContainerStyle'をセットしたので、' ItemContainerStyle'を動作させることができませんでした。それは間違っています... – JobaDiniz

関連する問題