AABBbaby

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

DevExpress WinForm界面开发技巧放送:GridView - 在EditForm中更改BackColor

点击获取DevExpress完整版下载

DevExpress技术交流群3:700924826      欢迎一起进群讨论

DevExpress WinForms拥有180+组件和UI库,能为Windows Forms平台创建具有影响力的业务解决方案。DevExpress WinForms能完美构建流畅、美观且易于使用的应用程序,无论是Office风格的界面,还是分析处理大批量的业务数据,它都能轻松胜任!

DevExpress WinForms
问题

假设在GridView中动态更改RowCell的颜色:

C#

private void GridView_RowCellStyle(object sender, RowCellStyleEventArgs e)
{
// ... some logic
e.Appearance.BackColor = Color.FromArgb(98, 182, 204, 252);
// ... other logic
}

需要在相应的编辑表单控件中使用相同的BackColor。有必要使用EditFormPrepared事件并更改e.BindableControls [column] .BackColor属性,但我想了解如何获取列样式。

解决方案

任务是获取相应列单元格的颜色,建议创建一个方法,该方法实现RowCellStyle逻辑来计算单元格颜色并将其在EditFormPrepared事件处理程序中使用。下面的代码说明了此方法:

C#

private void GridView1_EditFormPrepared(object sender, EditFormPreparedEventArgs e) {
GridView view = sender as GridView;
foreach (GridColumn c in view.VisibleColumns) {
e.BindableControls[c].BackColor = GetColor(c, e.RowHandle, view.GetRowCellValue(e.RowHandle, c));
}
}
private void GridView1_RowCellStyle(object sender, RowCellStyleEventArgs e) { 
e.Appearance.BackColor = GetColor(e.Column, e.RowHandle, e.CellValue); 
}
Color GetColor(GridColumn column, int rowHandle, object value) {
if (rowHandle != 0)
return Color.Empty;
//your logic
if (column.FieldName == "Name")
return Color.Green;
return Color.Red;
}

上DevExpress中文网,获取第一手最新产品资讯!

posted on   AABBbaby  阅读(191)  评论(0编辑  收藏  举报

编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
历史上的今天:
2020-04-27 现代Web开发堆栈工具DevExtreme——增强图表/文件管理器功能
点击右上角即可分享
微信分享提示