tags:

views:

324

answers:

2

This has been bothering me lately- when I use some code like below to increase selection every mouse click: if (m.LeftButton == ButtonState.Pressed) currentSelection++; Then currentSelection increases by a ton, simply because this code is in my Update() function and by design, runs every frame and so increases currentSelection. There is almost no chance you can click and release fast enough to prevent currentSelection from increasing more than one.

Now my question is what I should do to make it so everytime I click the mouse down once, it only increases currentSelection once until the next time I click down again.

+2  A: 

I'm sure you'll like this.

http://stackoverflow.com/questions/904454/how-to-slow-down-or-stop-key-presses-in-xna

Jubjub
I'm sure I will. I really need to hone my search-wording skills...
DMan
+4  A: 

You will need to compare the current mouse state and the last update's mouse state.

In your class you'll have MouseState mouseStateCurrent, mouseStatePrevious; declared and so it'll be something like:

mouseStateCurrent = Mouse.GetState();

if (mouseStateCurrent.LeftButton == ButtonState.Pressed &&
    mouseStatePrevious.LeftButton == ButtonState.Released)
{
    currentSelection++;
}

mouseStatePrevious = mouseStateCurrent;

So it will detect that previous time you pressed it, then you release it - only then it is considered as a click and it will add to currentSelection.

thephpdeveloper
DMan
Haha, never mind, I realized it was that you used '=' instead of '=='. =) This works, thanks.
DMan
I edited in the == fix.
Ricket
Thanks Ricket! Much appreciated.
DMan