質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.48%

  • WPF

    724questions

    Windows Presentation Foundation (WPF) は、魅力的な外観のユーザー エクスペリエンスを持つ Windows クライアント アプリケーションを作成するための次世代プレゼンテーション システムです

  • Visual Basic .NET

    102questions

    Microsoft Visual Basic .NET (VB.NET)とはオブジェクト志向のプログラム言語です。 Microsoft"s Visual Basic 6 のバージョンアップとしてみることができますが、Microsoft.NET Frameworktによって動かされています。

WPFのDataGrid内にコンボボックスを動的に生成する方法

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 4,110

yisland

score 23

環境
VB
WPF

WPFのDataGrid内に動的に生成したコンボボックスを表示させる方法が分かりません。
どなたか分かる方がいらしたら教えて頂きたいです。

追加
<Window x:Class="Window2"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    Title="Window2" Height="383" Width="666">
    <StackPanel Orientation="Vertical">

        <DataGrid Grid.Row="1" Name="DataGrid1" AutoGenerateColumns="False" Height="300" >
            <DataGrid.Columns>
                <DataGridTemplateColumn>
                    <DataGridTemplateColumn.Header>
                        <Grid>
                            <Grid.RowDefinitions>
                                <RowDefinition />
                                <RowDefinition />
                            </Grid.RowDefinitions>
                            <Label Grid.Row="0" Grid.RowSpan="2" Content="てすと1" />
                        </Grid>
                    </DataGridTemplateColumn.Header>
                    
                    <DataGridTemplateColumn.CellTemplate>
                        <DataTemplate>
                            <Grid>
                                <Grid.RowDefinitions>
                                    <RowDefinition />
                                    <RowDefinition />
                                </Grid.RowDefinitions>
                                <Label Grid.Row="0" Grid.RowSpan="2" Content="{Binding Test1}" />
                            </Grid>
                        </DataTemplate>
                    </DataGridTemplateColumn.CellTemplate>
                </DataGridTemplateColumn>

                <DataGridTemplateColumn>
                    <DataGridTemplateColumn.Header>
                        <DataGridColumnHeader>
                            <Grid>
                                <Grid.RowDefinitions>
                                    <RowDefinition />
                                    <RowDefinition />
                                </Grid.RowDefinitions>
                                <Label Grid.Row="0" Content="てすと2" />
                                <Label Grid.Row="1" Content="てすと3" />
                            </Grid>
                        </DataGridColumnHeader>
                    </DataGridTemplateColumn.Header>

                    <DataGridTemplateColumn.CellTemplate>
                        <DataTemplate>
                            <Grid>
                                <Grid.RowDefinitions>
                                    <RowDefinition />
                                    <RowDefinition />
                                </Grid.RowDefinitions>
                                <Label Grid.Row="0" Content="{Binding Test2}" />
                                <Label Grid.Row="1" Content="{Binding Test3}" />
                            </Grid>
                        </DataTemplate>
                    </DataGridTemplateColumn.CellTemplate>
                </DataGridTemplateColumn>

                <DataGridTemplateColumn>
                    <DataGridTemplateColumn.Header>
                        <Grid>
                            <Grid.RowDefinitions>
                                <RowDefinition />
                                <RowDefinition />
                            </Grid.RowDefinitions>
                            <Label Grid.Row="0" Grid.RowSpan="2" Content="コンボボックス" />
                        </Grid>
                    </DataGridTemplateColumn.Header>

                    <DataGridTemplateColumn.CellTemplate>
                        <DataTemplate>
                            <Grid>
                                <Grid.RowDefinitions>
                                    <RowDefinition />
                                    <RowDefinition />
                                </Grid.RowDefinitions>
                                <ComboBox Name="comboTest" />
                            </Grid>
                        </DataTemplate>
                    </DataGridTemplateColumn.CellTemplate>
                </DataGridTemplateColumn>
                    
            </DataGrid.Columns>
        </DataGrid>
    </StackPanel>
