WinSendKeys | Version: 3.2.2.2 Size: 501 kB |
Category: AutoIt3 | |
Last update: 2020-05-06 | Support: DonationCoder thread |
New:2020-05-06: WinSendKeys 3.2.2.2: Fixed a bug where a <windowname> was required when -f <strokesfile> was used, as the <windowname> can also be specified in the <strokesfile>.
2020-05-05: WinSendKeys 3.2.2.1: Fixed a standard library issue when using -x argument. No changes to WinSendKeys.
2018-11-04: WinSendKeys 3.2.2.0: Added -i <delay>, -s <delay> and -sd <delay> arguments to set an initial delay before sending and send-delays per character and the time a 'key' is held down.
2018-11-03: WinSendKeys 3.2.1.1: Now sets ERRORLEVEL to 1 if the Window (-w argument) isn't found, recompiled with latest AutoIt3 compiler (v3.3.14.5)
2011-10-01: WinSendKeys 3.2.1.0: Added setting -v option from the ini file and more documentation about the ini file
2011-09-30: WinSendKeys 3.2.0.1: Added more commands to multiple-window feature using -f mode
2011-06-21: WinSendKeys 3.1.0 Added -v commandline parameter and multiple-window feature using -f mode
A tool to send keystrokes and/or mouseclicks to an application that is running, or can be started on demand if found not running yet.
Use-case:
Split_e, user at the DonationCoder.com forum, needed a tool to flip the pages of his e-book reader software, after shooting a screen using ScreenShotCaptor.
That tool wasn't easily found on the internet, but scripting tools like AutoIt3 and AutoHotKey can easily do that, so it's a nice challenge to bring them together
Then WinSendKeys 1.0 was born, created using AutoIt3 mainly because I have some experience in it. It took me about an hour, including testing, to create it, and parsing a few command-parameters so it's a little manageble.
The next, yet unnumbered, release included debug-logging, and a few small improvements.
After the release, Split_e explained what and how he was using it, and that the e-reader PC software he's using wasn't keyboard-controlable any longer, so he added another AHK script to press a button in the interface.
But that mouse-press/control-clicking can ofcourse also be done by AutoIt3, so I decided to add that as a feature to WinSendKeys. After fiddling around a few hours, interpreting the sometimes sparse AutoIt3 documentation, it's now also controling the mouse and where it clicks.
I decided to name this version 2.0, because of the rather major enhancement.
Next was the promised feature of reading strokes from a file, and that was added in version 2.5
Version 2.6 added ClipBoard content handling.
Version 3.0 can optionally start an executable file (with parameters) if the WindowName is not found or executablename is not running yet.
Version 3.1 adds environment and macro expansion, and switching the targetwindow when using -f file mode.
Version 3.2 adds some scripting features and optional switching between destination targets to the .stro file.
A few settings are read from WinSendKeys.ini, if that file exists.
Usage:
The general use is to let WinSendKeys send keystrokes to an application you need to control 'from the outside' and without direct user-interaction.
Commands can be provided as parameters on the command-line, in a specified textfile or via the Clipboard, one stroke per line.
Syntax:
WinSendKeys [-d] [-t keydelay] [-m|-mm speed] [-c|-cc] [-cn] [-x executable_filepath] [-xp executable_parameters] [-f strokesfile] [-v] [-w] [] [] [...]
Options: (anything between [] is optional)
-d | Enable debug mode, writing log information to WinSendKeys.log (or whatever the tool is renamed to), and displays a messagebox if the window isn't found. Most useful if placed as first on the commandline, then also logs command line parsing. |
||||||||||||
-t keydelay | Change the delay between separate KeyStrokes/MouseStrokes. Value in milliseconds. Default is 100 msec. | ||||||||||||
-i delay | Insert an initial delay before anything is sent to the window, but after selecting it. Default is 0 msec. |
||||||||||||
-s delay | Change the delay between each character in a KeyStroke/MouseStroke sent. Default is 5 msec (AutoIt standard). 0 removes any delay. |
||||||||||||
-sd time | Change the time the 'key' for each character sent is held down. Default is 5 msec (AutoIt standard). 0 removes any delay. |
||||||||||||
-m | Enable MouseStrokes mode. Speed = 0, moves the mousecursor immediately, without animation. | ||||||||||||
-mm speed | Enable MouseStrokes mode with mouse moving with from it's current position to the new position. Valid range: 1 (fast) to 100 (slow). Out of range sets speed to 0. | ||||||||||||
-f strokefile | Read KeyStrokes and/or MouseStrokes from this file, line by line, keydelay is applied after each line. Comments have a semicolon in the first position, empty lines are ignored. Command-line strokes are handled first. | ||||||||||||
If a line in a strokesfile starts with one of these commands: | (these commands are not supported from the commandline! but -f ofcourse is) An extra strokesfile demonstrating these features is included: WinSendKeys-MultiWindow.stro |
||||||||||||
--window windowname | Switch focus/keystrokes to windowname, the same rules as for the -w commandline parameter apply | ||||||||||||
--exec exename | equivalent to -x commandline parameter. If the windowname or exename can not be found/activated or started, the -f processing will be stopped! | ||||||||||||
--exec "exename"_"parameters" | the same as combining -x and -xp commandline parameters, all 4 quotes and the underscore are required! Any -xd setting required should be supplied at the commandline. --exec allows for environment and macro parameters to be expanded, as explained with -v parameter, but here it's always enabled |
||||||||||||
--delay delay_in_msec | delay processing for this count of milliseconds | ||||||||||||
--winwait windowname [maxwait] | Wait for a windowname, title or exename to be or get active, and select that. Wait indefinately (default) or the number of seconds specifed in maxwait | ||||||||||||
--winclose windowname [maxwait] | Wait for a windowname, title or exename to be closed/go away. Wait indefinately (default) or the number of seconds specifed in maxwait | ||||||||||||
if maxwait is set, and the timeout expires, the result can be tested with --error | |||||||||||||
--error quit | Test the result of a timed --winwait/--winclose, and if it expired, quit the script | ||||||||||||
--error goto | Test the result of a timed --winwait/--winclose, and if it expired, goto that label in the script | ||||||||||||
--: | Set a label marker in a script to --error got, --goto or --gosub to | ||||||||||||
--goto | Continue processing at the named --: | ||||||||||||
--gosub | Jump to the routine at --: | ||||||||||||
--return | Return to the line after the last gosub that was activated. If encountered without an 'active' gosub, the script continues without error | ||||||||||||
--quit | End the script | ||||||||||||
--msg [timeout,]message text | Display a message as define in the message text, optionally using environment variables surrounded with %, macro's surrounded with @ or script variables surrounded with $ | ||||||||||||
Most useful (and guaranteed to exist) variable would be $params$, the parameters that can be passed with --gosub Available @macro@ variables can be found in the AutoIt3 @macro docs |
|||||||||||||
Sets status for --error if the optional timeout (in seconds) expires. | |||||||||||||
an extra strokes file showing these --winwait, --winclose, --error, --gosub and --msg features is included: WinSendKeys-WaitWindow.stro | |||||||||||||
(Continuation of command-line parameters) | |||||||||||||
-c | Send any text-content of the Windows Clipboard to the WindowName selected. | ||||||||||||
-cn | Like -c option, but does not send an {ENTER} after each line/command, can be added after -c or -cc to disable the {Enter} being sent | ||||||||||||
-cc | Like -c option, but the clipboard content can be embedded at the commandline using #$ prefix, like: |
||||||||||||
-x executable_filepath | Specify an executable to start if WindowName is not found. If no WindowName is specified, the executable is searched first, and executed if not found. Surround with quotes if the path has any spaces. Any %environment.var% and @macro@ variables are expanded. |
||||||||||||
-xp executable_parameters | Any parameters to pass onto executable_filepath, if the parameters need spaces then use quotes to group the parameters together. Any %environment.var% and @macro@ variables are expanded. | ||||||||||||
-xd delay | Delay for millisecondes after running -x executable_filepath, to allow for starting & initializing that app. It is added to the -t delay (100 msec) that was already there. Default = 0. | ||||||||||||
-v | Variable expansion mode. When enabled allows %environment% and @macro@ variables to be expanded for keystrokes that are sent to the window. The behavior is described here: AutoItSetOption sections ExpandEnvStrings and ExpandVarStrings | ||||||||||||
-? | Display the default help window | ||||||||||||
-w WindowName | Select (bring to foreground) an active, visible, application with this name/title. Exact rules/format documented here So WindowName kan be a partial match, like "- notepad" to select a notepad instance with an open document, or "readme.txt - notepad" to explicitly select that window, or [CLASS:Notepad] to select Windows Notepad. Next to specifying an application by title, it can also be selected by naming the Window ClassName, etc. as documented. When passing a numeric value (not hex!) then it will be converted to a Window Handle (HWnd), for other tools to more easily pass a known window -> This rather technical information can best be determined using 'AutoIt Window Info', installed with AutoIt3, as it presents the information in a way that can easily be copy/pasted onto the command-line or into a (batch)script. If the window can not be found, no keys are sent, use [ACTIVE] to send keystrokes to the current active window. If no KeyStrokes or MouseStrokes are specified, then only the window is activated. If WindowName is not specified but -x executable_filepath option is used, then that window is activated if it was already running. |
||||||||||||
Keystrokes are descriptive keys or normal text, to be sent to the window just specified. If no keystrokes or mousestrokes are specified, then only the window is brought to front. The entire set of keys is documented here Keys can be sent in small or larger groups, depending on requirement and reaction-speed of the application. Keystrokes grouped together (using quotes, or without spaces) are sent as one sequence, when separated by a space, the keydelay is applied, so using {TAB}^^b^^u sends these 3 keystrokes , Ctrl-B, Ctrl-U as 1 group, and {TAB} ^^b ^^u sends , delay(100 msec), Ctrl-B, delay(100 msec), Ctrl-U, to the application. -> The ^ character, meaning Ctrl in AutoIt3 speak, NEEDS to be doubled on a Windows commandline, as a single ^ is the escape-character for otherwise special characters in CMD.EXE like >, ( etc. If you need to send a space, or want to send multiple the same keystrokes, just wrap it inside single or double quotes, like ' ' for a space ({SPACE} would also work), or "{DOWN 5}" to send 5 times a DownArrow keypress. -> Sending Ctrl or Alt keys is usually best done using lower-case letters, as not all apps support upper-case here or interpret Ctrl-Shift- differently. |
|||||||||||||
MouseStrokes are sets of parameters to either the ControlClick or MouseClick function of AutoIt3. Documentation for ControlClick Documentation for MouseClick The ControlClicks or MouseClicks are distinguished from KeyStrokes by a prefix, ## for ControlClick, and #% for MouseClick. |
|||||||||||||
ControlClick parameters: ##[],[],Control[,Button[,Clicks[,x[,y]]]] | |||||||||||||
|
|||||||||||||
Example: WinSendKeys -m "Management Console" "##,,[CLASS:TToolBar; INSTANCE:1],,,12,12" This clicks on a window called Management Console, and presses a key on a toolbar, on coordinate 12,12 within the toolbar, where the Close button is located The ControlClick is enclosed in quotes because the control specification has a space in it, and that would split this MouseStroke, which isn't supported. |
|||||||||||||
MouseClick parameters: #%Button,x,y[,Clicks[,speed]] | |||||||||||||
|
|||||||||||||
Example: WinSendKeys.exe -m "Management Console" #%,20,70 Clicks in the same windows as the ControlClick example, but this time clicks on the relative position of the toolbar button within the window to close the application. |
|||||||||||||
ClipboardStrokes examples: | |||||||||||||
Example 1: WinSendKeys -cc [ACTIVE] dir{Enter} #$ {Tab} - This sends a 'dir' command (activated by {Enter}) to the currently active window (a cmd.exe session?), the first line of the clipboard including an {Enter}, and a {Tab} keystroke. |
|||||||||||||
Example 2: WinSendKeys -c [ACTIVE] - This sends all lines on the clipboard to the currently active window (a cmd.exe session?), each followed by an {Enter} |
|||||||||||||
Settings in WinSendKeys.ini: | |||||||||||||
The name of the inifile is the same as the name of the executable or au3 file of WinSendKeys. | |||||||||||||
Supported (optional) settings in a section called [Settings]: | |||||||||||||
[Settings] | |||||||||||||
delay= | The delay in milliseconds between (sets of) keystrokes sent, default = 100 msec. See -t command-line option. | ||||||||||||
initialdelay= | Insert an initial delay before anything is sent to the window, but after selecting it. Default is 0 msec. |
||||||||||||
senddelay= | Change the delay between each character in a KeyStroke/MouseStroke sent. Default is 5 msec (AutoIt standard). 0 removes any delay. |
||||||||||||
senddowndelay= | Change the time the 'key' for each character sent is held down. Default is 5 msec (AutoIt standard). 0 removes any delay. |
||||||||||||
mousestrokes= | Enable or disable (default) the use of MouseStrokes, mouse commands sent from WinSendKeys, 0 = off, 1 is on. See -m command-line option. | ||||||||||||
mousespeed= | The speed-factor for mouse-moves, 0 = immediate, range 1..100 where 1 is fast, and 100 is (quite) slow, see -mm command-line option and 'Speed' in this AutoIt doc page | ||||||||||||
exedelay= | The delay to obey after an exe is started, before it's activated by WinSendKeys, default = 0, see -xd command-line option. | ||||||||||||
expandvariables= | Enable environment, macro and local AutoIt variable expansion for keystrokes sent (default off for compatibility reasons), 0 = off, 1 is on. See -v command-line option. |
- Version
- Downloads 1326
- File Size 354.03 KB
- File Count 1
- Create Date May 6, 2020
- Last update 2020-05-06 21:00:05
- Last Updated May 6, 2020