質問

Silverlightでデータグリッド列を動的に作成およびバインドできることがわかりました。ただし、これらの列にデータをバインドする方法が見つかりません。

AutoGenerateColumns = trueで任意のタイプのオブジェクトをバインドしようとすると、オブジェクトの各プロパティの名前が列として追加され、データを表示しない既存の列に加えてオブジェクト情報がグリッドに表示されます。

AutoGenerateColumns = falseでリストを適用すると、テーブルには行が表示されますが、列にはデータが表示されません。

datagirdにデータを表示する必要があるケースごとに特定のオブジェクトを作成したくない。

列の名前をプロパティの名前に制限したくない、たとえばスペースのない名前。

リストまたは辞書配列をデータグリッドにバインドできるようにしたい。また、どの列にどのデータを表示するかを制御できるようにしたいです。

役に立ちましたか?

解決

情報をバインドするクラスまたは他のコンテナがあると仮定すると、次のことができます。

DataGridTextColumn product = new DataGridTextColumn();
                product.Binding = new System.Windows.Data.Binding("Product");
                product.Header = "Product";

                DataGridTextColumn date = new DataGridTextColumn();
                date.Binding = new System.Windows.Data.Binding("Date");
                date.Header = "Date";

                DataGridTextColumn version = new DataGridTextColumn();
                version.Binding = new System.Windows.Data.Binding("FileVersion");
                version.Header = "Version";

                DataGridTextColumn timestamp = new DataGridTextColumn();
                timestamp.Header = "TimeStamp";
                timestamp.Binding = new System.Windows.Data.Binding("TimeStamp");

                DataGridTextColumn user = new DataGridTextColumn();
                user.Header = "User";
                user.Binding = new System.Windows.Data.Binding("User");

                rpdata.Columns.Add(product);
                rpdata.Columns.Add(date);
                rpdata.Columns.Add(version);
                rpdata.Columns.Add(timestamp);
                rpdata.Columns.Add(user);

データグリッドのitemsourceを、お持ちのアイテムのコレクションに設定するだけです。

これにより、表示するヘッダーを設定できます。また、情報をコンテナ内の変数にバインドするため、追加した列のみの情報が表示されます。

他のヒント

おそらくほぼそこにいますが、xamlに微妙な問題があるだけです。実際の例を次に示します。

<UserControl x:Class="Testproject.EditableDataGrid"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 
    xmlns:data="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Data"
    Width="400" Height="300">
    <Grid x:Name="LayoutRoot" Background="White">
        <data:DataGrid x:Name="myDataGrid" AutoGenerateColumns="False"> 
            <data:DataGrid.Columns>
                <data:DataGridTextColumn Header="My text" Binding="{Binding StringValue}" />
                <data:DataGridCheckBoxColumn Header="Check Box" Binding="{Binding IsChecked}" />
                <data:DataGridTemplateColumn Header="A template column">
                    <data:DataGridTemplateColumn.CellTemplate>
                    <DataTemplate>
                        <StackPanel Orientation="Horizontal">
                            <Rectangle Width="20" Height="5" Fill="Red"/>
                            <TextBlock Text="{Binding IntValue}" />
                        </StackPanel>
                    </DataTemplate>
                </data:DataGridTemplateColumn.CellTemplate>

            </data:DataGridTemplateColumn>
                <data:DataGridTextColumn Header="My int" Binding="{Binding IntValue}" />
            </data:DataGrid.Columns>
        </data:DataGrid>
    </Grid>
</UserControl>

using System.Windows;
using System.Windows.Controls;
using System.Collections.Generic;

namespace Testproject
{
    public partial class EditableDataGrid   :UserControl
    {
        public EditableDataGrid()
        {
            InitializeComponent();

            myDataGrid.ItemsSource = new List<ClassForDataGridTest>()
                            {
                                new ClassForDataGridTest() {StringValue="hello", IntValue=21, IsChecked=false}
                                , new ClassForDataGridTest() {StringValue="the second", IntValue=122, IsChecked = true}
                            };
        }
    }

    public class ClassForDataGridTest   : DependencyObject
    {

        public string StringValue {get; set;}

        public int IntValue {get; set;}

        public bool IsChecked { get; set; }

    }
}
ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top