AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein In Hook auslösender Prozess ermitteln

In Hook auslösender Prozess ermitteln

Ein Thema von hesch21 · begonnen am 16. Dez 2013 · letzter Beitrag vom 19. Dez 2013
Antwort Antwort
hesch21

Registriert seit: 31. Aug 2004
Ort: Basel
114 Beiträge
 
Delphi XE2 Enterprise
 
#1

AW: In Hook auslösender Prozess ermitteln

  Alt 18. Dez 2013, 13:15
Erst mal Danke für Eure Hilfe. Die Lösung mit dem GetForeGroundWindow funktioniert da ich ja noch neben dem Dienst ein Miniprogramm am laufen habe, welches jeweils vom Dienst auf den gerade aktuellen Desktop geschmissen wird.

Nun bin ich aber bei meiner Rumspielerei mit den Hooks noch auf ein anderes Problem gestossen. Beim Maus-Hook gibt es in der Struktur den Wert wHitTestCode und der müsste mit einem Wert gemäss WM_NCHITTEST bestückt werden. Bei mir kommt aber immer nur 0 zurück. Habt Ihr eine Ahnung, was ich falsch mache? Hier der Code:
Delphi-Quellcode:
type
 PMSDLLHookInfo = ^TMSDLLHookInfo;
 tagMSDLLHOOKSTRUCT = packed record
    POINT : TPoint;
    Handle : DWORD;
    wHitTestCode: integer;
    dwExtraInfo : DWORD;
 end;
 TMSDLLHookInfo = tagMSDLLHOOKSTRUCT;

var HookMaus : HHook;
var hApp : HWND;

function MouseHookProc(Code: Integer; wParam: WPARAM; lParam: LPARAM): LRESULT; stdcall;
const WM_XBUTTONDOWN = $020B;
const WM_XBUTTONUP = $020C;
const WM_XBUTTONDBLCLK = $020D;
var Wnd : HWND;
var PID : DWord;
var TID : DWord;
var mVKCode : integer;
var mUpDown : integer;
var XKord : integer;
var YKord : integer;
var woHit : string;
var wasHit : string;

begin
  if (Code = HC_ACTION) and (wParam <> WM_MOUSEMOVE) and (wParam <> WM_NCMOUSEMOVE) then
     begin
     Wnd := GetForeGroundWindow;
     TID := GetWindowThreadProcessId(Wnd, PID);
     MUpDown := wParam;
     case wParam of
          WM_LBUTTONDBLCLK : WasHit := 'L-ButtonDBLClick';
          WM_LBUTTONDOWN : WasHit := 'L-ButtonDown';
          WM_LBUTTONUP : WasHit := 'L-ButtonUp';
          WM_MBUTTONDBLCLK : WasHit := 'M-ButtonDBLClick';
          WM_MBUTTONDOWN : WasHit := 'M ButtonDown';
          WM_MBUTTONUP : WasHit := 'M-ButtonUp';
          WM_RBUTTONDBLCLK : WasHit := 'R-ButtonDBLClick';
          WM_RBUTTONDOWN : WasHit := 'R-ButtonDown';
          WM_RBUTTONUP : WasHit := 'R-ButtonUp';
          WM_XBUTTONDBLCLK : WasHit := 'X-ButtonDBLClick';
          WM_XBUTTONDOWN : WasHit := 'X-ButtonDown';
          WM_XBUTTONUP : WasHit := 'X-ButtonUp';
          WM_MOUSEHOVER : WasHit := 'MouseHover';
          WM_MOUSELEAVE : WasHit := 'MouseLeave';
          WM_MOUSEMOVE : WasHit := 'MouseMove';
          WM_MOUSEWHEEL : WasHit := 'MouseWheel';
          WM_MOUSEACTIVATE : WasHit := 'MouseActivate';
          WM_NCLBUTTONDOWN : WasHit := 'NCL-L-ButtonDown';
     else
          WasHit := IntToStr(wparam);
     end;
     XKord := PMSDLLHookInfo(lParam).POINT.X;
     YKord := PMSDLLHookInfo(lParam).POINT.Y;
     mVKCode := PMSDLLHookInfo(lParam).wHitTestCode;
     case mVKCode of
          HTBORDER : WoHit := 'Border';
          HTBOTTOM : WoHit := 'Bottom';
          HTBOTTOMLEFT : WoHit := 'BottomLeft';
          HTBOTTOMRIGHT : WoHit := 'BottomRight';
          HTCAPTION : WoHit := 'Caption';
          HTCLIENT : WoHit := 'Client';
          HTCLOSE : WoHit := 'Close';
          HTERROR : WoHit := 'Error';
          HTHELP : WoHit := 'Help';
          HTHSCROLL : WoHit := 'Scroll';
          HTLEFT : WoHit := 'Left';
          HTMENU : WoHit := 'Menu';
          HTREDUCE : WoHit := 'Reduce';
          HTNOWHERE : WoHit := 'Nowhere';
          HTRIGHT : WoHit := 'Right';
          HTSIZE : WoHit := 'Size';
          HTSYSMENU : WoHit := 'SysMenu';
          HTTOP : WoHit := 'Top';
          HTTOPLEFT : WoHit := 'TopLeft';
          HTTOPRIGHT : WoHit := 'TopRight';
          HTTRANSPARENT : WoHit := 'Transparent';
          HTVSCROLL : WoHit := 'V-Scroll';
          HTZOOM : WoHit := 'Zoom';
     else
          WoHit := IntToStr(mVKCode);
     end;
anzumerken wäre, dass die x- und y-Koordinaten richtig aus der Struktur ausgelesen werden.
Heinz Schneider
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#2

AW: In Hook auslösender Prozess ermitteln

  Alt 18. Dez 2013, 14:56
Bist du dir sicher, dass du weißt, was du da gerade tust?

Ich fürchte mal nicht ... denn

Du sprichst immer von globalen (also den LowLevel) Hooks, benutzt aber die Struktur für den normalen Hook.
Welchen Hook willst du denn jetzt benutzen?
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)

Geändert von Sir Rufo (18. Dez 2013 um 14:58 Uhr)
  Mit Zitat antworten Zitat
hesch21

Registriert seit: 31. Aug 2004
Ort: Basel
114 Beiträge
 
Delphi XE2 Enterprise
 
#3

AW: In Hook auslösender Prozess ermitteln

  Alt 19. Dez 2013, 09:00
Upps!
war vermutlich Wunschdenken! Ich bin vorderhand wirklich nur am rumspielen mit dem Maushook und die Anzeige, wo geklickt wurde, wäre echt schön gewesen. Das scheint aber mit der korrekten Low-Level-Struktur leider nicht möglich zu sein. Da gibt es nichts ähnliches wie HitTestCode. Schade.
Heinz Schneider
  Mit Zitat antworten Zitat
Antwort Antwort

Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 11:26 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz