时间:2021-05-20
本文所述实例主要实现WPF项目中C#改变DataGrid某一行和单元格颜色的功能。分享给大家供大家参考。具体方法如下:
如果要改变DataGrid某一行的颜色、高度,以及某个单元格的颜色、单元格字体的颜色,就必需取到datagrid的一行和一行的单元格,通过查找相关资料及测试总结出如下实例代码,现记录下来便于大家参考使用。
1、前台WPF界面添加一个DataGrid控件,并添加两列(便于编写,达到目的即可)
<DataGrid AutoGenerateColumns="False" Height="642" HorizontalAlignment="Left" Margin="131,57,0,0" Name="dataGrid1" VerticalAlignment="Top" Width="799" CanUserAddRows="True" LoadingRow="dataGrid1_LoadingRow" GridLinesVisibility="None"> <DataGrid.ColumnHeaderStyle > <Style TargetType="DataGridColumnHeader"> <Setter Property="Height" Value="50"></Setter> </Style> </DataGrid.ColumnHeaderStyle> <DataGrid.Columns> <DataGridTextColumn Header="id" Binding="{Binding Path=id}" ElementStyle="{StaticResource dgCell}"></DataGridTextColumn> <DataGridTextColumn Header="name" Binding="{Binding Path=name}" ElementStyle="{StaticResource dgCell}"></DataGridTextColumn> </DataGrid.Columns></DataGrid>2、创建一个数据源并绑定,此处是创建一个datatable
DataTable dt = new DataTable();dt.Columns.Add(new DataColumn("id", typeof(int)));dt.Columns.Add(new DataColumn("name", typeof(string)));for (int i = 0; i < 6; i++){ DataRow dr = dt.NewRow(); if (i == 3) { dr["id"] = DBNull.Value; dr["name"] = DBNull .Value ; dt.Rows.Add(dr); } else { dr["id"] = i; dr["name"] = "tom" + i.ToString(); dt.Rows.Add(dr); }}this.dataGrid1.CanUserAddRows = false;this.dataGrid1.ItemsSource = dt.DefaultView;3、获取单行
for (int i = 0; i < this.dataGrid1.Items.Count; i++){ DataRowView drv = dataGrid1.Items[i] as DataRowView; DataGridRow row = (DataGridRow)this.dataGrid1.ItemContainerGenerator.ContainerFromIndex(i); if (i == 2) { row.Height = 50; row.Background = new SolidColorBrush(Colors.Blue); drv["id"] = 333; } if (drv["id"] == DBNull.Value) { row.Background = new SolidColorBrush(Colors.Green); row.Height = 8; }}4、获取单元格
for (int i = 0; i < this.dataGrid1.Items.Count; i++){ DataRowView drv = dataGrid1.Items[i] as DataRowView; DataGridRow row = (DataGridRow)this.dataGrid1.ItemContainerGenerator.ContainerFromIndex(i); if (i == 4) { DataGridCellsPresenter presenter = GetVisualChild<DataGridCellsPresenter>(row); DataGridCell cell = (DataGridCell)presenter.ItemContainerGenerator.ContainerFromIndex(1); cell.Background = new SolidColorBrush(Colors.Red); }}public static T GetVisualChild<T>(Visual parent) where T : Visual{ T childContent = default(T); int numVisuals = VisualTreeHelper.GetChildrenCount(parent); for (int i = 0; i < numVisuals; i++) { Visual v = (Visual)VisualTreeHelper.GetChild(parent, i); childContent = v as T; if (childContent == null) { childContent = GetVisualChild<T>(v); } if (childContent != null) { break; } } return childContent;}5、如果在项目中把创建数据源、绑定数据源、对datagrid进行操作(改变行的颜色、高度)都写在一个事件中,其中在取datagrid的row时出现错误:未将对象引用设置到对象的实例。
解决的方法:
//创建数据源、绑定数据源 if (!Window.GetWindow(dataGrid1).IsVisible){ Window.GetWindow(dataGrid1).Show();}dataGrid1.UpdateLayout();//可以获取某一行、某一行的单元格相信本文所述对大家的C#程序设计有一定的借鉴作用。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
excel表格标题居中的方法是: 1、新建excel表格,简单制作一份表格; 2、选择第一行单元格,进行合并单元格操作; 3、在合并单元格中输入标题;
标记的属性用于设定表格中某一单元格的属性。表格的标记属性属性描述ALIGN单元格内容的水平对齐VALIGN单元格内容的垂直对齐BGCOLOR单元格的背景颜色BA
excel单元格c4表示C列第4行的单元格。单元格属于MicrosoftExcelWPS表格中使用的术语。 MicrosoftExcel是Microsoft为
以Excel为例,合并单元格要选中两个或多个位于同一行或者同一列的单元格并合并成一个单元格。 MicrosoftExcel是Microsoft为使用Windo
以excel为例,单元格地址是指单元格在工作表中的位置。由列标和行标组成,比如第一列第一行为A1。 单元格是表格中行与列的交叉部分,它是组成表格的最小单位,可