delphi 更改DBGrid 颜色技巧

页面导航:首页 > 软件编程 > Delphi > delphi 更改DBGrid 颜色技巧

delphi 更改DBGrid 颜色技巧

来源: 作者: 时间:2016-01-18 15:41 【

1、根据条件更改某一单元格的颜色[delphi]procedure TMainFrm.First_DGDrawColumnCell(Sender: TObject; const Rect: TRect; DataCol: Integer; Column: TColumn; State: TGridDrawState);begin if ...

1、根据条件更改某一单元格的颜色


[]
procedure TMainFrm.First_DGDrawColumnCell(Sender: TObject; 
  const Rect: TRect; DataCol: Integer; Column: TColumn; 
  State: TGridDrawState); 
begin 
  if DM.FirstListStatus.AsString='生产' then begin 
     First_DG.Canvas.Font.Color:=clGreen 
   end 
  else begin 
     First_DG.Canvas.Font.Color:=clRed; 
  end; 
  if DataCol = 4 then 
     First_DG.DefaultDrawColumnCell(Rect,DataCol,Column,State); 
end; 

procedure TMainFrm.First_DGDrawColumnCell(Sender: TObject;
  const Rect: TRect; DataCol: Integer; Column: TColumn;
  State: TGridDrawState);
begin
  if DM.FirstListStatus.AsString='生产' then begin
     First_DG.Canvas.Font.Color:=clGreen
   end
  else begin
     First_DG.Canvas.Font.Color:=clRed;
  end;
  if DataCol = 4 then
     First_DG.DefaultDrawColumnCell(Rect,DataCol,Column,State);
end;

2、多种改变方式


[delphi]
<SPAN style="COLOR: #000000">procedure TMainForm.DBGrid1DrawColumnCell(Sender: TObject; 
  const Rect: TRect; DataCol: Integer; Column: TColumn;State: TGridDrawState); 
var i :integer; 
begin 
  if gdSelected in State then Exit; 
//定义表头的字体和背景颜色:  
    for i :=0 to (Sender as TDBGrid).Columns.Count-1 do 
    begin 
      (Sender as TDBGrid).Columns[i].Title.Font.Name :='宋体'; //字体  
      (Sender as TDBGrid).Columns[i].Title.Font.Size :=9; //字体大小  
      (Sender as TDBGrid).Columns[i].Title.Font.Color :=$000000ff; //字体颜色(红色)  
      (Sender as TDBGrid).Columns[i].Title.Color :=$0000ff00; //背景色(绿色)  
    end; 
//隔行改变网格背景色:  
  if Query1.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 := $0000ff00; //定义画笔颜色(绿色)  
    MoveTo(Rect.Right, Rect.Top); //画笔定位  
    LineTo(Rect.Right, Rect.Bottom); //画绿色的竖线  
  end; 
end;</SPAN> 

procedure TMainForm.DBGrid1DrawColumnCell(Sender: TObject;
  const Rect: TRect; DataCol: Integer; Column: TColumn;State: TGridDrawState);
var i :integer;
begin
  if gdSelected in State then Exit;
//定义表头的字体和背景颜色:
    for i :=0 to (Sender as TDBGrid).Columns.Count-1 do
    begin
      (Sender as TDBGrid).Columns[i].Title.Font.Name :='宋体'; //字体
      (Sender as TDBGrid).Columns[i].Title.Font.Size :=9; //字体大小
      (Sender as TDBGrid).Columns[i].Title.Font.Color :=$000000ff; //字体颜色(红色)
      (Sender as TDBGrid).Columns[i].Title.Color :=$0000ff00; //背景色(绿色)
    end;
//隔行改变网格背景色:
  if Query1.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 := $0000ff00; //定义画笔颜色(绿色)
    MoveTo(Rect.Right, Rect.Top); //画笔定位
    LineTo(Rect.Right, Rect.Bottom); //画绿色的竖线
  end;
end;

 

 

