我有一个 DBGrid,每次使用水平滚动条时都需要运行一些代码。我在 DBGrid 中找不到这样的事件。你能给点建议吗?
问问题
10961 次
4 回答
6
TCustomGrid 中有一个 WMHScroll 过程,但它是私有的。您不能在 DBGrid 中使用它。
您必须创建自己的 TDBGrid 后代并自己做
procedure WMHScroll(var Msg: TWMHScroll); message WM_HSCROLL;
或者做一些非常糟糕的黑客行为......
更新:诡计/黑客将您的代码潜入...
[...]
uses
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
Dialogs, DB, ADODB, Grids, DBGrids;
type
// Hack to redeclare your TDBGrid here whitout the the form designer going mad
TDBGrid = class(DBGrids.TDBGrid)
procedure WMHScroll(var Msg: TWMHScroll); message WM_HSCROLL;
end;
TForm8 = class(TForm)
DBGrid1: TDBGrid;
DataSource1: TDataSource;
ADODataSet1: TADODataSet;
ADOConnection1: TADOConnection;
private
{ Private declarations }
public
{ Public declarations }
end;
var
Form8: TForm8;
implementation
{$R *.dfm}
{ TDBGrid }
procedure TDBGrid.WMHScroll(var Msg: TWMHScroll);
begin
case Msg.ScrollCode of
SB_ENDSCROLL: OutputDebugString('SB_ENDSCROLL') ;
SB_LEFT:OutputDebugString('SB_LEFT');
SB_RIGHT:OutputDebugString('SB_RIGHT');
SB_LINELEFT:OutputDebugString('SB_LINELEFT');
SB_LINERIGHT:OutputDebugString('SB_LINERIGHT');
SB_PAGELEFT:OutputDebugString('SB_PAGELEFT');
SB_PAGERIGHT:OutputDebugString('SB_PAGERIGHT');
SB_THUMBPOSITION:OutputDebugString('SB_THUMBPOSITION');
end;
inherited; // to keep the expected behavior
end;
[...]
更新2 :请注意,您可以将您的特殊 TDBGrid 代码移动到一个单独的单元(推荐),只需确保将此单元名称放在DBGrids之后的 Form 的 uses 子句中。
于 2009-11-12T19:00:09.177 回答
5
也许这会有所帮助。它显示了一个捕获常规 TStringGrid 的滚动事件的示例。同步两个 TStringgrids 的滚动?
于 2009-11-12T18:08:10.393 回答
1
编辑:显然是错误的答案。它捕捉垂直滚动条,但不捕捉水平滚动条。
您不会在 DBGrid 级别捕获它。您在附加的 TDataSet 的 BeforeScroll 或 AfterScroll 处捕获它。它使用 DBGrid 中出现的滚动条、向上和向下箭头键、向上和向下翻页键等触发。
于 2009-11-12T18:12:18.167 回答
0
我现在无法检查这个,但如果我没记错的话,事件就在那里,但没有发布。尝试创建一个源自 TDBGrid 并发布滚动条事件的控件。
于 2009-11-12T16:54:07.123 回答