Trapping double-click before mouse down event


I am wondering if it is possible to delay the processing of the MouseDown event until after processing a DoubleClick event.

I need to use MouseDown, but I also have to check for a double-click.  The double-click needs to take precedence over an ordinary mouse down event.

Can the MouseDown event be delayed?
Who is Participating?
Thanx, jdthedj...    :-)
That's what I've written on top of my tools unit. It's the order of the mouse messages. "d=down; c=click; u=up; 2=double click".
So you see, the second mouse down comes AFTER the double click event. So all you have to do is set a variable in the double click event that the next down event must not be handled.
Or do you want to delay the FIRST mouse down event? That will not be possible, because at that time noone knows (perhaps even the user not) whether it will be a single or a double click.

Regards, Madshi.
jdthedjAuthor Commented:
Hi Madshi - Thanks for replying

Thanks for the order of processing - it helps a bit - I think, but my application works in a similar way to a lot of regular windows programs - the user may either double-click an item, or single click and then click OK.  

I have to use MouseDown to retrieve the X and Y coordinates of the hotspot area so that I know that the user has clicked in the right place.

Any ideas??
Free Tool: ZipGrep

ZipGrep is a utility that can list and search zip (.war, .ear, .jar, etc) archives for text patterns, without the need to extract the archive's contents.

One of a set of tools we're offering as a way to say thank you for being a part of the community.


It's simple. in the mousedown procedure, just call the doubleClick event with the correct parameters in the first statement. So in this way, a doubleclick event is called before the mousedown event.

but beware: this is very tricky.

What you want is very easy to achieve using the OnMousemove event.
This event (from Tcontrol, but not always published) fires when the mouse is over the control. And that seems to be the only thing you want?

procedure TForm1.Button1MouseMove(Sender: TObject; Shift: TShiftState; X,
  Y: Integer);
 Caption:='Yes, i"m here';

You mean, you need the position of the mouse at the time the double click has happened?
You could write an own message handler for the WM_LBUTTONDBLCLK message. Windows tells you the position with this message. Delphi hides the position, don't know why.

Add this to your main form:
    procedure LButtonDblClick(var Message: TMessage); message WM_LBUTTONDBLCLK;

Regards, Madshi.
jdthedjAuthor Commented:
Thanks for the replies.  I think I still need to clarify a bit.

If a person double-clicks I need to IGNORE an OnClick event or a MouseDown event, but the problem is that a single click or a mouse down event fires before the double click event.  

Any thoughts?  
Ok, how about that:
you could do nothing but set a timer in the MouseDown or MouseClick event that is fired before the double click event.
Then, if the double click event is fired before the timer has expired, you could stop the timer and do the double click action. Otherwise, when the timer has expired and there were no double click event in the meanwhile you could do the mouse down/mouse click action.
Have I understood this time, what you need?
If I have, this is the only way I can image to solve your problem...

Regards, Madshi.
jdthedjAuthor Commented:
Hi Madshi - Thanks for your patience.

You have shown me what to do, so if you would like to turn your latest reply into an answer I will give you the points.  Thanks again.

Sorry Makli, but your answer was not quite what I was looking for.
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

All Courses

From novice to tech pro — start learning today.