DBGridEH根据某一字段不同值显示不同的行颜色

本文介绍如何在Delphi应用中利用DBGridEH控件,根据数据库中特定字段的值来动态设置表格行的颜色。通过读取test_color表中的颜色值并结合SQL查询,实现在表格中展示不同状态时的定制颜色效果。程序中包含异常处理,并提供了程序运行界面的截图。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

以下是程序具体的代码:

 

procedure TFrm_test.dbeh_1DrawColumnCell(Sender: TObject;
  const Rect: TRect; DataCol: Integer; Column: TColumnEh;
  State: TGridDrawState);
var
    strColor    :String;
    BkColor     :TColor;
begin
    Try
        strColor:=trim(qry_Renew.FieldByName('颜色值').AsString);
        if(strColor='') then exit;
        BkColor:=stringtocolor(strColor);  //读取数据库表里的颜色值
        (Sender as TDBGridEh).Canvas.Brush.Color:=BkColor;

        with dbeh_1 do   //显示数据的DBGridEh
        begin
           if (gdSelected in State) then   //如果某行被选中
            begin
              Canvas.Brush.Color:= StringToColor('$00E7E6BE'); //背景色
              Canvas.Font.Color:= clBlack; //字体色
            end
            else  //其他没被选中的行按各自指定的颜色去显示
            begin
              Canvas.Brush.Color:=BkColor;
            end;
            DefaultDrawcolumnCell(rect,DataCol,Column,State);
        end;
    Except
    On E:Exception Do
        begin
            MessageBox(Handle,PChar(E.Message),'失败...',MB_ICONSTOP) ;
            exit;
        end;
    End;
end;

 

 

     在我的这个例子里,我用test_main这个表保存记录的具体信息,在test_color表里保存记录的状态(这个是用户手动设定的,然后更新到一个下拉列表中去,在用户插入记录时可选择)和不同状态对应的颜色值。根据当前状态的不同去设置各行不同的颜色。
在qry_Renew里写如下的SQL语句:
Select A.Name,A.ID,A.Time,A.Status,B.颜色值 from test_main as A,test_color as B  Where A.Status=B.Status

感谢程序人生给我提供的帮助,我现在将知识分享给大家,希望对大家有所帮助!



最后提供程序界面的截图:

 

see Yizero by yizero.com

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值