Code:

procedure TForm1.AppOnMessage(var Msg: TMsg; var Handled: Boolean);

var

  ccode: Word;

begin

  case Msg.Message of

    WM_KEYDOWN, WM_KEYUP:

      begin

        if (GetKeyState(VK_NUMLOCK) >= 0{NumLock not active} and

          ((Msg.lParam and $1000000) = 0{not a gray key} then

        begin

          ccode := 0;

          case Msg.wParam of

            VK_HOME: ccode   := VK_NUMPAD7;

            VK_UP: ccode     := VK_NUMPAD8;

            VK_PRIOR: ccode  := VK_NUMPAD9;

            VK_LEFT: ccode   := VK_NUMPAD4;

            VK_CLEAR: ccode  := VK_NUMPAD5;

            VK_RIGHT: ccode  := VK_NUMPAD6;

            VK_END: ccode    := VK_NUMPAD1;

            VK_DOWN: ccode   := VK_NUMPAD2;

            VK_NEXT: ccode   := VK_NUMPAD3;

            VK_INSERT: ccode := VK_NUMPAD0;

            VK_DELETE: ccode := VK_DECIMAL;

          end; {Case}

          if ccode <> 0 then

            Msg.wParam := ccode;

        end; {If}

      end; {Case Msg.Message}

  end; {Case}

end;

 

procedure TForm1.FormCreate(Sender: TObject);

begin

  Application.OnMessage := AppOnMessage;

end;

 

Пример демонстрирует установку горячей клавиши CTRL-F7:

Нам потребуется универсальная функция, которую можно будет применять для различных визуальных контролов.

 Вот пример вызова нашей функции:

 

Перевод одноимённой статьи с сайта delphi.about.com )

Начиная с самого рассвета компьютерной промышленности, клавиатура была первичным устройством ввода информации, и вероятнее всего сохранит свою позицию ещё долгое время.

События клавиатуры, наряду с событиями мыши, являются основными элементами взаимодействия пользователя с программой. В данной статье пойдёт речь о трёх событиях, которые позволяют отлавливать нажатия клавиш в приложении Delphi: OnKeyDown, OnKeyUp и OnKeyPress.

 

Code:

var hintWnd: THintWindow;

 

procedure TForm1.ActivateHintNOW( x,y: Integer);

var rect: TRect;

begin

HintTxt := 'qq';

if hintTxt <> '' then

begin

   rect := hintWnd.CalcHintRect( Screen.Width, hinttxt, nil);

   rect.Left := rect.Left + x;

   rect.Right := rect.Right + x;

   rect.Top := rect.Top + y;

   rect.Bottom := rect.Bottom + y;

   hintWnd.ActivateHint( rect, hinttxt);

end;

end;

 

 

Замечание: Не забудьте каждый раз создавать hintWnd:

    hintwnd:= THintWindow.create(self);

 

а затем освобождать его

      hintwnd.releasehandle;

 

Code:

function InsertOn: Boolean;

begin

{©Drkb v.3}

 

Result:=LowOrderBitSet(GetKeyState(VK_INSERT));

end;

 

 

Code:

mouse_event(MOUSEEVENTF_LEFTDOWN,0,0,0,0);

Application.ProcessMessages;

mouse_event(MOUSEEVENTF_LEFTUP,0,0,0,0);

 

Все потомки TComponent могут посылать сообщения CM_MOUSEENTER и CM_MOUSELEAVE во время вхождения и покидания курсора мыши области компонента. Если вам необходимо, чтобы ваши компоненты обладали реакцией на эти события, необходио написать для них соответствующие обработчики.

 

Следующий пример демонстрирует использование API функции mouse_event() для эмуляции событий мышки. Когда Button2 нажата, то мышь перемещается на Button1 и щёлкает по ней. Координаты мыши даны в "Mickeys", где 65535 соответствует ширине экрана.

В этом примере курсор мыши сам встает на кнопку и нажимает на нее.

 

Для этого можно воспользоваться API функцией ClipCursor(). Например, можно вставить следующий код в обработчик события формы OnMouseDown:

ClipCursor(&BoundsRect);

а следующий код в обработчик события формы OnMouseUp:

ClipCursor(NULL);