AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein GUI-Design mit VCL / FireMonkey / Common Controls Delphi Doppelklick in MouseDown erkennen (MouseDown vs. DblClick)
Thema durchsuchen
Ansicht
Themen-Optionen

Doppelklick in MouseDown erkennen (MouseDown vs. DblClick)

Ein Thema von CodeX · begonnen am 12. Mär 2010 · letzter Beitrag vom 1. Jan 2019
Antwort Antwort
Seite 2 von 2     12   
Schokohase
(Gast)

n/a Beiträge
 
#11

AW: Doppelklick in MouseDown erkennen (MouseDown vs. DblClick)

  Alt 31. Dez 2018, 14:09
Ok, ich war da eben nicht ganz korrekt mit meiner Antwort.

Ein Click ist wie folgt deklariert: Ein WM_LBUTTONDOWN und WM_LBUTTONUP Nachricht muss innerhalb der Grenzen eines Controls erfolgen. Die Zeitspanne zwischen WM_LBUTTONDOWN und WM_LBUTTONUP ist unerheblich (können auch mehrere Stunden sein, wenn man keinen Krampf im Finger bekommt).

Ein DoubleClick ist da schon etwas anderes. Das Betriebssystem selber erkennt den DoubkeClick und sendet dann eine WM_LBUTTONDBLCLK Nachricht. Auslöser dafür ist das erneute drücken der Maustaste innerhalb eines bestimmten Zeitraums innerhalb bestimmter Grenzen (einstellbar im Betriebssystem).

Für jeden DoppelKlick erhält man also folgende Nachrichten:
Code:
WM_LBUTTONDOWN -> WM_LBUTTONUP -> WM_LBUTTONDBLCLK -> WM_LBUTTONUP
Das System sendet nun also anstatt einer simplen WM_LBUTTONDOWN eine WM_LBUTTONDBLCLK Nachricht (aufgepasst, die Maus-Taste ist noch gedrückt) und wenn die Taste losgelassen wird wie gehabt eine WM_LBUTTONUP Nachricht.

Delphi-Spezifisch

In Delphi selber kann man sich darauf verlassen, dass es zu einem MouseUp Event auch ein MouseDown Event gegeben hat (diese tauchen also zeitlich getrennt immer paarweise auf). Darum wird in Delphi auch der MouseDown Event bei der Nachricht WM_LBUTTONDBLCLK ausgelöst, denn sonst würde bei einem DoppelKlick dieser Paarlogik gebrochen.

Es geht auch anders

Bei Microsoft und WinForms, da wird der Click und DoubleClick Event erst bei MouseUp ausgelöst. Allerdings bekommt man hier nun ein etwas anderes Verhalten bei einem Doppelklick.

So kann man hier einen DoubleClick wie den Click herauszögern oder sogar verhindern, wenn man beim zweiten Drücken die Taste festhält und dann eine beliebige Zeitspann wartet und dann irgendwann die Maustaste löst.
  Mit Zitat antworten Zitat
Benmik

Registriert seit: 11. Apr 2009
557 Beiträge
 
Delphi 12 Athens
 
#12

AW: Doppelklick in MouseDown erkennen (MouseDown vs. DblClick)

  Alt 31. Dez 2018, 16:50
Finde ich jetzt nicht wirklich gut.
Naja, ich kam hierher durch eine Suche. Der Titel passt perfekt zu dem, was ich suchte, so dass andere auch genau hier landen werden. Ich hätte künstlich einen anderen Titel vergeben müssen, dann hätten alle zwei Themen durchgehen müssen.

Natürlich war mir klar, dass sich Borland seinerzeit etwas dabei gedacht hat. Die Erklärung von Schokohase habe ich dann beim zweiten Durchlesen begriffen.

In all den Jahren war ich fest der Überzeugung, dass die Reihenfolge so ist: WM_LBUTTONDOWN -> WM_LBUTTONUP -> WM_LBUTTONCLK -> WM_LBUTTONDBLCLK . Soso, WM_LBUTTONCLK gibt es gar nicht. Und der Doppelklick kommt vom Betriebssystem. Jetzt verdrehen hier alle alten Hasen die Augen, aber ich bin mir völlig sicher, dass so mancher stiller Mitleser ebenso platt ist wie ich.

Also: Bei jedem MouseDown aufpassen, wenn es auch noch ein DblClick gibt. Der Tipp von Uwe mit (ssDouble in Shift) ist dabei sehr nützlich. Das ist ja ein Minenfeld hier.
  Mit Zitat antworten Zitat
Schokohase
(Gast)

n/a Beiträge
 
#13

