リストからデータグリッドコンテンツを生成します。データグリッドで選択した行の「名前」セルの値を子ウィンドウのtexblockに渡すことができる必要があります。コンテキストメニュー項目をクリックすると、子ウィンドウが起動します。シナリオは、ユーザーが選択した行の「名前」セルの上でマウスを右クリックし、子ウィンドウを起動するコンテキストメニュー項目を選択することです。ChildWindowは、データグリッドのそのセルのテキストブロックテキスト値を使用して起動されます。どんなアイデアでも大歓迎です!前もって感謝します!
コンテキストメニュー付きのデータグリッド:
<sdk:DataGrid x:Name="dgPack" ItemsSource="{Binding Source={StaticResource PackagesCollectionViewSource}}">
<InputToolkit:ContextMenuService.ContextMenu>
<InputToolkit:ContextMenu x:Name="cmPackages_DataGrid" DataContext="{Binding Source={StaticResource GlobalLabelsDataSource}}">
<InputToolkit:MenuItem x:Name="item1" Header="item1"/>
<InputToolkit:MenuItem x:Name="GetChildWindow" Header="GetChildWindow" Click="GetChildWindow_Click"/>
</InputToolkit:ContextMenu>
</InputToolkit:ContextMenuService.ContextMenu>
<sdk:DataGrid.Columns>
<sdk:DataGridTextColumn x:Name="DataGrid_Name" Binding="{Binding Name}" Header="Name" />
<sdk:DataGridTextColumn x:Name="DataGrid_Version" Binding="{Binding Version}" Header="Version" />
<sdk:DataGridTextColumn x:Name="DataGrid_Size" Binding="{Binding Size}" Header="Size" />
</sdk:DataGrid.Columns>
子ウィンドウを起動するためのコードビハインドのメソッド:
private void GetChildWindow_Click(object sender, System.Windows.RoutedEventArgs e)
{
var selectedItem = PackVM.SelectedPack;
if (selectedItem != null)
{
var bpw = new GetChildWindow1_ChildWindow(selectedItem.Id);
bpw.Show();
}
}
リスト:
public List<Pack> GetCollection()
{
return new List<Pack>()
{
new Pack() { Name="item1", Size=10, Version="1"},
new Pack() { Name="item2", Size=12, Version="5", },
};
}
そして最後に子ウィンドウ:
<Grid x:Name="LayoutRoot">
<Grid.RowDefinitions>
<RowDefinition />
<RowDefinition Height="Auto" />
</Grid.RowDefinitions
<Button x:Name="OKButton" Content="OK" Click="OKButton_Click" Width="75" Height="23" Margin="0,0,79,0" HorizontalAlignment="Right" Grid.Row="1" />
<Button x:Name="CancelButton" Content="Cancel" Click="CancelButton_Click" Width="75" Height="23" HorizontalAlignment="Right" Grid.Row="1" />
<TextBlock x:Name="Message" HorizontalAlignment="Left" TextWrapping="Wrap" Text="" VerticalAlignment="Top"/>
</Grid>