亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C# > 正文

C#實現改變DataGrid某一行和單元格顏色的方法

2020-01-24 02:25:49
字體:
來源:轉載
供稿:網友

本文所述實例主要實現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#程序設計有一定的借鑒作用。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
精品久久久香蕉免费精品视频| 亚洲精品www久久久久久广东| 欧美日韩国产在线看| 2025国产精品视频| 亚洲精品狠狠操| 国产中文字幕日韩| 日韩专区在线播放| 欧美一级片免费在线| 国产精品专区一| 日韩一级裸体免费视频| 中文字幕亚洲一区在线观看| 色偷偷av一区二区三区| 亚洲精品一区av在线播放| 色在人av网站天堂精品| 亚洲欧美成人精品| 久久精品视频在线播放| 亚洲一区二区三区成人在线视频精品| 欧美最顶级的aⅴ艳星| 欧美成人午夜视频| 欧美一区三区三区高中清蜜桃| 国产亚洲一级高清| 欧美在线日韩在线| 欧美日韩国产精品| 懂色av影视一区二区三区| 久久久久久69| 久久免费视频在线观看| 久久中国妇女中文字幕| 伊人亚洲福利一区二区三区| 成人精品在线观看| 欧美床上激情在线观看| 欧美日韩加勒比精品一区| 国产精品直播网红| 久久久人成影片一区二区三区观看| 欧美电影免费在线观看| 97在线观看视频国产| 久久精品91久久香蕉加勒比| 自拍偷拍免费精品| 理论片在线不卡免费观看| 欧美日韩亚洲一区二区| 日韩精品免费视频| 亚洲一区二区三区四区视频| 亚洲精品永久免费精品| 98精品国产自产在线观看| 1769国内精品视频在线播放| 亚洲视频在线看| 欧美老女人性生活| 久久精品欧美视频| 国产精品99蜜臀久久不卡二区| 91中文精品字幕在线视频| 亚州成人av在线| 欧美日韩在线另类| 国产免费一区视频观看免费| 伊人一区二区三区久久精品| 一区二区三区视频观看| 国产亚洲人成a一在线v站| 国产精品一区电影| 亚洲综合在线做性| 亚洲三级 欧美三级| 久久久久久久久久婷婷| 欧美激情视频三区| 国产精品视频99| 欧美日韩成人在线播放| 插插插亚洲综合网| 精品久久久久久中文字幕| 日韩在线视频观看正片免费网站| 亚洲天堂网站在线观看视频| 国产精品一区二区三区毛片淫片| 国产欧美日韩综合精品| 91久久精品视频| 欧美在线视频免费播放| 久久成年人视频| 成人精品视频99在线观看免费| 国产精品男女猛烈高潮激情| 国产精品永久免费观看| 国产成人中文字幕| 亚洲午夜av久久乱码| 国产日本欧美一区二区三区| 精品福利免费观看| 欧美电影免费观看电视剧大全| 亚洲欧美激情精品一区二区| 亚洲伦理中文字幕| 欧洲永久精品大片ww免费漫画| 国产在线精品播放| 成人免费视频97| 亚洲精品网站在线播放gif| 欧美日韩在线另类| 一区二区亚洲精品国产| 国产精品亚洲аv天堂网| 91sa在线看| 欧美日韩国产精品一区二区不卡中文| 亚洲成**性毛茸茸| 96国产粉嫩美女| 精品电影在线观看| 国产又爽又黄的激情精品视频| 亚洲成av人乱码色午夜| 亚洲精品视频播放| 久久在线观看视频| 欧美丰满老妇厨房牲生活| 日韩av中文字幕在线播放| 成人国产精品久久久久久亚洲| 亚洲另类图片色| 国产a∨精品一区二区三区不卡| 国产xxx69麻豆国语对白| 高清日韩电视剧大全免费播放在线观看| 一本一本久久a久久精品牛牛影视| 日韩美女写真福利在线观看| 日韩精品视频在线观看免费| 青青在线视频一区二区三区| 国产精品成av人在线视午夜片| 国产一区二区在线播放| 亚洲一区二区免费在线| 亚洲日韩欧美视频| 日韩成人久久久| 91精品国产高清久久久久久91| 久久久久久国产精品三级玉女聊斋| 欧美最猛性xxxx| 欧美日本黄视频| 久久久久久91香蕉国产| 欧美日韩成人黄色| 日本精品久久久久影院| 亚洲精品久久久久久久久久久久| 久久99国产精品自在自在app| 麻豆国产精品va在线观看不卡| 国产大片精品免费永久看nba| 国产国语videosex另类| 久久久免费精品视频| 日韩精品久久久久久福利| 欧美激情一区二区三区成人| 色综合老司机第九色激情| 欧美裸体男粗大视频在线观看| 性色av一区二区咪爱| 欧美一区二区大胆人体摄影专业网站| 亚洲国产精品久久久久秋霞不卡| 欧美巨大黑人极品精男| 97免费视频在线播放| 萌白酱国产一区二区| 欧美日韩亚洲网| 爱福利视频一区| 精品美女永久免费视频| 在线视频欧美日韩精品| 国产深夜精品福利| 欧美视频精品一区| 少妇高潮久久久久久潘金莲| 全亚洲最色的网站在线观看| 91亚洲精品一区| 色婷婷av一区二区三区在线观看| 中国日韩欧美久久久久久久久| 欧美极品少妇xxxxⅹ裸体艺术| 日韩精品在线影院| 成人精品视频久久久久| 国产中文字幕日韩| 欧美—级a级欧美特级ar全黄| 91高潮在线观看| 精品调教chinesegay| 国产精品国产三级国产专播精品人| 国产主播喷水一区二区| 国产精品久久久久久久久久东京| 亚洲永久在线观看| 久久久久久97| 中文字幕亚洲欧美在线| 久久成人这里只有精品| 欧美激情精品久久久久久蜜臀| 7777kkkk成人观看| 日本高清不卡在线|