0

コードを介して ItemsSource-Property を設定することによって追加される列を示す Datagrid があります。XAML によって追加される 2 つの列もあります (ボタンと、グリッド内のイメージとボタンの組み合わせ)。今、いくつかのセルを編集していて、それらを読みたいと思っています。Windows フォームでは特定のセルを読み取ることができましたが、これは WPF では不可能であるか、推奨されていません。したがって、SelectedItem-Binding を使用したいと考えています。私の問題は、SelectedItem が常に null であることです。列の「混合追加」が原因で Datagrid に問題があるか、何か間違ったことをしている可能性があります。

ここに私のコードの一部があります:

XAML:

 <DataGrid AutoGenerateColumns="True" Margin="12,162,12,12" Name="dgExisting" CanUserAddRows="False" RowHeight="24" VerticalGridLinesBrush="#50000000" HorizontalGridLinesBrush="#50000000" SelectionMode="Single" CellStyle="{StaticResource DataGridCell_Centering}" CellEditEnding="dgExisting_CellEditEnding" SelectedItem="{Binding SelectedItem, Mode=TwoWay}">            
        <DataGrid.Columns>
            <DataGridTemplateColumn Header="Password" Width="60" IsReadOnly="True">
                <DataGridTemplateColumn.CellTemplate>                        
                    <DataTemplate>
                        <Button Style="{StaticResource Flat}" Click="btnDgChangePassword_Click">
                            <Grid>
                                <Image Source="{Binding imgStatus}" Margin="0,0,0,0" HorizontalAlignment="Left" VerticalAlignment="Top"/>
                                <Label Content="{Binding PasswordState}" Margin="16,-5,0,0" HorizontalAlignment="Left" VerticalAlignment="Top" Height="25" />
                            </Grid>
                        </Button>
                    </DataTemplate>
                </DataGridTemplateColumn.CellTemplate>
            </DataGridTemplateColumn>
            <DataGridTemplateColumn Header="Delete" Width="50" IsReadOnly="True">
                <DataGridTemplateColumn.CellTemplate>
                    <DataTemplate>
                        <Button Click="btnDgRemove_Click" Style="{StaticResource Flat}">
                            <Image Source="Images/redcross16.png" />
                        </Button>
                    </DataTemplate>
                </DataGridTemplateColumn.CellTemplate>
            </DataGridTemplateColumn>
        </DataGrid.Columns>
    </DataGrid>

そして、コードで列を追加する方法のコード:

//Create Table for Gridview
DataTable dtList = new DataTable();
dtList.Columns.Add(new DataColumn("Username"));
dtList.Columns.Add(new DataColumn("PasswordState"));
dtList.Columns.Add(new DataColumn("Domain"));
dtList.Columns.Add(new DataColumn("Description"));
dtList.Columns.Add(new DataColumn("id"));

foreach (UserCredential uc in credentialList)
{
    DataRow dR = dtList.NewRow();                
    dR["Username"] = uc.getUsername();
    dR["PasswordState"] = (uc.getPassword().Length > 0 ? "yes":"no");
    dR["Domain"] = uc.getDomain();
    dR["Description"] = uc.getDescription();
    dR["id"] = uc.getId();

    dtList.Rows.Add(dR);
}

dtList.Columns.Add("imgStatus");

for (int i = 0; i < dtList.Rows.Count; i++)
{
    dtList.Rows[i]["imgStatus"] = (dtList.Rows[i]["PasswordState"].ToString() == "yes" ? "Images/key16.png" : "");
}

dgExisting.ItemsSource = dtList.DefaultView;
dgExisting.Columns[getColumnId("Password")].DisplayIndex = 2; //reorder Key-Image
dgExisting.Columns[getColumnId("PasswordState")].Visibility = System.Windows.Visibility.Hidden; 
dgExisting.Columns[getColumnId("imgStatus")].Visibility = System.Windows.Visibility.Hidden; 
dgExisting.Columns[getColumnId("id")].Visibility = System.Windows.Visibility.Hidden; 
4

1 に答える 1

1

C# コードでは、DataGrid の項目ソースへのバインディングを作成していません。

dgExisting.ItemsSource = dtList.DefaultView;

バインディングではありません。これが、XAML バインディングで SelectedItem が常に null である理由です。コードでバインディングを作成するには、次のようにする必要があります。

var binding = new Binding("ItemsSource");
binding.Source = dtList.DefaultView;
dgExisting.SetBinding(DataGrid.ItemsSourceProperty, binding);

C# でバインディング WPF を設定するのは少し臭いです。やらないといけない理由があるのか​​もしれません。ただし、XAML でバインディングを設定できるように、アプリケーションを再設計して MVVM パターンによりよく従うことをお勧めします。

于 2012-06-08T17:48:58.067 に答える