怎么样在使Dbgrid的行的颜色阁一行一种颜色,请高手指点迷津。

解决方案 »

  1.   

    procedure TForm1.DBGrid1DrawDataCell(Sender: TObject; const Rect: TRect;
      Field: TField; State: TGridDrawState);
    begin
      for i:= query.recodcount-1 do
      begin
        if i mod 2=0 then
          SetBkColor(dbgrid1.canvas.handle,clred)
        else
          SetBkColor(dbgrid1.canvas.handle,clred);
        dbgrid1.Canvas.TextRect(rect,0,0,field.AsString);
        dbgrid1.Canvas.Textout(rect.Left,rect.Top,field.
      

  2.   

    // 在OnDrawColumnCell事件中
    procedure TForm1.DBGrid1DrawColumnCell(Sender: TObject;
      const Rect: TRect; DataCol: Integer; Column: TColumn;
      State: TGridDrawState);
    begin
      with DBGrid1.Canvas do
      if (DBGrid1.MouseCoord(Rect.Left+1, Rect.Top+1).Y mod 2) = 1 then
        Brush.Color := clBlue  // 奇数行为蓝色
      else
        Brush.Color := clRed;  // 偶数行为红色
      DBGrid1.DefaultDrawColumnCell(Rect, DataCol, Column, State);
    end;
    // 在相对应的Query的AfterScroll事件中
    procedure TForm1.Query1AfterScroll(DataSet: TDataSet);
    begin
      DBGrid1.Invalidate;  // 滚动时刷新grid
    end;
      

  3.   

    procedure TForm1.DBGrid1DrawColumnCell(Sender: TObject; const Rect: TRect;
      DataCol: Integer; Column: TColumn; State: TGridDrawState);
    begin
      if( gdSelected in State)then
      //如果是被选中的  
      begin
        DBGrid1.Canvas.Brush.Color:=clBlue;
        //选中的背景色为clBlue
        DBGrid1.Canvas.Font.Color:=clYellow;
        //选中的字体颜色为clYellow
      end
      else
      if dbgrid1.DataSource.DataSet.RecNo mod 2=1 then
         //用self.DataSource1.DataSet.RecNo mod 2
         //来判断行数产生隔行
        DbGrid1.Canvas.Brush.Color:=clRed
      else 
        DBGrid1.CanVas.Brush.Color:=clWhite;
      
      DBGrid1.DefaultDrawcolumnCell(rect,DataCol,Column,State);
      //其他默认
    end;
      

  4.   

    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;