如何拦截DbGrids的KeyDown事件? |
尚未結案
|
railgunman
初階會員 發表:59 回覆:121 積分:36 註冊:2003-03-31 發送簡訊給我 |
|
railgunman
初階會員 發表:59 回覆:121 積分:36 註冊:2003-03-31 發送簡訊給我 |
|
hagar
版主 發表:143 回覆:4056 積分:4445 註冊:2002-04-14 發送簡訊給我 |
|
terrychen
尊榮會員 發表:90 回覆:794 積分:501 註冊:2003-05-01 發送簡訊給我 |
|
daphne_
一般會員 發表:0 回覆:2 積分:0 註冊:2005-04-12 發送簡訊給我 |
procedure TForm1.DBGrid1KeyDown(Sender: TObject; var Key: Word;
Shift: TShiftState);
var
aDataSet: TDataSet;
begin
if not (Sender is TDBGrid) then Exit;
if not Assigned(TDBGrid(Sender).DataSource) then Exit; aDataSet := TDBGrid(Sender).DataSource.DataSet;
if not Assigned(aDataSet) then Exit;
if not aDataSet.Active then Exit; if not (aDataSet.State in [dsInsert,dsEdit]) then Exit; if Key = VK_DOWN then Key := VK_CONTROL;
end;
|
wameng
版主 發表:31 回覆:1336 積分:1188 註冊:2004-09-16 發送簡訊給我 |
我不懂您的用意為何?
在 KeyDown Event 只有 Key 值是可以改變的。
CTRL 鍵 為複合鍵。 若要當按下 DOWN 鍵,等於 CTRL + DOWN。
可這樣做。
type TDBGrid = Class(DBGrids.TDBGrid) Protected procedure KeyDown(var Key: Word; Shift: TShiftState); override; end; TForm1 = class(TForm) .... procedure TDBGrid.KeyDown(var Key: Word; Shift: TShiftState); begin if Key=VK_DOWN then Shift := Shift [ssCtrl]; inherited KeyDown(Key,Shift); end;~~~~~~~~~~~ 難得聰明,常常糊塗。 ~~~~~~~~~~~ |
jeff377
初階會員 發表:9 回覆:60 積分:33 註冊:2004-08-10 發送簡訊給我 |
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |