当前位置:主页>Delphi教程>文章内容
让你的DBGridEh的Column自动适应宽度
来源: 作者: 发布时间:2007-04-29  

  EhLib控件的强大表格处理能力,相信使用过的朋友都有领会,但DBGrdiEh没有发布自动根据栏宽的方法,的确是有点遗憾。

  不过还好,在DBGrdiEh的OptionsEh中,我们可以发现有个dghDblClickOptimizeColWidth选项,可以让用户在栏头的宽度调整位置上,双击鼠标以自动调整栏宽度。

  既然该功能已经实现,但却没能在DBGridEh发布的方法中找到该方法,经过笔者尝试,已经找到该方法,只要把它发布出来即可使用。具体过程如下:

  首先我们找到DBGridEh.hpp文件,并且备份,
根据dghDblClickOptimizeColWidth的线索,我们在DBGridEh.pas中全文查找该关键字,在10514行中,找到以下代码段:
//
    if (AGridState = gsColSizing) and (dghDblClickOptimizeColWidth in OptionsEh) then
      OptimizeSelectedColsWidth(Columns[ASizingIndex - IndicatorOffset])

//
  那么看来OptimizeSelectedColsWidth(TColumnEh* WithColumn)函数就是我们要的了!

  在头文件DBGridEh.hpp中查找OptimizeSelectedColsWidth函数名,在1859行找到以下声明
  void __fastcall OptimizeSelectedColsWidth(TColumnEh* WithColumn);
  它是放在protected域中,我们注释掉改行,复制,并在public域中粘帖该声明,
  于是OptimizeSelectedColsWidth就发布了。

  因为我们没有修改pas源码部分,因此,无需重新编译,即可使用。
  注意,该函数传递TColumnEh的指针,我们只要遍历DBGridEh的Column所有对象指针,即可调整完整个表格的Column宽度。

以下为使用实例:

  for(int i=0;i<sDBGridEh->Columns->Count;i++ )
    sDBGridEh->OptimizeSelectedColsWidth((TColumnEh *)sDBGridEh->Columns->Items[i]);


 
上一篇:Delphi的拨号连接类   下一篇:SQLServer中一个多用户自动生成编号的过程
 
  相关文章
·Delphi的拨号连接类
·SQLServer中一个多用户自动生成编号的
·对“网页内容查询控制”主题所得(下载
·入手自制软件背单词
·SQLServer和Oracle的常用函数对比
·动态SQL语句在SQLServer中非固定行的转
·软件注册加密技术
·来自SVG的灵感
·ComboBox的DataValue值
·实现StatusBar的Flat风格
·所见及所得的类分析跟踪器
·SQLServer中按某字段排列名次
 
【关闭窗口】
推荐本站资源
最新文章