</Window>
ViewModelでDataGridのItemsSourceにどうやって設定すればいいのかが分かりません。
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • Tak1wa

    2015/09/02 09:53

    「動的に生成したコンボボックスを表示させる」についてもう少し明確に記載をお願いします。 どの点が動的なのでしょうか。

    キャンセル

  • yisland

    2015/09/02 10:01

    DBから情報を取得してリストにしたいです。

    キャンセル

  • daichan

    2015/09/02 10:52

    DataGridとコンボボックスの関係をもう少し具体的に書いていただけないでしょうか。 ・コンボボックスのあるセルの列を追加したい? ・コンボボックスのあるセルを含む行を追加したい?

    キャンセル

  • yisland

    2015/09/02 10:56

    コンボボックスのあるセルを含む行を追加したいです

    キャンセル

回答 2

checkベストアンサー

+1

DB云々のところはViewModel内で適宜読み替えてください。
また、型をStringとしていますので独自型に適宜変更することになるでしょう。

<Window x:Class="MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:local="clr-namespace:WpfApplication1"
        Title="MainWindow" Height="350" Width="525">
    <Window.DataContext>
        <local:MainWindowViewModel />
    </Window.DataContext>
    <StackPanel Orientation="Vertical">
        <DataGrid Grid.Row="1" ItemsSource="{Binding GridItems}"
                  Name="DataGrid1" AutoGenerateColumns="False" Height="300" >
            <DataGrid.Columns>
                <DataGridTemplateColumn>
                    <DataGridTemplateColumn.Header>
                        <Grid>
                            <Grid.RowDefinitions>
                                <RowDefinition />
                                <RowDefinition />
                            </Grid.RowDefinitions>
                            <Label Grid.Row="0" Grid.RowSpan="2" Content="てすと1" />
                        </Grid>
                    </DataGridTemplateColumn.Header>
                    <DataGridTemplateColumn.CellTemplate>
                        <DataTemplate>
                            <Grid>
                                <Grid.RowDefinitions>
                                    <RowDefinition />
                                    <RowDefinition />
                                </Grid.RowDefinitions>
                                <Label Grid.Row="0" Grid.RowSpan="2" Content="{Binding Test1}" />
                            </Grid>
                        </DataTemplate>
                    </DataGridTemplateColumn.CellTemplate>
                </DataGridTemplateColumn>
                <DataGridTemplateColumn>
                    <DataGridTemplateColumn.Header>
                        <DataGridColumnHeader>
                            <Grid>
                                <Grid.RowDefinitions>
                                    <RowDefinition />
                                    <RowDefinition />
                                </Grid.RowDefinitions>
                                <Label Grid.Row="0" Content="てすと2" />
                                <Label Grid.Row="1" Content="てすと3" />
                            </Grid>
                        </DataGridColumnHeader>
                    </DataGridTemplateColumn.Header>
                    <DataGridTemplateColumn.CellTemplate>
                        <DataTemplate>
                            <Grid>
                                <Grid.RowDefinitions>
                                    <RowDefinition />
                                    <RowDefinition />
                                </Grid.RowDefinitions>
                                <Label Grid.Row="0" Content="{Binding Test2}" />
                                <Label Grid.Row="1" Content="{Binding Test3}" />
                            </Grid>
                        </DataTemplate>
                    </DataGridTemplateColumn.CellTemplate>
                </DataGridTemplateColumn>
                <DataGridTemplateColumn>
                    <DataGridTemplateColumn.Header>
                        <Grid>
                            <Grid.RowDefinitions>
                                <RowDefinition />
                                <RowDefinition />
                            </Grid.RowDefinitions>
                            <Label Grid.Row="0" Grid.RowSpan="2" Content="コンボボックス" />
                        </Grid>
                    </DataGridTemplateColumn.Header>
                    <DataGridTemplateColumn.CellTemplate>
                        <DataTemplate>
                            <Grid>
                                <Grid.RowDefinitions>
                                    <RowDefinition />
                                    <RowDefinition />
                                </Grid.RowDefinitions>
                                <ComboBox Name="comboTest"
                                          ItemsSource="{Binding RelativeSource={RelativeSource AncestorType=Window}, Path=DataContext.ComboItems}"/>
                            </Grid>
                        </DataTemplate>
                    </DataGridTemplateColumn.CellTemplate>
                </DataGridTemplateColumn>
            </DataGrid.Columns>
        </DataGrid>
    </StackPanel>
