X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/2dcbc4615b8991370eb4ab77eca49e4f97c52a4c..b404a8f3b072129c107c6d9a5e0f6f53cd34807b:/src/msw/uiaction.cpp?ds=sidebyside diff --git a/src/msw/uiaction.cpp b/src/msw/uiaction.cpp index ee59fd0603..e8c7d94df8 100644 --- a/src/msw/uiaction.cpp +++ b/src/msw/uiaction.cpp @@ -16,9 +16,12 @@ #if wxUSE_UIACTIONSIMULATOR #include "wx/uiaction.h" -#include "wx/window.h" //for wxCharCodeWXToMSW #include "wx/msw/wrapwin.h" +#include "wx/msw/private/keyboard.h" + +#include "wx/math.h" + namespace { @@ -55,11 +58,13 @@ bool wxUIActionSimulator::MouseMove(long x, long y) { // Because MOUSEEVENTF_ABSOLUTE takes measurements scaled between 0 & 65535 // we need to scale our input too - int displayx, displayy, scaledx, scaledy; + int displayx, displayy; wxDisplaySize(&displayx, &displayy); - scaledx = ((float)x / displayx) * 65535; - scaledy = ((float)y / displayy) * 65535; + + int scaledx = wxRound(((float)x / displayx) * 65535); + int scaledy = wxRound(((float)y / displayy) * 65535); mouse_event(MOUSEEVENTF_ABSOLUTE | MOUSEEVENTF_MOVE, scaledx, scaledy, 0, 0); + return true; } @@ -75,7 +80,7 @@ bool wxUIActionSimulator::DoKey(int keycode, int WXUNUSED(modifiers), bool isDown) { bool isExtended; - DWORD vkkeycode = wxCharCodeWXToMSW(keycode, &isExtended); + DWORD vkkeycode = wxMSWKeyboard::WXToVK(keycode, &isExtended); DWORD flags = 0; if ( isExtended )