![]() |
"Falsche" Klicks durch Doppelklicks
Hallo liebe Experten hier,
ich habe bei meinen Programmen immer mal wieder das Problem, dass Kunden z.B. in einem angezeigten Fenster auf "OK" doppelklicken. Wird dann dabei das Fenster geschlossen, kann es passiert, dass ein Klick auf das darunterliegende Fenster "weitergeleitet" wird, sodass manchmal das Programm "seltsame" Dinge tut, die der Kunde ja eigentlich nicht wollte. (und bei denen es echt mühselig ist herauszufinden, wieso dies und jenes passiert). Meine Frage an euch: Wie geht ihr mit solchen Möglichkeiten um? Gibt es Tricks oder Dinge, die ich als Entwickler im Quellcode beachten kann/sollte? Ich habe mal gelesen, der beste Programmtest wäre es, sich einfach auf die Tastatur zusetzen - das Programm sollte stabil weiterlaufen. So ganz von der Hand zu weisen ist das wohl nicht :shock: :) |
AW: "Falsche" Klicks durch Doppelklicks
Sollte da nicht ein Application.Processmessages im OnCloseQuery des Hauptfensters reichen? Damit wird die Evenqueue des Tasks ausgefegt und dann geschlossen.
Grüße, Messie |
AW: "Falsche" Klicks durch Doppelklicks
Vielleicht wäre es möglich, eine Button-Komponente abzuleiten, die einen Doppelklick-Ereignishandler hat? Dann wird nämlich automatisch bei einem Einfack-Klick eine gewisse Zeit auf einen zweiten Klick gewartet, und es wird nicht sofort das normale OnClick-Ereignis ausgelöst. So ist es bei anderen Komponenten, die ein Doppelklick-Ereignis besitzen.
Die andere Möglichkeit, die mir einfiele, wäre, in den OnClick-Handler ein kleines Delay einzubauen, was aber nicht gerade schön wäre. |
AW: "Falsche" Klicks durch Doppelklicks
Du könntest Dir die Schließzeit der Fenster (bzw. auch das Auslösen bestimmter Aktionen) global merken und weitere Aktionen innerhalb x ms ignorieren.
|
AW: "Falsche" Klicks durch Doppelklicks
Zitat:
Ich habe nun einen Delay von 100ms eingerichtete, der recht zuverlässig alle Doppelklicks abfängt. Eine Ableitung von TButton bietet sich leider so schnell nicht an, da ich ja alle Formulare umbauen müsste und dazu fehlt mir einfach die Zeit. Ich bin ja schon froh, dass ich endlich eine Erklärung für komische Kunden-"Fehlermeldungen" habe... :roll: |
AW: "Falsche" Klicks durch Doppelklicks
Warum solltest du dafür die Formulare umbauen müssen?
Dafür kann man doch die Klassen "hacken" ;) Einfach eine Unit bauen mit der nötigen Erweiterung und dann bei jeder Form die Unit einbinden.
Delphi-Quellcode:
unit uButtonHack;
interface uses StdCtrls; type TButton = class( StdCtrls.TButton ) // hier kannst du dich jetzt austoben ;) end; implementation end. |
AW: "Falsche" Klicks durch Doppelklicks
Zitat:
|
AW: "Falsche" Klicks durch Doppelklicks
Wenn man alles über Actions ausführt (natürlich noch nicht in FMX) dann kann man das ja am OnExecute der Actionlist festmachen.
|
AW: "Falsche" Klicks durch Doppelklicks
Zitat:
Das mit den Buttons klingt doch ganz interessant...ich werde das mal antesten, danke! |
AW: "Falsche" Klicks durch Doppelklicks
Was sind das für Nutzer? Sind es ältere Menschen oder sind sie behindert oder sind es ganz normale Menschen, wie du und ich? Wenn es normale Personen sind, würde ich sagen: "Lernt endlich Windows zu bedienen." Oder ich würde das Formular, welches darunter liegt, etwas umgestalten, so dass der zweite Klick aufs leere Fenster geht und nicht auf ein Steuerelement.
|
AW: "Falsche" Klicks durch Doppelklicks
Ich würde ehrlichgesagt eher Zeit in die Schulung der User stecken. Wenn die nicht lernen, wie man eine Windowssoftware üblicherweise bedient, wirst Du bis zum Sankt Nimmerleinstag Hacks programmieren.
|
AW: "Falsche" Klicks durch Doppelklicks
Es gäbe noch Trick 17 mit Selbstüberlistung. Statt dem Delay legst du ein Overlay über das untere Form (gab es hier glaub ich schon mal in nem Thread), nach dem Schließen des modalen Fensters fadest du das wieder aus. Damit "vertuschst" du quasi die Wartezeit und eventuelle Klicks gehen auf das Overlay und nicht die Controls darunter.
Das Problem ist übrigens auch auf Webseiten sehr beliebt :D Doppelklick zum Öffnen... |
AW: "Falsche" Klicks durch Doppelklicks
Zitat:
|
AW: "Falsche" Klicks durch Doppelklicks
Zitat:
Zitat:
|
AW: "Falsche" Klicks durch Doppelklicks
@Luckie: Komm, die OT beenden wir mal hier. Nur eins, ich betrachte den User als Kunden. Und wenn der Kunde Zitterfinger hat sichere ich mein UI entsprechend ab. Das kriegt man mit einer Windows-Schulung nämlich nicht in den Griff und es kommt auch gar nicht gut an.
|
AW: "Falsche" Klicks durch Doppelklicks
Zitat:
Der Typ Mensch halt, der auch auf Internet-Links doppelklickt :-D Und bevor ich den Leuten klarmache, dass sie ja *eigentlich* den PC falsch bedienen, baue ich lieber eine (deaktivierbare) Sicherheitsfunktion ein ;) |
AW: "Falsche" Klicks durch Doppelklicks
Zitat:
Wenn ein Käufer kommt, der kein Kupplungsbein hat? Empfiehlt man dem, Taxi zu fahren oder verkauft man ihm einen Automatikwagen? :wink: |
AW: "Falsche" Klicks durch Doppelklicks
[QUOTE=Luckie;1126632]
Zitat:
Wie soll ich dann die Steuerelemente denn deaktivieren? Denn das Formular wird ja geschlossen und dann soll die Tabelle ja wieder problemlos bedienbar sein - es sei denn, ich baue einen Timer ein, wobei ich ja dann wieder bei der Delay-Lösung bin. Ich sehe das Ganze positiv: Ich lerne immer was Neues und weiß, wo ich auch nach seltsamen "Bugs" suchen muss. :cyclops: |
Alle Zeitangaben in WEZ +1. Es ist jetzt 23:13 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