AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

NonVCL-Fenster in VCL-Anwendung

Offene Frage von "Schubi"
Ein Thema von Schubi · begonnen am 16. Mär 2011 · letzter Beitrag vom 19. Mär 2011
Antwort Antwort
Seite 1 von 2  1 2      
Schubi

Registriert seit: 4. Nov 2003
Ort: Happurg (Nürnberg)
331 Beiträge
 
Delphi 2006 Professional
 
#1

NonVCL-Fenster in VCL-Anwendung

  Alt 16. Mär 2011, 08:27
Hallo zusammen.

Kann mir bitte jemand einen Tipp geben, wie ich am einfachsten ein NonVCL-Fenster aus einer normalen VCL-App heraus erzeuge?
Mein Problem liegt eher darin, dass ich keine Ahnung habe, wie das dann mit der Message-Que ablaufen muss.

Hintergrund ist, dass ich ein fertiges (VCL-) Projekt habe, bei dem eine Desktop-Uhr dazu gehört.
Diese ist momentan in einem VCL-Fenster, bei dem ich per SetWindowLong WS_EX_TRANSPARENT und WS_EX_LAYERED setze.

Da das aber zu einigen Problemchen führt, möchte ich das am liebsten mit einem Fenster machen, über das ich die volle Kontrolle habe.

Das Fenster muss quasi nur alle Minute eine aktualisierte Bitmap laden. Viel mehr ist nicht nötig.

Würde mich über ein paar Tipps freuen.

Grüßle,
Schubi
Christian Schubert
Ich fange gerade erst an, den Umfang meiner Ahnungslosigkeit zu begreifen...
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
43.119 Beiträge
 
Delphi 12 Athens
 
#2

AW: NonVCL-Fenster in VCL-Anwendung

  Alt 16. Mär 2011, 10:15
Wenn du die NonVCL-Controls innerhalb des VCL-Threads (Hauptthread) erzeugst, dann werden diese von der Message-Loop der VCL mit behandelt und du brauchst die MessageQueue nicht selber zu verarbeiten.

Erstellst du die Controls in einem anderem Thread, dann mußt du die MessageQueue auch selber dort abarbeiten.
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests
  Mit Zitat antworten Zitat
Benutzerbild von turboPASCAL
turboPASCAL

Registriert seit: 8. Mai 2005
Ort: Sondershausen
4.274 Beiträge
 
Delphi 6 Personal
 
#3

AW: NonVCL-Fenster in VCL-Anwendung

  Alt 16. Mär 2011, 13:56
Mit der VCL wenn man die eh schon nutzt kann man das aber auch ohne Probleme lösen.

Wenn du unst beschreibst was, wie, und was nicht kann man bestimmt helfen.
Matti
Meine Software-Projekte - Homepage - Grüße vom Rüsselmops -Mops Mopser
  Mit Zitat antworten Zitat
Schubi

Registriert seit: 4. Nov 2003
Ort: Happurg (Nürnberg)
331 Beiträge
 
Delphi 2006 Professional
 
#4

AW: NonVCL-Fenster in VCL-Anwendung

  Alt 17. Mär 2011, 17:02
Wie gesagt, es handelt sich um eine Desktop-Uhr.
Die zeichne ich in ein TBitmap und lade das Ganze in ein TImage auf der Form.
Die wird transparent gemacht, so dass ich nur noch den Kreis übrig habe.
Dann setzte ich WS_EX_LAYERED, so dass ich durch das Form "hindurchklicken" kann.
Zusätzlich gibt es maus-sensitives Alphablending. Also beim drüber fahren mit der Maus wird das Form fast ganz durchsichtig gemacht.
Das setzte ich mit einem Maus-Hook um, weil ja OnMouseEnter nicht mehr funktioniert.

Probleme dabei sind aber folgende:
Beim
- Sperren der Session (Win+L)
- nach dem Drücken von Strg+Alt+Entf (Die eingeblendete "Windowssicherheit" verhält sich genauso wie ein Sessionlock)
muss ich den Mousehook sowie alle Fenstereigenschaften neu setzen.
Alphablending geht sporadisch verloren, exlayered, also hindurchklickbar, geht auch nicht mehr und das maussensitive Alphablending geht wegen dem Hook nicht mehr.

Punkt 1 habe ich durch überwachen vom WM_SESSIONCHANGE und anschließendes Neu-Setzen des Hooks sowie der Fenstereigenschaften umgehen können.
Punkt 2 nur durch sporadisches Neu-Setzen der Eigenschaften.

So weit war das alles noch verkraftbar und lief gut.
Dann hatten sich allerdings Freezes von Windows gezeigt. Und zwar auf nahezu allen Rechnern wo das Programm lief.
Zeitweise hat der Rechnicht auf Keinerlei Eingaben mehr reagiert. Weder Maus, noch Tastatur. Erst nach dem Drücken von Strg+Alt+Entf oder dem Sperren der Session wurden wieder ein bis zwei Eingaben angenommen. Danach das gleiche Spiel.

Aufgehört hat das erst, als ich den Mousehook aus dem Programm entfernt habe.

Das ist jetzt der Komplette Leidensweg...

Alte Threads zum Thema:
http://www.delphipraxis.net/133703-d...h-klicken.html
http://www.delphipraxis.net/143253-w...icherheit.html

