delphi - 如何获取TDBGrid列上最长条目的长度

标签 delphi datagrid datagridview tdbgrid

我有一个名为grMain的TDBGrid组件。我需要知道在grMain上检索的Column最长条目的值的长度,以调整持有g​​rMain的表单的最小宽度。

如何获取TDBGrid列上最长条目的长度?

提前致谢。

最佳答案

那样的东西...

Procedure FitGrid(Grid:TDBGrid);
Const
 C_Add=3;
var
 ds:TDataset;
 bm:TBookmark;
 i:Integer;
 w:Integer;
 a:Array of Integer;
begin
   ds := Grid.DataSource.DataSet;
   if Assigned(ds) then
      begin
        ds.DisableControls;
        bm := ds.GetBookmark;
        try

        ds.First;
        SetLength(a,Grid.Columns.Count);
        ZeroMemory(@a[0],SizeOf(Integer)*Length(a));
        while not ds.Eof do
          begin
            for I := 0 to Grid.Columns.Count - 1 do
                begin
                  if Assigned( Grid.Columns[i].Field) then
                    begin
                     w :=  Grid.Canvas.TextWidth( ds.FieldByName( Grid.Columns[i].Field.FieldName).DisplayText);
                     if a[i] < w  then a[i] := w + C_Add;
                    end;

                end;
            ds.Next;
          end;
        for I := 0 to Grid.Columns.Count - 1 do Grid.Columns[i].Width := a[i];
        ds.GotoBookmark(bm);
        finally
          ds.FreeBookmark(bm);
          ds.EnableControls;
        end;
      end;
end;

procedure TForm1.Button1Click(Sender: TObject);

begin
  FitGrid(DBgrid1)
end;

关于delphi - 如何获取TDBGrid列上最长条目的长度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15267466/

相关文章:

delphi - 在哪里可以找到每个组件的 indy 10 演示?

wpf - 将 DataGrid 绑定(bind)到 wpf 中的列表

c# - 如何将 List<string> 绑定(bind)到 DataGridView 控件?

html - 如何在 html 页面中找到带有 "value"的按钮(Webbrowser - Delphi)

delphi - 如何在Delphi中解析JSON字符串?

c# - 如何使数据网格在控件中看到编辑?

c# - 如何将绑定(bind)添加到数据网格中的列?

C# DataGridView Checkbox 勾选事件

mysql - 使用 VB.net 更改 MySQL 中表的列名

file - 如何将delphi保存到INI文件