AW: Doppelklick in MouseDown erkennen (MouseDown vs. DblClick)

  Alt 31. Dez 2018, 20:29
Es steht aber so geschrieben
Zitat:
Double-clicking the left mouse button actually generates a sequence of four messages: WM_LBUTTONDOWN, WM_LBUTTONUP, WM_LBUTTONDBLCLK, and WM_LBUTTONUP.
Es ist also mehr eine Frage ob man die Dokumentation gelesen hat.
  Mit Zitat antworten Zitat
Benmik

Registriert seit: 11. Apr 2009
557 Beiträge
 
Delphi 12 Athens
 
#14

AW: Doppelklick in MouseDown erkennen (MouseDown vs. DblClick)

  Alt 31. Dez 2018, 20:59
Aber klar ist es das. Und ganz bestimmt habe ich nicht alle Dokumentation über alles gelesen. Das haben die Profis aber immer wieder auch nicht, wie man hier unschwer mitlesen kann. Die über solche grundlegenden Dinge wie Mausereignisse aber vermutlich schon. Schön für die Profis. Sie wären aber vermutlich nicht mehr lange Profis, wenn sie es nicht täten.

Übrigens hätte mir das Studium der Dokumentation hier auch nur bedingt geholfen. Denn am Ende der Sequenz kommt bei Windos WM_LBUTTONUP, bei Delphi aber MouseDown. Egal, wieder was gelernt.

Geändert von Benmik (31. Dez 2018 um 21:01 Uhr)
  Mit Zitat antworten Zitat
Schokohase
(Gast)

n/a Beiträge
 
#15

AW: Doppelklick in MouseDown erkennen (MouseDown vs. DblClick)

  Alt 31. Dez 2018, 21:35
Der Hinweis auf die Dokumentation soll ja auch nur die Verwunderung bremsen, weil es eben kein geheimes Wissen ist. Mehr nicht.

Warum Delphi den MouseDown Event feuert habe ich auch erläutert und ja, wenn man mit Delphi für Windows programmiert, dann muss man sich mit Delphi und Windows auseinandersetzen. Da sollte jetzt aber nicht neu sein. Da die Dokumentation von Delphi teilweise schwach bis gar nicht vorhanden ist, muss man dort auch mal in den Source schauen (soweit es möglich ist).
  Mit Zitat antworten Zitat
Benmik

Registriert seit: 11. Apr 2009
557 Beiträge
 
Delphi 12 Athens
 
#16

AW: Doppelklick in MouseDown erkennen (MouseDown vs. DblClick)

  Alt 1. Jan 2019, 18:58
"Verwunderung" ist ja eine freundliche Umschreibung ...

Der Hobbyprogrammierer unterscheidet sich ja vom Profi (unter anderem) darin, dass er nicht alles von der Pike auf lernt, sondern in der Regel nur das, was er gerade braucht (oder zu brauchen glaubt). Das bringt Lücken mit sich, die dem Profi die Haare zu Berge stehen lassen.

Das Problem hier bestand darin, dass ich gar nicht auf die Idee kam, meine Vorstellung vom Ablauf eines Doppelklicks zu hinterfragen (so wie auch hier geschehen). Selbst wenn, dann hätte ich ohne dieses Forum die Hintergründe niemals so schnell erfahren. Das ist ja die erstaunliche Stärke der Delphi-Praxis, dass sich hier gestandene Experten nicht zu schade sind, ihre Zeit (und ihre Haare, die sie sich dauernd raufen) Anfängern zu widmen.

Natürlich ist es auch schön, wenn man mal den Platz auf der anderen Seite der Schulbank einnehmen kann. Und da verwundert es nicht, dass es hier strenge pädagogische Prinzipien gibt, und zwar noch von der guten alten Art. Ein ehernes lautet: Eigenleistung! Das Kind bekommt nichts fertig vorgesetzt, es soll sich selber anstrengen! Wenig hat mich so erheitert wie dieser Sketch, in dem gestandene Erwachsene um die Generation Z herumtanzen (ideales Subjekt für eine psychologische Seminararbeit: DieDolly). Man muss KetchUp aber auch für seine Bierruhe und sein Durchhaltevermögen bewundern. Wie sehr man aber der eigenen Sphäre verhaftet ist, das sieht man unter anderem (nur ein Beispiel!) an diesem Kommentar. Es ging um ein Schulprojekt! Jetzt bin ich über die Phase von Schulprojekten hinaus, aber ich bin mir sicher, dass man sich noch öfter über meine Lücken wird wundern müssen. Ich werde nie mit Delphi mein Brot verdienen - morgen fängt mein RL wieder an!
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12   


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 10:05 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