3、纵向斑马线效果:实现网格的奇数列和偶数列分别以不同的颜色显示以区别相邻的数据列。


[delphi]
Case DataCol Mod 2 = 0 of 
  True: DbGrid1.Canvas.Brush.Color:= clBlue; file://偶数列用蓝色  
 False: DbGrid1.Canvas.Brush.Color:= clAqua; file://奇数列用浅绿色  
End; 
DbGrid1.Canvas.Pen.Mode:=pmMask; 
DBGrid1.DefaultDrawColumnCell(Rect,DataCol,Column,State); 

Case DataCol Mod 2 = 0 of
  True: DbGrid1.Canvas.Brush.Color:= clBlue; file://偶数列用蓝色
 False: DbGrid1.Canvas.Brush.Color:= clAqua; file://奇数列用浅绿色
End;
DbGrid1.Canvas.Pen.Mode:=pmMask;
DBGrid1.DefaultDrawColumnCell(Rect,DataCol,Column,State);

4、纵向斑马线,同时以红色突出显示当前单元格效果:以突出显示当前选中的字段。

[delphi]
Case DataCol Mod 2 = 0 of 
True: DbGrid1.Canvas.Brush.Color:= clBlue; file://偶数列用蓝色  
False: DbGrid1.Canvas.Brush.Color:= clAqua; file://奇数列用浅绿色  
End; 
If ((State = [gdSelected]) or (State=[gdSelectedgdFocused])) then 
If Not DbGrid1.SelectedRows.CurrentRowSelected then 
DbGrid1.Canvas.Brush.Color:=clRed; file://当前选中单元格显示红色  
DbGrid1.Canvas.Pen.Mode:=pmMask; 
DBGrid1.DefaultDrawColumnCell(Rect,DataCol,Column,State); 

Case DataCol Mod 2 = 0 of
True: DbGrid1.Canvas.Brush.Color:= clBlue; file://偶数列用蓝色
False: DbGrid1.Canvas.Brush.Color:= clAqua; file://奇数列用浅绿色
End;
If ((State = [gdSelected]) or (State=[gdSelectedgdFocused])) then
If Not DbGrid1.SelectedRows.CurrentRowSelected then
DbGrid1.Canvas.Brush.Color:=clRed; file://当前选中单元格显示红色
DbGrid1.Canvas.Pen.Mode:=pmMask;
DBGrid1.DefaultDrawColumnCell(Rect,DataCol,Column,State);
5、在数据网格中以红色突出显示当前选中的行。


[delphi]
设置DbGrid控件的Options属性中的dgRowSelect属性为真,Color属性为clAqua(背景色) 
在DbGrid的DrawColumnCell事件中编写如下代码: 
 
if ((State = [gdSelected]) or (State=[gdSelected gdFocused])) then 
DbGrid1.Canvas.Brush.color:=clRed; file://当前行以红色显示,其它行使用背景的浅绿色  
DbGrid1.Canvas.pen.mode:=pmmask; 
DBGrid1.DefaultDrawColumnCell(Rect,DataCol,Column,State); 

设置DbGrid控件的Options属性中的dgRowSelect属性为真,Color属性为clAqua(背景色)
在DbGrid的DrawColumnCell事件中编写如下代码:

if ((State = [gdSelected]) or (State=[gdSelected gdFocused])) then
DbGrid1.Canvas.Brush.color:=clRed; file://当前行以红色显示,其它行使用背景的浅绿色
DbGrid1.Canvas.pen.mode:=pmmask;
DBGrid1.DefaultDrawColumnCell(Rect,DataCol,Column,State);

6、行突显的斑马线效果:既突出当前行,又区分不同的列(字段)。


[delphi]
if ((State = [gdSelected]) or (State=[gdSelectedgdFocused])) then 
begin 
Case DataCol Mod 2 = 0 of 
True : DbGrid1.Canvas.Brush.color:=clRed; file://当前选中行的偶数列显示红色  
False: DbGrid1.Canvas.Brush.color:=clblue; file://当前选中行的奇数列显示蓝色  
end; 
DbGrid1.Canvas.pen.mode:=pmmask; 
DBGrid1.DefaultDrawColumnCell(Rect,DataCol,Column,State); 

