こんにちは
WPFのDataGridComboBoxについてです。
DataSetのDataTableをItemsSourceに設定する場合
C#のコードからは出来たのですが
XAMLでの設定はどうしたらいいでしょうか
ご教授よろしくお願いします。
XAML
1<Window x:Class="WpfApplication1.MainWindow" 2 xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 3 xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 4 xmlns:d="http://schemas.microsoft.com/expression/blend/2008" 5 xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" 6 xmlns:local="clr-namespace:WpfApplication1" 7 mc:Ignorable="d" 8 Title="MainWindow" Height="400" Width="400"> 9 <Grid> 10 <DataGrid x:Name="dataGrid" AutoGenerateColumns="False" ItemsSource="{Binding table2}" SelectionUnit="Cell"> 11 <DataGrid.Columns> 12 <DataGridTextColumn Binding="{Binding Name}" Width="100"/> 13 <DataGridComboBoxColumn 14 SelectedValueBinding="{Binding field1}" 15 ItemsSource="{Binding table1}" 16 DisplayMemberPath="Name" 17 SelectedValuePath="ID" 18 Width="100"/> 19 </DataGrid.Columns> 20 </DataGrid> 21 </Grid> 22</Window>
C#
1using System; 2using System.Data; 3using System.Windows; 4using System.Windows.Controls; 5 6namespace WpfApplication1 7{ 8 /// <summary> 9 /// MainWindow.xaml の相互作用ロジック 10 /// </summary> 11 public partial class MainWindow : Window 12 { 13 private DataSet _ds; 14 15 public MainWindow() 16 { 17 InitializeComponent(); 18 19 _ds = new DataSet(); 20 21 DataTable table1 = new DataTable("table1"); 22 table1.Columns.Add("ID", typeof(int)); 23 table1.Columns.Add("Name", typeof(string)); 24 table1.Rows.Add(new object[] { 0, "りんご" }); 25 table1.Rows.Add(new object[] { 1, "みかん" }); 26 table1.Rows.Add(new object[] { 2, "パイナップル" }); 27 28 DataTable table2 = new DataTable("table2"); 29 table2.Columns.Add("Name", typeof(string)); 30 table2.Columns.Add("field1", typeof(int)); 31 table2.Rows.Add(new object[] { "テスト1", 0 }); 32 table2.Rows.Add(new object[] { "テスト2", 1 }); 33 table2.Rows.Add(new object[] { "テスト3", 2 }); 34 35 _ds.Tables.Add(table1); 36 _ds.Tables.Add(table2); 37 38 //DataGridComboBoxColumn col = (DataGridComboBoxColumn)dataGrid.Columns[1]; 39 //col.ItemsSource = _ds.Tables["table1"].DefaultView; 40 41 this.DataContext = _ds; 42 } 43 } 44}
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。