</Window>


Class ViewModelBase
    Implements INotifyPropertyChanged

    Protected Sub RaisePropertyChanged(propertyName As String)
        RaiseEvent PropertyChanged(Me, New PropertyChangedEventArgs(propertyName))
    End Sub
    Public Event PropertyChanged(sender As Object, e As PropertyChangedEventArgs) Implements INotifyPropertyChanged.PropertyChanged
End Class

Class MainWindowViewModel
    Inherits ViewModelBase

    Public Sub New()
        Dim tmpGrid = New List(Of String)
        tmpGrid.Add("A")
        tmpGrid.Add("B")
        tmpGrid.Add("C")
        Dim tmpCombo = New List(Of String)
        tmpCombo.Add("A")
        tmpCombo.Add("B")
        tmpCombo.Add("C")
        GridItems = tmpGrid
        ComboItems = tmpCombo
    End Sub

    Private _GridItems As List(Of String)
    Public Property GridItems() As List(Of String)
        Get
            Return _GridItems
        End Get
        Set(ByVal value As List(Of String))
            _GridItems = value
            RaisePropertyChanged("GridItems")
        End Set
    End Property

    Private _ComboItems As List(Of String)
    Public Property ComboItems() As List(Of String)
        Get
            Return _ComboItems
        End Get
        Set(ByVal value As List(Of String))
            _ComboItems = value
            RaisePropertyChanged("ComboItems")
        End Set
    End Property
End Class

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2015/09/03 15:38

    参考になりました。
    ありがとうございます。

    キャンセル

0

こんにちは。

WPFとのことですが、MVVMについては理解・使用されますでしょうか。

WPFのDataGrid内に動的に生成したコンボボックスを表示させる方法が分かりません

ViewModelでDataGridのItemsSourceへバインドさせるリストを保持します。
そのそれぞれの子要素にDataGrid各行のリストボックス.ItemsSourceへバインドさせるリストを保持します。
リストボックス内容がマスタデータなどであれば、View側でDataContextを検索して別途設定します。

今時点ではこの程度の回答しかできませんので、現在どこまで実装できてどこがわからないので
提示してください。

まずはDataGridのConboBoxを表示させるところまで。
これをたたき台にやりたいことを明記して頂けると。

<Window x:Class="WpfApplication2.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:sys="clr-namespace:System;assembly=mscorlib"
        Title="MainWindow" Height="350" Width="525" Loaded="Window_Loaded">
    <Window.Resources>
        <x:Array x:Key="hogeList" Type="sys:String">
            <sys:String>1</sys:String>
            <sys:String>2</sys:String>
        </x:Array>
    </Window.Resources>
    <Grid>
        <DataGrid ItemsSource="{StaticResource hogeList}">
            <DataGrid.Columns>
                <DataGridTextColumn Header="AAA" />
                <DataGridComboBoxColumn Header="BBB" />
            </DataGrid.Columns>
        </DataGrid>
    </Grid>
</Window>

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

関連した質問

同じタグがついた質問を見る

  • WPF

    724questions

    Windows Presentation Foundation (WPF) は、魅力的な外観のユーザー エクスペリエンスを持つ Windows クライアント アプリケーションを作成するための次世代プレゼンテーション システムです

  • Visual Basic .NET

    102questions

    Microsoft Visual Basic .NET (VB.NET)とはオブジェクト志向のプログラム言語です。 Microsoft"s Visual Basic 6 のバージョンアップとしてみることができますが、Microsoft.NET Frameworktによって動かされています。