在DBGrid中有多条记录.
我怎样才能在鼠标或光标移动到某一条记录上的时候,该条记录会自动变成其它颜色,离开时又恢复原来的颜色

解决方案 »

  1.   

    在DBGrid的OnDrawColumnCell事件中写代码,如: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:=clred;
      DBGrid1.Canvas.pen.Color:=clyellow;
      DBGrid1.DefaultDrawColumnCell(Rect,DataCol,Column,State);
      end;
    end;
      

  2.   

    在CSDN里搜索一下,会找到一大把答案
      

  3.   

    按pilicat 所说的去做,只有光标移到的地方才会变颜色..但同一条记录的其它字段不会变的.
    有没有办法整条记录的字段同时变呢??? 
    刚学,所以不懂请指教~~谢谢
      

  4.   

    在DBGRID的OPTION里选中ROWSELECTED为TRUE。就行了。
      

  5.   

    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;