![]() |
eigenen tray-bereich programmieren
Liste der Anhänge anzeigen (Anzahl: 1)
Hallo Leute,
wollte mal fragen, ob ihr zufällig wisst, wie man eine eigene tray area programmieren kann. Meine Frage ist, wie ich die Icons vom TrayNotifyWnd-Fenster auf mein Programm umleiten kann. Vielleicht wisst ihr auch, wie man das TrayNotifyWnd-Fenster aus dem Shell_TrayWnd-Fenster abkapseln kann :) (das würde die neuprogrammierung des Traybereichs ersparen) Ähm ja ich gebe zu das klingt jetzt etwas kryptisch, deshalb anbei ein Screenshot meines Desktops :) hoffe, ihr versteht mich :gruebel: :dp: Grüße, jr |
Re: eigenen tray-bereich programmieren
Zitat:
Delphi-Quellcode:
Edit:
Unit Unit1;
Interface Uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls; Type TForm1 = Class(TForm) Button1: TButton; Button2: TButton; Procedure Button1Click(Sender: TObject); Procedure Button2Click(Sender: TObject); private { Private-Deklarationen } OriginParent: Hwnd; public { Public-Deklarationen } End; Var Form1: TForm1; Implementation {$R *.dfm} Procedure TForm1.Button1Click(Sender: TObject); Begin OriginParent := Windows.GetParent(xxx); Windows.SetParent(xxx, Self.Handle); End; Procedure TForm1.Button2Click(Sender: TObject); Begin Windows.SetParent(xxx, OriginParent); End; End. xxx = Handle Deiner TNA Edit2: Hab mir gerade erst Deinen Anhang angesehen. Wenn Du
Delphi-Quellcode:
ersetzt durch
Windows.SetParent(xxx, Self.Handle);
Delphi-Quellcode:
landet Deine TNA übrigens auf dem Desktop.
Windows.SetParent(xxx, 0);
Edit3: Was mir gerade noch einfällt: Solltest Du die TNA auf Deine eigene Form packen, dann denke daran, beim Beenden Deiner Anwendung das Ganze wieder rückgängig zu machen (Button2Click) - ansonsten stehst Du ohne TNA da ;) Obwohl man die auch irgendwie wieder herstellen kann; weiss allerdings aktuell nicht, wie. Edit4: Rechtschreibfehler in Edit3 beseitigt |
Re: eigenen tray-bereich programmieren
hey danke erstmal für den guten Ansatz! Das ganze funktioniert auch mit der gesamten Taskleiste und sieht echt putzig aus =) aber wenn ich es nur auf die TNA anwende, verschwindet sie im Nirvana =(
|
Re: eigenen tray-bereich programmieren
Hmm,
bei mir gehts. Die TNA landet in der linken oberen Ecke des Desktops. Sicher, dass Du das korrekte handle hast, also das der Klasse 'ToolbarWindow32' mit dem Titel 'Infobereich'? |
Re: eigenen tray-bereich programmieren
ich benutze das handle kind:
elter := FindWindow('Shell_TrayWnd', nil); kind := FindWindowEx(elter, 0, 'TrayNotifyWnd', nil); |
Re: eigenen tray-bereich programmieren
Liste der Anhänge anzeigen (Anzahl: 1)
Tipp: besorge Dir WinSpy und hol Dir darüber erstmal manuell das korrekte Handle, um zu sehen, ob es grundlegend funktioniert. Evtl. ist in Deiner Handle-Suche noch etwas nicht ganz korrekt.
Edit: Du bist noch nicht tief genug -> s. Screenshot |
Re: eigenen tray-bereich programmieren
Ich habe jetzt folgenden Code
Delphi-Quellcode:
und irgendwie klappt es immernoch nicht, obwohl er ein gültiges Handle liefert. Hm vielleicht sollte ich mich nochmal genauer mit Handles beschäftigen... was ist denn dein Handle-Suchcode?
Procedure TForm1.Button1Click(Sender: TObject);
Begin OriginParent := Windows.GetParent(d); Windows.SetParent(d, 0); End; Procedure TForm1.Button2Click(Sender: TObject); Begin Windows.SetParent(d, OriginParent); End; procedure TForm1.FormCreate(Sender: TObject); begin a := FindWindow('Shell_TrayWnd', nil); b := FindWindowEx(a, 0, 'TrayNotifyWnd', nil); c:=FindWindowEx(b, 0, 'Syspager', nil); d:=FindWindowEx(c, 0, 'ToolbarWindow32', 'Infobereich'); end; |
Re: eigenen tray-bereich programmieren
Liste der Anhänge anzeigen (Anzahl: 1)
Ich hab mir das Handle wie gesagt über WinSpy geholt, da ich keine Lust hatte, mich da durch zu hangeln.
Aber das hast Du ja jetzt für mich gemacht ;) Habe also Deine Routine zur Ermittlung des Handles übernommen und es funktioniert bei mir -> die TNA wird beim Klick auf Button1 auf meine Form verfrachtet. Beispielprojekt anbei. |
Re: eigenen tray-bereich programmieren
aaah es hat die ganze Zeit geklappt! Das Problem war nur: bei mir ist die Taskleiste oben. und deshalb hat sie auch wunderschön den TNA-Bereich überdeckt ^^ vielen Dank für deine Hilfe! =)
|
Re: eigenen tray-bereich programmieren
Das funktioniert ja "nur" wenn auch die Taskleiste da ist, sprich der Explorer als Shell läuft, oder? Wenn ich jetzt hergehen würde und eine andere Shell benutze, wie erstelle ich dann "per Hand" eine TNA?
Muss ich dann diese Windows-Struktur selbst erstellen? :wiejetzt: |
Re: eigenen tray-bereich programmieren
Hallo,
Zitat:
Zitat:
Zitat:
Im Prinzip sind ja alles nur Fenster, die auf irgendwelche Botschaften reagieren. Also wäre der Nachbau einer Taskbar mit all ihren Elementen nichts anderes als jede andere Anwendung mit Buttons und dergleichen auch. Nur dass man hier wohl nicht umher kommen würde, sich mit der WinAPI zu beschäftigen, da es meines Wissens nach keine Komponenten gibt, welche diese Funktionalitäten kapseln. |
Re: eigenen tray-bereich programmieren
![]() |
Re: eigenen tray-bereich programmieren
@Rastaman: und dann? da sind zwar Nachrichten drin die eine eigene Taskleiste möglich machen, aber zum Thema Tray-Bereich hab dort jetzt nix gesehen...
|
Re: eigenen tray-bereich programmieren
Kleiner Hinweis: Schau mal auf
![]() |
Re: eigenen tray-bereich programmieren
Es gibt bestimmt Dokumentationen von Microsoft, wie man eine eigene Shell programmiert. Dort sollten auch die benötigten Schnittstellen dokumentiert sein.
|
Re: eigenen tray-bereich programmieren
Zitat:
Zitat:
![]() Aber insgesammt würde ich von einer komplette Neuprogrammierung des Tray absolut abraten insofern es nicht echt nötig ist. Das ganze ist ziemlich kompliziert und es ist fast ein ding der unmöglichkeit eine eigenen system tray zu implementieren der absolut fehlerfrei funktioniert. Grund ist zum einen der Mangel an Dokumentation (man kann sich vieles nur aus dem Thema verwandten MSDN und Knowledge Base Artikeln zusammen suchen und probieren) und der Fakt das es Anwendungen gibt die den MSDN Richtlinien nicht exakt Folgen (aber trotzdem im explorer tray richtig angezeigt werden... nur in deinem eigenen nicht). Den eigenen Tray parallel zum explorer tray laufen lassen ist übriegens nicht möglich da es nur ein 'Shell_TrayWnd' geben kann welches die Tray Nachrichten via WM_COPYDATA empfängt. Wenn es für deine Zwecke reicht solltest du wirklich versuchen die Shell_TrayWnd und TrayNotifyWnd Fenster von der Taskbar abzudocken. Schau vielleicht mit Winspector nach ob es noch irgendein parent Fenster gibt was du gleich mit rausziehen kannst. In der Taskbar ist das soweit ich mich erinnere ganz gut organisiert. Das einzige auf was du absolut achten mußt ist das das TrayNotififyWnd ein child Fenster vom Shell_TrayWnd bleibt. |
Re: eigenen tray-bereich programmieren
Zitat:
|
Re: eigenen tray-bereich programmieren
Zitat:
Hier ist man größtenteils wirklich auf sich allein gestellt (insofern man nicht blind von bereits existierenden shells kopieren will) und einem bleibt manchmal auch nix anderes übrig als mit Winspector Nachrichten und Fenster zu überwachen oder manchmal sogar 100 MB große Process Monitor startup logs von windows/explorer zu analysieren. Hat schon seinen Grund warum ich davon abrate insofern es nicht absolut notwendig ist :) |
Alle Zeitangaben in WEZ +1. Es ist jetzt 07:09 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