I\'ve often struggled with simulating keyboard press events for various bots, or other GUI automating programs.
I\'ve managed to simulate keydown events using:
Now I think a lot of this actually depends on the specifics of the game/3d application you are trying to 'fool'.
For some odd case in my first attempt to trick the particular game I was working on it would accept merely a single SCANCODE as enough of a keypress to toggle a skill, as long as the game window itself was regaining focus. (I.E. you have a web browser open, your application switches to the game window and then fires the SCANCODE event).
However, for some odd reason, while I could get this to work for the first time after the window regained focus, I couldn't get the event to repeatedly fire at all after that.
This puzzled me, until eventually I came to a post on here stating "Repeating keystrokes is a feature of the keyboard controller, not of Windows or SendInput. You can certainly emulate it with a timer, repeatedly calling SendInput()."
Which gave me the idea that instead of sending just one keystroke, or two inputs (one extended key down, the other a key up), why not attempt to send a stream of inputs the way a hardware device MIGHT (which I don't actually know for sure if it does, but it all seemed like a good idea at the time)
So eventually, and there were failures (mainly trying to send X amount of single INPUT1), what I came up with, was this:
INPUT[] kInput = new INPUT[30];
for (int j = 0; j < kInput.Length - 1; j++)
{
//activate skill
//INPUT[] kInput = new INPUT[2];
kInput[j].type = SendInputEventType.InputKeyboard;
kInput[j].mkhi.ki.wVk = 0;
kInput[j].mkhi.ki.wScan = (ushort) MapVirtualKey((uint) Keys.D5, 0);
kInput[j].mkhi.ki.dwFlags = KeyboardEventFlags.SCANCODE;
kInput[j].mkhi.ki.time = 0;
kInput[j].mkhi.ki.dwExtraInfo = IntPtr.Zero;
}
kInput[kInput.Length - 1].type = SendInputEventType.InputKeyboard;
kInput[kInput.Length - 1].mkhi.ki.wVk = 0;
kInput[kInput.Length - 1].mkhi.ki.wScan = (ushort)MapVirtualKey((uint)Keys.D5, 0);
kInput[kInput.Length - 1].mkhi.ki.dwFlags = KeyboardEventFlags.KEYUP;
kInput[kInput.Length - 1].mkhi.ki.time = 0;
kInput[kInput.Length - 1].mkhi.ki.dwExtraInfo = IntPtr.Zero;
SendInput((uint)kInput.Length, kInput, Marshal.SizeOf(typeof(INPUT)));
And this seems to work well enough for me for the game I am current trying to 'fool' with it. This is the first time I have been able to simulate a key being held with SendInput the way that a human might hold one.
Now please note that in my example, my Input array is of size 30. This isn't 30 because 30 is some magic value, it's 30 because because 30 was the first and only number I had to pick to achieve the result I desired.
Using this code, I have been able to emulate the long sought after keyboard key being held event. I hope that this will help others who have been trying to achieve this effect. I hope that this works for others. And I hope that people more technically inclined than myself, can explain how hardware actually simulates a key held event in the input stream and how send input can be made to more closely do the same.
To simulate keyboard events in directX games you need wrapper for a keyboard driver. I had the same issue, and neither of this methods (SendInput, SendKeys class) doesn't help me. Try to use this wrapper, to me it was successfully.