Wer das Programm kurz ausporbieren will:
https://hydra.erlangen.ccc.de/~schub...0124_Setup.exe

Den Einstellungs-Dialog beim ersten Start einfach bestätigen.
Ist die Version ohne Freezes, Restlos-Uninstaller ist auch dabei
Christian Schubert
Ich fange gerade erst an, den Umfang meiner Ahnungslosigkeit zu begreifen...

Geändert von Schubi (17. Mär 2011 um 17:13 Uhr) Grund: Link hinzu
  Mit Zitat antworten Zitat
Benutzerbild von SirThornberry
SirThornberry
(Moderator)

Registriert seit: 23. Sep 2003
Ort: Bockwen
12.235 Beiträge
 
Delphi 2006 Professional
 
#5

AW: NonVCL-Fenster in VCL-Anwendung

  Alt 17. Mär 2011, 18:48
Dann würde ich nach einer alternative für den Maushook suchen. Vermutlich kracht es bei dir so fürchterlich weil die kommunikation zwischen den hookinstanzen und deiner Anwendung nicht mehr funktioniert. Und nach Beschreibung aller Symptome wird es daran liegen das dein Formular recreated wird und somit ein neues Handle bekommt.
Also am besten die ganzen Styles für das Fensterhandle etc. in CreateWnd (musst du überschreiben) setzen und mit dem Hook nicht über das Hauptfensterhandle kommunizieren sondern entweder ein extra handle dafür anfordern oder eine bessere Variante wählen (zum Beispiel über PostThreadMessages, so kommen die Nachrichten auch über mehrere Desktops hinweg an)
Jens
Mit Source ist es wie mit Kunst - Hauptsache der Künstler versteht's
  Mit Zitat antworten Zitat
EWeiss
(Gast)

n/a Beiträge
 
#6

AW: NonVCL-Fenster in VCL-Anwendung

  Alt 17. Mär 2011, 18:52
Warum nen MouseHook
Setze das doch einfach mit

Delphi-Quellcode:
GetCursorPos(CurPos);
ScreenToClient(WinHandle, CurPos);

if PtInRect(rc, CurPos) then
um..
so kannst du auch ohne Hook prüfen ob sich deine Maus über
deiner Uhr befindet.

Hooks sind sehr kritisch.

gruss
  Mit Zitat antworten Zitat
Benutzerbild von SirThornberry
SirThornberry
(Moderator)

Registriert seit: 23. Sep 2003
Ort: Bockwen
12.235 Beiträge
 
Delphi 2006 Professional
 
#7

AW: NonVCL-Fenster in VCL-Anwendung

  Alt 17. Mär 2011, 18:54
Diese Variante würde aber mit Polling arbeiten was unnötig Rechenzeit verbracht. Ich finde es spricht nichts gegen einen Hook (für irgend etwas müssen die ja gut sein), man muss eben nur damit richtig umgehen.
Jens
Mit Source ist es wie mit Kunst - Hauptsache der Künstler versteht's
  Mit Zitat antworten Zitat
Schubi

Registriert seit: 4. Nov 2003
Ort: Happurg (Nürnberg)
331 Beiträge
 
Delphi 2006 Professional
 
#8

AW: NonVCL-Fenster in VCL-Anwendung

  Alt 17. Mär 2011, 21:59
Danke für die Antworten.
Polling kommt nicht in Frage, ist zu langsam und zu Prozessorlastig. Letztlich brauch ich nur die OnMouseEnter- und Leave-Messages. Auf welchem Weg auch immer.

Also am besten die ganzen Styles für das Fensterhandle etc. in CreateWnd (musst du überschreiben) setzen...
Wie hat das mit dem Überschreiben auszusehen? Was muss ich übergeben? Hab von inherited Calls nicht so wirklich Plan.

Der Mousehook baut übrigen hierauf auf:
http://www.swissdelphicenter.ch/de/showcode.php?id=1729
Christian Schubert
Ich fange gerade erst an, den Umfang meiner Ahnungslosigkeit zu begreifen...

Geändert von Schubi (17. Mär 2011 um 22:11 Uhr)
  Mit Zitat antworten Zitat
EWeiss
(Gast)

n/a Beiträge
 
#9

AW: NonVCL-Fenster in VCL-Anwendung

  Alt 17. Mär 2011, 22:18
Diese Variante würde aber mit Polling arbeiten was unnötig Rechenzeit verbracht.
Im Microbereich
Jeder wie er möchte war nur ein vorschlag.

gruss
  Mit Zitat antworten Zitat
Schubi

Registriert seit: 4. Nov 2003
Ort: Happurg (Nürnberg)
331 Beiträge
 
Delphi 2006 Professional
 
#10

AW: NonVCL-Fenster in VCL-Anwendung

  Alt 17. Mär 2011, 22:24
Eben leider nicht. Wenn die Uhr einigermaßen schnell ausblenden soll, wenn die Maus drüber geht, macht sich das schon bemerkbar.
Vor allem auf den alten Celeron-Kisten, wo das Programm hauptsächlich läuft.
Christian Schubert
Ich fange gerade erst an, den Umfang meiner Ahnungslosigkeit zu begreifen...
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 08:03 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz