![]() |
AW: Nach Explorer absturz
Hier ist jetzt die Lösung.
Delphi-Quellcode:
MainProc.
procedure WinEventProc(hWinEventHook: THandle; event: DWORD; EHandle: HWND;
idObject: Integer; idChild: Integer; idEventThread: DWord; dwmsEventTime: DWord); stdcall; begin if (event = EVENT_OBJECT_DESTROY) and (EHandle = HwndTarget) and (idObject = OBJID_WINDOW) and (idChild = INDEXID_CONTAINER) then begin if (MainApp.FHNotifyRBin <> 0) then begin if SHChangeNotifyDeregister(MainHandle) then begin SendMessage(MainHandle, WM_COMMAND, IDM_Restart, 0); MainApp.RegisterRecyleBin(MainHandle); end; end; end; end;
Delphi-Quellcode:
WM_DESTROY:
begin if (HWEH <> 0) then UnhookWinEvent(HWEH);
Delphi-Quellcode:
Aber!
{$REGION 'procedure RegisterRecyleBin'}
procedure TMainApp.RegisterRecyleBin(WinHandle: HWND); var dwProcessId: DWord; dwThreadId: DWord; pidlRecycleBin: PItemIDList; stPIDL: TSHChangeNotifyEntry; hr: HRESULT; begin HwndTarget := FindWindow('Progman', 'Program Manager'); dwThreadId := GetWindowThreadProcessId(HwndTarget, @dwProcessId); if (dwThreadId <> 0) then HWEH := SetWinEventHook(EVENT_OBJECT_DESTROY, EVENT_OBJECT_DESTROY, 0, @WinEventProc, dwProcessId, dwThreadId, WINEVENT_OUTOFCONTEXT); hr := SHGetSpecialFolderLocation(WinHandle, CSIDL_BITBUCKET, pidlRecycleBin); if Succeeded(hr) then begin stPIDL.pidl := pidlRecycleBin; stPIDL.fRecursive := True; FHNotifyRBin := SHChangeNotifyRegister(WinHandle, SHCNF_ACCEPT_INTERRUPTS or SHCNF_ACCEPT_NON_INTERRUPTS, SHCNE_ALLEVENTS, WM_SHELLNOTIFY, 1, stPIDL); if 0 = FHNotifyRBin then RaiseLastOSError(GetLastError); end else RaiseLastOSError; end; {$ENDREGION} Wie kann ich das nun zuverlässig testen? Wenn ich nun einen Hard Reset ausführe also den Prozess Explorer kille dann startet der Explorer nicht automatisch neu und dann wird das DesktopListView nicht mehr gefunden. Gibt es einen anderen weg den Explorer zu beenden so das er automatisch neustartet damit ich den Fehler gegenprüfen kann? EDIT: Es ist ja nicht die Aufgabe meiner Anwendung den Explorer neu zu starten oder? |
AW: Nach Explorer absturz
.. geht es nicht über den TaskManager Windows-Explorer markieren -> unten rechts neu starten.
Grüße Klaus |
AW: Nach Explorer absturz
Zitat:
Aber dazwischen greift ja das Event bzw. die Callback. Wenn ich danach die Anwendung neu\restarte wird das DesktopListView nicht gefunden der Explorer startet ja erst danach neu! Werde wohl einen Loop hinzufügen müssen der darauf wartet bis das Handle vom Progman wieder gefunden wird. |
AW: Nach Explorer absturz
Es gibt doch aber auch irgendwo ein Event, wenn der Explorer die Taskleiste neu gestartet wurde.
Wenn man etwas hat, was sich dort rein hängt, dann muß man eben auch auf dessen Events reagieren. Und ja, es ist krank, dass Desktop/Taskleiste und Explorer.exe ein und das Selbe sind, aber damit muß man eben leben, bis es endlich mal repariert/geändert wird. |
AW: Nach Explorer absturz
Zitat:
Habe es jetzt so geändert. Ob das elegant ist mag dahin gestellt sein.
Delphi-Quellcode:
procedure WinEventProc(hWinEventHook: THandle; event: DWORD; EHandle: HWND;
idObject: Integer; idChild: Integer; idEventThread: DWord; dwmsEventTime: DWord); stdcall; var Counter: Integer; begin if (event = EVENT_OBJECT_DESTROY) and (EHandle = HwndTarget) and (idObject = OBJID_WINDOW) and (idChild = INDEXID_CONTAINER) then begin if (MainApp.FHNotifyRBin <> 0) then begin HwndTarget := 0; Counter := 0; if SHChangeNotifyDeregister(MainHandle) then begin MainApp.FHNotifyRBin := 0; repeat HwndTarget := FindWindow('Progman', 'Program Manager'); WinProcessMessages; inc(Counter); until (HwndTarget <> 0) or (Counter = 30000); if HwndTarget <> 0 then MainApp.RegisterRecyleBin(MainHandle); end; end; end; end; |
AW: Nach Explorer absturz
Zitat:
Delphi-Quellcode:
RegisterWindowMessage('TaskbarCreated')
|
AW: Nach Explorer absturz
Zitat:
|
AW: Nach Explorer absturz
Zitat:
Das ist egal. Explorer und Taskleiste sind quasi das Gleiche. Die erste Instanz der explorer.exe ist der "Desktop", mit der Taskleiste drauf. Genauso wie (File) Explorer und Internet Exporer untrennbar zusammen gehören. Der Interactive Desktop und die WebView des Explorers ist ein Internet Explorer. Das FTP im Explorer läuft über den Intenret Explorer. :wall: (und alle runtergeladenen Dateien landen im IECache, wo auch noch die gesetzte Speichergrenze ignoriert wird) Man kann sogar über die selbe API alle Internet Explorer und (File) Explorer auslisten, mit samt ihrer URL/Pfad. |
AW: Nach Explorer absturz
[QUOTE=venice2;1473613]
Zitat:
|
AW: Nach Explorer absturz
Zitat:
Was, wie, wo soll ich ändern? bzw. Ist bei mir nicht die korrekte Implementierung. Ich habe doch ein Event HWEH := SetWinEventHook Warum soll ich jetzt noch eine Message Registrieren. RegisterWindowMessage('TaskbarCreated') Ich frage deshalb nochmal weil ich Probleme habe der HOOK greift nicht immer.
Delphi-Quellcode:
Papierkorb registrieren
if (HWEH <> 0) then
begin UnhookWinEvent(HWEH); // HOOK zerstören wenn erstellt. HWEH := 0; end; HWEH := SetWinEventHook(EVENT_OBJECT_DESTROY, EVENT_OBJECT_DESTROY, 0, @WinEventProc, dwProcessId, dwThreadId, WINEVENT_OUTOFCONTEXT); // HOOK erstellen.
Delphi-Quellcode:
Seltsamer weise incrementiert FHNotifyRBin bin mir nicht sicher ob das so sein soll.
FHNotifyRBin := SHChangeNotifyRegister(WinHandle,
SHCNF_ACCEPT_INTERRUPTS or SHCNF_ACCEPT_NON_INTERRUPTS, SHCNE_ALLEVENTS, WM_SHELLNOTIFY, 1, stPIDL); Ich deregistriere doch das Event.
Delphi-Quellcode:
if SHChangeNotifyDeregister(MainHandle) then
trotzdem wird FHNotifyRBin incrementiert |
Alle Zeitangaben in WEZ +1. Es ist jetzt 17:47 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