如和在delphi dbgrid 中改变整行颜色,也就是说分单行和双行颜色?谢谢,我先在打开ONDrawColumnCell事件里面什么都没有,该写写什么代码?谢谢
解决方案 »
- 一些概念
- 联通的短信开发
- 请教大侠:ado+access,数据库里面单精度类型,我设置了小数位数为两位。可是读到dbgrid里面后,小数有一长串!请问如何去掉?
- 这个问题你遇见过吗?一个关于ADOQuery 的SQL参数问题。急!!!
- 有这种经验的同志进来拿分吧。
- 访问SQL数据库的问题
- 这个想法应该怎么来实现? ************ 在线等 *************
- 有个关于随机数的大家以前可能都没有见过的问题
- WINDOWS的DrawFocusRect功能是怎么样实现的?
- 如何实现两库字段内容修改?
- SOCKET编程问题,如何从一台计算机上COPY一个文件到另外一台计算机上?用DELPHI的SOCKET控件如何实现?
- 如何自动生成字段编号
// DBGrid1的OnDrawColumnCell事件
if ((State = [gdSelected]) or (State=[gdSelected,gdFocused])) then
begin
DBGrid1.Canvas.Font.Color :=ClYellow;
DBGrid1.Canvas.Brush.Color :=clblue; //关键
DBGrid1.DefaultDrawColumnCell(Rect,DataCol,Column,State);
end;
DBGrid1.Canvas.Font.Color :=ClYellow;//字体颜色,可以改成你想要的
DBGrid1.Canvas.Brush.Color :=clblue; //背景颜色,可以改成你想要的
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
Dialogs, Grids, DBGrids, DB, DBTables;type
TForm1 = class(TForm)
DBGrid1: TDBGrid;
DataSource1: TDataSource;
Query1: TQuery;
procedure DBGrid1DrawColumnCell(Sender: TObject; const Rect: TRect;
DataCol: Integer; Column: TColumn; State: TGridDrawState);
private
{ Private declarations }
public
{ Public declarations }
end;var
Form1: TForm1;implementation{$R *.dfm}procedure TForm1.DBGrid1DrawColumnCell(Sender: TObject; const Rect: TRect;
DataCol: Integer; Column: TColumn; State: TGridDrawState);
begin
if (query1.RecNo mod 2)=1 then
begin
with (Sender as TDbGrid).Canvas do
begin
Brush.Color:=$00FFFFC1;
FillRect(Rect);
end;
end;
(Sender as TDbGrid).DefaultDrawColumnCell(Rect,DataCol,Column,State);
end;end.
begin
if gdSelected in State then Exit; //隔行改变网格背景色:
if adoQuery1.RecNo mod 2 = 0 then
(Sender as TDBGrid).Canvas.Brush.Color := clinfobk //定义背景颜色
else
(Sender as TDBGrid).Canvas.Brush.Color := RGB(191, 255, 223); //定义背景颜色 //定义网格线的颜色:
DBGrid1.DefaultDrawColumnCell(Rect,DataCol,Column,State);
with (Sender as TDBGrid).Canvas do //画 cell 的边框
begin
Pen.Color := $00ff0000; //定义画笔颜色(蓝色)
MoveTo(Rect.Left, Rect.Bottom); //画笔定位
LineTo(Rect.Right, Rect.Bottom); //画蓝色的横线
Pen.Color := clbtnface; //定义画笔颜色(兰色)
MoveTo(Rect.Right, Rect.Top); //画笔定位
LineTo(Rect.Right, Rect.Bottom); //画绿色
end;
DataCol: Integer; Column: TColumn; State: TGridDrawState);
begin
if adoquery1.RecNo mod 2=1 then
begin
dbgrid1.Canvas.Brush.Color:=clMoneyGreen;
end
else
begin
dbgrid1.Canvas.Brush.Color:=clSkyBlue;
end;
dbgrid1.DefaultDrawColumnCell(rect,datacol,column,state);
end;
隔行换色,我在用.
==============================================汗^^^^^^^^^^^^^^^^^^是你的数据库控件
你DBGrid里的数据是从哪里来的?
你用什么查询数据的?table还是query?
用那个,就把它改成那个.
如:SELECT rownum,CNDZD.* FROM CNDZD
procedure TFYHDZD1.DBGridEh1DrawColumnCell(Sender: TObject;
const Rect: TRect; DataCol: Integer; Column: TColumnEh;
State: TGridDrawState);
begin
if Frac(Query1.fieldbyname('rownum').value/2)=0 then
begin
DBGridEh1.Canvas.Brush.Color:=$00DDF5FF;
DBGridEh1.Canvas.Font.Color:=clWindowText;
end;
DBGridEh1.DefaultDrawColumnCell(rect,datacol,column,state);
end;