if ((State = [gdSelected]) or (State=[gdSelectedgdFocused])) then
begin
Case DataCol Mod 2 = 0 of
True : DbGrid1.Canvas.Brush.color:=clRed; file://当前选中行的偶数列显示红色
False: DbGrid1.Canvas.Brush.color:=clblue; file://当前选中行的奇数列显示蓝色
end;
DbGrid1.Canvas.pen.mode:=pmmask;
DBGrid1.DefaultDrawColumnCell(Rect,DataCol,Column,State);

7、横向斑马线, 同时以红色突显当前行效果。


[delphi]
Case Table1.RecNo mod 2 = 0 of file://根据数据集的记录号进行判断  
True : DbGrid1.Canvas.Brush.color:=clAqua; file://偶数行用浅绿色显示  
False: DbGrid1.Canvas.Brush.color:=clblue; file://奇数行用蓝色表示  
end; 
if ((State = [gdSelected]) or (State=[gdSelectedgdFocused])) then file://选中行用红色显示  
DbGrid1.Canvas.Brush.color:=clRed; 
DbGrid1.Canvas.pen.mode:=pmMask; 
DBGrid1.DefaultDrawColumnCell(Rect,DataCol,Column,State); 

Case Table1.RecNo mod 2 = 0 of file://根据数据集的记录号进行判断
True : DbGrid1.Canvas.Brush.color:=clAqua; file://偶数行用浅绿色显示
False: DbGrid1.Canvas.Brush.color:=clblue; file://奇数行用蓝色表示
end;
if ((State = [gdSelected]) or (State=[gdSelectedgdFocused])) then file://选中行用红色显示
DbGrid1.Canvas.Brush.color:=clRed;
DbGrid1.Canvas.pen.mode:=pmMask;
DBGrid1.DefaultDrawColumnCell(Rect,DataCol,Column,State);

8、双向斑马线效果:即行间用不同色区分,同时,选中行以纵向斑马线效果区分不同的列。


[delphi]
Case Table1.RecNo mod 2 = 0 of file://根据数据集的记录号进行判断  
True : DbGrid1.Canvas.Brush.color:=clAqua; file://偶数行用浅绿色显示  
False: DbGrid1.Canvas.Brush.color:= clblue; file://奇数行用蓝色表示  
end; 
If ((State = [gdSelected]) or (State=[gdSelectedgdFocused])) then 
Case DataCol mod 2 = 0 of 
True : DbGrid1.Canvas.Brush.color:=clRed; file://当前选中行的偶数列用红色  
False: DbGrid1.Canvas.Brush.color:= clGreen; file://当前选中行的奇数列用绿色表示  
end; 
DbGrid1.Canvas.pen.mode:=pmMask; 
DBGrid1.DefaultDrawColumnCell(Rect,DataCol,Column,State); 

Case Table1.RecNo mod 2 = 0 of file://根据数据集的记录号进行判断
True : DbGrid1.Canvas.Brush.color:=clAqua; file://偶数行用浅绿色显示
False: DbGrid1.Canvas.Brush.color:= clblue; file://奇数行用蓝色表示
end;
If ((State = [gdSelected]) or (State=[gdSelectedgdFocused])) then
Case DataCol mod 2 = 0 of
True : DbGrid1.Canvas.Brush.color:=clRed; file://当前选中行的偶数列用红色
False: DbGrid1.Canvas.Brush.color:= clGreen; file://当前选中行的奇数列用绿色表示
end;
DbGrid1.Canvas.pen.mode:=pmMask;
DBGrid1.DefaultDrawColumnCell(Rect,DataCol,Column,State);


 

Tags:

文章评论

最 近 更 新
热 点 排 行
Js与CSS工具
代码转换工具

<