1.如何改变单个网格的颜色?
2.单击一个网格,如何判断该网格是在第几行第几列?
3.还有DBGRID导入数据时列宽老是自动改变,能固定死它吗?

解决方案 »

  1.   

    我用的时ADOTABLE连接ACCESS数据库
      

  2.   

    3、可以在ADOTABLE的afteropen事件里用代码控制,也可以设计时生成字段来设置
      

  3.   


       以下的示例程序演示了对 DBGrid 各属性的设置,使 Delphi 显示的表格就像网页中的表格一样漂亮美观。
       示例程序的运行:
       在 Form1 上放置 DBGrid1、Query1、DataSource1 三个数据库组件,设置相关的属性,使 DBGrid1 能显示表中的数据。然后,在 DBGrid1 的 onDrawColumnCell 事件中键入以下代码,然后运行程序,就可以看到神奇的结果了。本代码在 Windows98、Delphi5.0 环境下调试通过。
    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; 
    隔行改变DBGrid网格颜色 
       在 Form1 上放置 DBGrid1、Query1、DataSource1 三个数据库组件,设置相关的属性,使 DBGrid1 能显示表中的数据。然后,在 DBGrid1 的 onDrawColumnCell 事件中键入以下代码,然后运行程序代码:
    procedure TForm1.DBGrid1DrawColumnCell(Sender: TObject; const Rect: TRect;
    DataCol: Integer; Column: TColumn; State: TGridDrawState);var i:integer;
    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;
    end;用BDE中的table1未能通过,颜色没有隔行变化。