1 | <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0//EN">
|
---|
2 | <html>
|
---|
3 | <head>
|
---|
4 | <meta HTTP-EQUIV="Content-Type" CONTENT="text/html;CHARSET=iso-8859-1">
|
---|
5 | <meta name="keywords" content="Virtual Screen, Open Source, Software" />
|
---|
6 | <meta name="description" content="Mouse and Keyboard Sharing" />
|
---|
7 | <link rel="stylesheet" type="text/css" href="synergy.css" media="screen" />
|
---|
8 | <title>Synergy Configuration Guide</title>
|
---|
9 | </head>
|
---|
10 | <body class="main">
|
---|
11 | <p>
|
---|
12 | </p><h3>Synergy Configuration File Format</h3><p>
|
---|
13 | </p><p>
|
---|
14 | The synergy server requires configuration. It will try certain
|
---|
15 | pathnames to load the configuration file if you don't specify a
|
---|
16 | path using the <span class="code">--config</span> command line
|
---|
17 | option. <span class="code">synergys --help</span> reports those
|
---|
18 | pathnames.
|
---|
19 | </p><p>
|
---|
20 | The configuration file is a plain text file. Use any text editor
|
---|
21 | to create the configuration file. The file is broken into sections
|
---|
22 | and each section has the form:
|
---|
23 | <span class="codeblock">
|
---|
24 | section: <span class="arg">name</span>
|
---|
25 | <span class="arg">args</span>
|
---|
26 | end
|
---|
27 | </span>
|
---|
28 | Comments are introduced by <span class="code">#</span> and continue to
|
---|
29 | the end of the line. <span class="arg">name</span> must be one of the
|
---|
30 | following:
|
---|
31 | <ul class="code">
|
---|
32 | <li>screens
|
---|
33 | <li>aliases
|
---|
34 | <li>links
|
---|
35 | <li>options
|
---|
36 | </ul>
|
---|
37 | See below for further explanation of each section type. The
|
---|
38 | configuration file is case-sensitive so <span class="code">Section</span>,
|
---|
39 | <span class="code">SECTION</span>, and <span class="code">section</span>
|
---|
40 | are all different and only the last is valid. Screen names are the
|
---|
41 | exception; screen names are case-insensitive.
|
---|
42 | </p><p>
|
---|
43 | The file is parsed top to bottom and names cannot be used before
|
---|
44 | they've been defined in the <span class="code">screens</span> or
|
---|
45 | <span class="code">aliases</span> sections. So the
|
---|
46 | <span class="code">links</span> and <span class="code">aliases</span>
|
---|
47 | must appear after the <span class="code">screens</span> and links
|
---|
48 | cannot refer to aliases unless the <span class="code">aliases</span>
|
---|
49 | appear before the <span class="code">links</span>.
|
---|
50 | </p><p>
|
---|
51 | </p><h4>screens</h4><p>
|
---|
52 | </p><p>
|
---|
53 | <span class="arg">args</span> is a list of screen names, one name per
|
---|
54 | line, each followed by a colon. Names are arbitrary strings but they
|
---|
55 | must be unique. The hostname of each computer is recommended. (This
|
---|
56 | is the computer's network name on win32 and the name reported by the
|
---|
57 | program <span class="code">hostname</span> on Unix and OS X. Note
|
---|
58 | that OS X may append <span class="code">.local</span> to the name you
|
---|
59 | gave your computer; e.g. <span class="code">somehost.local</span>.)
|
---|
60 | There must be a screen name for the server and each client. Each
|
---|
61 | screen can specify a number of options. Options have the form
|
---|
62 | <span class="code"><span class="arg">name</span> =
|
---|
63 | <span class="arg">value</span></span> and are listed one per line
|
---|
64 | after the screen name.
|
---|
65 | </p><p>
|
---|
66 | Example:
|
---|
67 | <span class="codeblock">
|
---|
68 | section: screens
|
---|
69 | moe:
|
---|
70 | larry:
|
---|
71 | halfDuplexCapsLock = true
|
---|
72 | halfDuplexNumLock = true
|
---|
73 | curly:
|
---|
74 | meta = alt
|
---|
75 | end
|
---|
76 | </span>
|
---|
77 | This declares three screens named <span class="code">moe</span>,
|
---|
78 | <span class="code">larry</span>, and <span class="code">curly</span>.
|
---|
79 | Screen <span class="code">larry</span> has half-duplex Caps Lock and
|
---|
80 | Num Lock keys (see below) and screen <span class="code">curly</span>
|
---|
81 | converts the meta modifier key to the alt modifier key.
|
---|
82 | </p><p>
|
---|
83 | A screen can have the following options:
|
---|
84 | <ul>
|
---|
85 | <li><span class="code">halfDuplexCapsLock = {true|false}</span>
|
---|
86 | </p><p>
|
---|
87 | This computer has a Caps Lock key that doesn't report a
|
---|
88 | press and a release event when the user presses it but
|
---|
89 | instead reports a press event when it's turned on and a
|
---|
90 | release event when it's turned off. If Caps Lock acts
|
---|
91 | strangely on all screens then you may need to set this
|
---|
92 | option to <span class="code">true</span>
|
---|
93 | on the server screen. If it acts strangely on one
|
---|
94 | screen then that screen may need the option set to
|
---|
95 | <span class="code">true</span>.
|
---|
96 | </p><p>
|
---|
97 | <li><span class="code">halfDuplexNumLock = {true|false}</span>
|
---|
98 | </p><p>
|
---|
99 | This is identical to <span class="code">halfDuplexCapsLock</span>
|
---|
100 | except it applies to the Num Lock key.
|
---|
101 | </p><p>
|
---|
102 | <li><span class="code">halfDuplexScrollLock = {true|false}</span>
|
---|
103 | </p><p>
|
---|
104 | This is identical to <span class="code">halfDuplexCapsLock</span>
|
---|
105 | except it applies to the Scroll Lock key. Note that, by default,
|
---|
106 | synergy uses Scroll Lock to keep the cursor on the current screen. That
|
---|
107 | is, when Scroll Lock is toggled on, the cursor is locked to the screen
|
---|
108 | that it's currently on. You can use that to prevent accidental switching.
|
---|
109 | You can also configure other hot keys to do that; see <a href="#lockCursor">
|
---|
110 | lockCursorToScreen</a>.
|
---|
111 | </p><p>
|
---|
112 | <li><span class="code">switchCorners = <corners></span>
|
---|
113 | </p><p>
|
---|
114 | See <a href="#corners">switchCorners</a> below.
|
---|
115 | </p><p>
|
---|
116 | <li><span class="code">switchCornerSize = N</span>
|
---|
117 | </p><p>
|
---|
118 | See <a href="#cornerSize">switchCornerSize</a> below.
|
---|
119 | </p><p>
|
---|
120 | <li><span class="code">xtestIsXineramaUnaware = {true|false}</span>
|
---|
121 | </p><p>
|
---|
122 | This option works around a bug in the XTest extension
|
---|
123 | when used in combination with Xinerama. It affects
|
---|
124 | X11 clients only. Not all versions of the XTest
|
---|
125 | extension are aware of the Xinerama extension. As a
|
---|
126 | result, they do not move the mouse correctly when
|
---|
127 | using multiple Xinerama screens. This option is
|
---|
128 | currently <span class="code">true</span> by default. If
|
---|
129 | you know your XTest extension is Xinerama aware then set
|
---|
130 | this option to <span class="code">false</span>.
|
---|
131 | </p><p>
|
---|
132 | <li><span class="code">shift = {shift|ctrl|alt|meta|super|none}<br>
|
---|
133 | ctrl = {shift|ctrl|alt|meta|super|none}<br>
|
---|
134 | alt = {shift|ctrl|alt|meta|super|none}<br>
|
---|
135 | meta = {shift|ctrl|alt|meta|super|none}<br>
|
---|
136 | super = {shift|ctrl|alt|meta|super|none}</span>
|
---|
137 | </p><p>
|
---|
138 | Map a modifier key pressed on the server's keyboard to
|
---|
139 | a different modifier on this client. This option only
|
---|
140 | has an effect on a client screen; it's accepted and
|
---|
141 | ignored on the server screen.
|
---|
142 | </p><p>
|
---|
143 | You can map, say, the shift key to shift (the default),
|
---|
144 | ctrl, alt, meta, super or nothing. Normally, you
|
---|
145 | wouldn't remap shift or ctrl. You might, however, have
|
---|
146 | an X11 server with meta bound to the Alt keys. To use
|
---|
147 | this server effectively with a windows client, which
|
---|
148 | doesn't use meta but uses alt extensively, you'll want
|
---|
149 | the windows client to map meta to alt (using
|
---|
150 | <span class="code">meta = alt</span>).
|
---|
151 | </p><p>
|
---|
152 | </ul>
|
---|
153 | </p><p>
|
---|
154 | </p><a name="aliases"></a><h4>aliases</h4><p>
|
---|
155 | </p><p>
|
---|
156 | <span class="arg">args</span> is a list of screen names just like
|
---|
157 | in the <span class="code">screens</span> section except each screen
|
---|
158 | is followed by a list of aliases, one per line, <b>not</b> followed
|
---|
159 | by a colon. An alias is a screen name and must be unique. During
|
---|
160 | screen name lookup each alias is equivalent to the screen name it
|
---|
161 | aliases. So a client can connect using its canonical screen name
|
---|
162 | or any of its aliases.
|
---|
163 | </p><p>
|
---|
164 | Example:
|
---|
165 | <span class="codeblock">
|
---|
166 | section: aliases
|
---|
167 | larry:
|
---|
168 | larry.stooges.com
|
---|
169 | curly:
|
---|
170 | shemp
|
---|
171 | end
|
---|
172 | </span>
|
---|
173 | Screen <span class="code">larry</span> is also known as
|
---|
174 | <span class="code">larry.stooges.com</span> and can connect as
|
---|
175 | either name. Screen <span class="code">curly</span> is also
|
---|
176 | known as <span class="code">shemp</span> (hey, it's just an example).
|
---|
177 | </p><p>
|
---|
178 | </p><h4>links</h4><p>
|
---|
179 | </p><p>
|
---|
180 | <span class="arg">args</span> is a list of screen names just like
|
---|
181 | in the <span class="code">screens</span> section except each screen
|
---|
182 | is followed by a list of links, one per line. Each link has the
|
---|
183 | form <span class="code">{left|right|up|down}[<range>]</span> =
|
---|
184 | <span class="code">name[<range>]</span>. A link indicates which
|
---|
185 | screen is adjacent in the given direction.
|
---|
186 | </p><p>
|
---|
187 | Each side of a link can specify a range which defines a portion
|
---|
188 | of an edge. A range on the direction is the portion of edge you can
|
---|
189 | leave from while a range on the screen is the portion of edge you'll
|
---|
190 | enter into. Ranges are optional and default to the entire edge. All
|
---|
191 | ranges on a particular direction of a particular screen must not
|
---|
192 | overlap.
|
---|
193 | </p><p>
|
---|
194 | A <range> is written as <span class="code">(<start>,<end>)</span>.
|
---|
195 | Both <span class="code">start</span> and <span class="code">end</span>
|
---|
196 | are percentages in the range 0 to 100, inclusive. The start must be
|
---|
197 | less than the end. 0 is the left or top of an edge and 100 is the
|
---|
198 | right or bottom.
|
---|
199 | </p><p>
|
---|
200 | Example:
|
---|
201 | <span class="codeblock">
|
---|
202 | section: links
|
---|
203 | moe:
|
---|
204 | right = larry
|
---|
205 | up(50,100) = curly(0,50)
|
---|
206 | larry:
|
---|
207 | left = moe
|
---|
208 | up(0,50) = curly(50,100)
|
---|
209 | curly:
|
---|
210 | down(0,50) = moe
|
---|
211 | down(50,100) = larry(0,50)
|
---|
212 | end
|
---|
213 | </span>
|
---|
214 | This indicates that screen <span class="code">larry</span> is to
|
---|
215 | the right of screen <span class="code">moe</span> (so moving the
|
---|
216 | cursor off the right edge of <span class="code">moe</span> would
|
---|
217 | make it appear at the left edge of <span class="code">larry</span>),
|
---|
218 | the left half of
|
---|
219 | <span class="code">curly</span> is above the right half of
|
---|
220 | <span class="code">moe</span>,
|
---|
221 | <span class="code">moe</span> is to the left of
|
---|
222 | <span class="code">larry</span> (edges are not necessarily symmetric
|
---|
223 | so you have to provide both directions), the right half of
|
---|
224 | <span class="code">curly</span> is above the left half of
|
---|
225 | <span class="code">larry</span>, all of <span class="code">moe</span>
|
---|
226 | is below the left half of <span class="code">curly</span>, and the
|
---|
227 | left half of <span class="code">larry</span> is below the right half of
|
---|
228 | <span class="code">curly</span>.
|
---|
229 | </p><p>
|
---|
230 | <a name="asymmetric"></a>Note that links do not have to be
|
---|
231 | symmetrical; for instance, here the edge between
|
---|
232 | <span class="code">moe</span> and <span class="code">curly</span>
|
---|
233 | maps to different ranges depending on if you're going up or down.
|
---|
234 | In fact links don't have to be bidirectional. You can configure
|
---|
235 | the right of <span class="code">moe</span> to go to
|
---|
236 | <span class="code">larry</span> without a link from the left of
|
---|
237 | <span class="code">larry</span> to <span class="code">moe</span>.
|
---|
238 | It's possible to configure a screen with no outgoing links; the
|
---|
239 | cursor will get stuck on that screen unless you have a hot key
|
---|
240 | configured to switch off of that screen.
|
---|
241 | </p><p>
|
---|
242 | </p><h4>options</h4><p>
|
---|
243 | </p><p>
|
---|
244 | <span class="arg">args</span> is a list of lines of the form
|
---|
245 | <span class="code">name = value</span>. These set the global
|
---|
246 | options.
|
---|
247 | </p><p>
|
---|
248 | Example:
|
---|
249 | <span class="codeblock">
|
---|
250 | section: options
|
---|
251 | heartbeat = 5000
|
---|
252 | switchDelay = 500
|
---|
253 | end
|
---|
254 | </span>
|
---|
255 | </p><p>
|
---|
256 | You can use the following options:
|
---|
257 | <ul>
|
---|
258 | <li><span class="code">heartbeat = N</span>
|
---|
259 | </p><p>
|
---|
260 | The server will expect each client to send a message no
|
---|
261 | less than every <span class="code">N</span> milliseconds.
|
---|
262 | If no message arrives from a client within
|
---|
263 | <span class="code">3N</span> seconds the server forces that
|
---|
264 | client to disconnect.
|
---|
265 | </p><p>
|
---|
266 | If synergy fails to detect clients disconnecting while
|
---|
267 | the server is sleeping or vice versa, try using this
|
---|
268 | option.
|
---|
269 | </p><p>
|
---|
270 | <li><span class="code"><a name="corners"></a>switchCorners = <corners></span>
|
---|
271 | </p><p>
|
---|
272 | Synergy won't switch screens when the mouse reaches the edge of
|
---|
273 | the screen if it's in a listed corner. The size of all corners
|
---|
274 | is given by the <span class="code">switchCornerSize</span>
|
---|
275 | option.
|
---|
276 | </p><p>
|
---|
277 | Corners are specified by a list using the following names:
|
---|
278 | <ul>
|
---|
279 | <li><span class="code">none</span> -- no corners
|
---|
280 | <li><span class="code">top-left</span> -- the top left corner
|
---|
281 | <li><span class="code">top-right</span> -- the top right corner
|
---|
282 | <li><span class="code">bottom-left</span> -- the bottom left corner
|
---|
283 | <li><span class="code">bottom-right</span> -- the bottom right corner
|
---|
284 | <li><span class="code">left</span> -- top and bottom left corners
|
---|
285 | <li><span class="code">right</span> -- top and bottom right corners
|
---|
286 | <li><span class="code">top</span> -- left and right top corners
|
---|
287 | <li><span class="code">bottom</span> -- left and right bottom corners
|
---|
288 | <li><span class="code">all</span> -- all corners
|
---|
289 | </ul>
|
---|
290 | </p><p>
|
---|
291 | The first name in the list is one of the above names and defines
|
---|
292 | the initial set of corners. Subsequent names are prefixed with
|
---|
293 | + or - to add the corner to or remove the corner from the set,
|
---|
294 | respectively. For example:
|
---|
295 | </p><p>
|
---|
296 | <span class="code">
|
---|
297 | all -left +top-left
|
---|
298 | </span>
|
---|
299 | </p><p>
|
---|
300 | starts will all corners, removes the left corners (top and bottom)
|
---|
301 | then adds the top-left back in, resulting in the top-left,
|
---|
302 | bottom-left and bottom-right corners.
|
---|
303 | </p><p>
|
---|
304 | <li><span class="code"><a name="cornerSize"></a>switchCornerSize = N</span>
|
---|
305 | </p><p>
|
---|
306 | Sets the size of all corners in pixels. The cursor must be within
|
---|
307 | <span class="code">N</span> pixels of the corner to be considered
|
---|
308 | to be in the corner.
|
---|
309 | </p><p>
|
---|
310 | <li><span class="code">switchDelay = N</span>
|
---|
311 | </p><p>
|
---|
312 | Synergy won't switch screens when the mouse reaches the
|
---|
313 | edge of a screen unless it stays on the edge for
|
---|
314 | <span class="code">N</span>
|
---|
315 | milliseconds. This helps prevent unintentional
|
---|
316 | switching when working near the edge of a screen.
|
---|
317 | </p><p>
|
---|
318 | <li><span class="code">switchDoubleTap = N</span>
|
---|
319 | </p><p>
|
---|
320 | Synergy won't switch screens when the mouse reaches the
|
---|
321 | edge of a screen unless it's moved away from the edge
|
---|
322 | and then back to the edge within <span class="code">N</span>
|
---|
323 | milliseconds. With
|
---|
324 | the option you have to quickly tap the edge twice to
|
---|
325 | switch. This helps prevent unintentional switching
|
---|
326 | when working near the edge of a screen.
|
---|
327 | </p><p>
|
---|
328 | <li><span class="code">screenSaverSync = {true|false}</span>
|
---|
329 | </p><p>
|
---|
330 | If set to <span class="code">false</span> then synergy
|
---|
331 | won't synchronize screen savers. Client screen savers
|
---|
332 | will start according to their individual configurations.
|
---|
333 | The server screen saver won't start if there is input,
|
---|
334 | even if that input is directed toward a client screen.
|
---|
335 | </p><p>
|
---|
336 | <li><span class="code">relativeMouseMoves = {true|false}</span>
|
---|
337 | </p><p>
|
---|
338 | If set to <span class="code">true</span> then secondary
|
---|
339 | screens move the mouse using relative rather than absolute
|
---|
340 | mouse moves when and only when the cursor is locked to the
|
---|
341 | screen (by Scroll Lock or a <a href="#lockCursor">configured
|
---|
342 | hot key</a>).
|
---|
343 | This is intended to make synergy work better with certain
|
---|
344 | games. If set to <span class="code">false</span> or not
|
---|
345 | set then all mouse moves are absolute.
|
---|
346 | </p><p>
|
---|
347 | <li><span class="code">keystroke(<span class="arg">key</span>) = <span class="arg">actions</span></span>
|
---|
348 | </p><p>
|
---|
349 | Binds the key combination <span class="arg">key</span> to the
|
---|
350 | given <span class="arg">actions</span>. <span class="arg">key</span>
|
---|
351 | is an optional list of modifiers (<span class="code">shift</span>,
|
---|
352 | <span class="code">control</span>, <span class="code">alt</span>,
|
---|
353 | <span class="code">meta</span> or <span class="code">super</span>)
|
---|
354 | optionally followed by a character or a key name, all separated by
|
---|
355 | <span class="code">+</span> (plus signs). You must have either
|
---|
356 | modifiers or a character/key name or both. See below for
|
---|
357 | <a href="#keynames">valid key names</a>.
|
---|
358 | </p><p>
|
---|
359 | Actions are described <a href="#actions">below</a>.
|
---|
360 | </p><p>
|
---|
361 | Keyboard hot keys are handled while the cursor is on the primary
|
---|
362 | screen and secondary screens. Separate actions can be assigned
|
---|
363 | to press and release.
|
---|
364 | </p><p>
|
---|
365 | <li><span class="code">mousebutton(<span class="arg">button</span>) = <span class="arg">actions</span></span>
|
---|
366 | </p><p>
|
---|
367 | Binds the modifier and mouse button combination
|
---|
368 | <span class="arg">button</span> to the given
|
---|
369 | <span class="arg">actions</span>. <span class="arg">button</span>
|
---|
370 | is an optional list of modifiers (<span class="code">shift</span>,
|
---|
371 | <span class="code">control</span>, <span class="code">alt</span>,
|
---|
372 | <span class="code">meta</span> or <span class="code">super</span>)
|
---|
373 | followed by a button number. The primary button (the
|
---|
374 | left button for right handed users) is button 1, the middle button
|
---|
375 | is 2, etc.
|
---|
376 | </p><p>
|
---|
377 | Actions are described <a href="#actions">below</a>.
|
---|
378 | </p><p>
|
---|
379 | Mouse button actions are not handled while the cursor is on the
|
---|
380 | primary screen. You cannot use these to perform an action while
|
---|
381 | on the primary screen. Separate actions can be assigned to press
|
---|
382 | and release.
|
---|
383 | </p><p>
|
---|
384 | </ul>
|
---|
385 | You can use both the <span class="code">switchDelay</span> and
|
---|
386 | <span class="code">switchDoubleTap</span> options at the same
|
---|
387 | time. Synergy will switch when either requirement is satisfied.
|
---|
388 | </p><p>
|
---|
389 | <a name="actions">Actions</a> are two lists of individual actions separated
|
---|
390 | by commas. The two lists are separated by a semicolon. Either list can be
|
---|
391 | empty and if the second list is empty then the semicolon is optional. The
|
---|
392 | first list lists actions to take when the condition becomes true (e.g. the
|
---|
393 | hot key or mouse button is pressed) and the second lists actions to take
|
---|
394 | when the condition becomes false (e.g. the hot key or button is released).
|
---|
395 | The condition becoming true is called activation and becoming false is
|
---|
396 | called deactivation.
|
---|
397 | Allowed individual actions are:
|
---|
398 | <ul>
|
---|
399 | <li><span class="code">keystroke(<span class="arg">key</span>[,<span class="arg">screens</span>])</span>
|
---|
400 | <li><span class="code">keyDown(<span class="arg">key</span>[,<span class="arg">screens</span>])</span>
|
---|
401 | <li><span class="code">keyUp(<span class="arg">key</span>[,<span class="arg">screens</span>])</span>
|
---|
402 | </p><p>
|
---|
403 | Synthesizes the modifiers and key given in <span class="arg">key</span>
|
---|
404 | which has the same form as described in the
|
---|
405 | <span class="code">keystroke</span> option. If given,
|
---|
406 | <span class="arg">screens</span> lists the screen or screens to
|
---|
407 | direct the event to, regardless of the active screen. If not
|
---|
408 | given then the event is directed to the active screen only.
|
---|
409 | </p><p>
|
---|
410 | <span class="code">keyDown</span> synthesizes a key press and
|
---|
411 | <span class="code">keyUp</span> synthesizes a key release.
|
---|
412 | <span class="code">keystroke</span> synthesizes a key press on
|
---|
413 | activation and a release on deactivation and is equivalent to
|
---|
414 | a <span class="code">keyDown</span> on activation and
|
---|
415 | <span class="code">keyUp</span> on deactivation.
|
---|
416 | </p><p>
|
---|
417 | <span class="arg">screens</span> is either <span class="code">*</span>
|
---|
418 | to indicate all screens or a colon (:) separated list of screen
|
---|
419 | names. (Note that the screen name must have already been encountered
|
---|
420 | in the configuration file so you'll probably want to put actions at
|
---|
421 | the bottom of the file.)
|
---|
422 | </p><p>
|
---|
423 | <li><span class="code">mousebutton(<span class="arg">button</span>)</span>
|
---|
424 | <li><span class="code">mouseDown(<span class="arg">button</span>)</span>
|
---|
425 | <li><span class="code">mouseUp(<span class="arg">button</span>)</span>
|
---|
426 | </p><p>
|
---|
427 | Synthesizes the modifiers and mouse button given in
|
---|
428 | <span class="arg">button</span>
|
---|
429 | which has the same form as described in the
|
---|
430 | <span class="code">mousebutton</span> option.
|
---|
431 | </p><p>
|
---|
432 | <span class="code">mouseDown</span> synthesizes a mouse press and
|
---|
433 | <span class="code">mouseUp</span> synthesizes a mouse release.
|
---|
434 | <span class="code">mousebutton</span> synthesizes a mouse press on
|
---|
435 | activation and a release on deactivation and is equivalent to
|
---|
436 | a <span class="code">mouseDown</span> on activation and
|
---|
437 | <span class="code">mouseUp</span> on deactivation.
|
---|
438 | </p><p>
|
---|
439 | <li><a name="lockCursor"></a><span class="code">lockCursorToScreen(<span class="arg">mode</span>)</span>
|
---|
440 | </p><p>
|
---|
441 | Locks the cursor to or unlocks the cursor from the active screen.
|
---|
442 | <span class="arg">mode</span> can be <span class="code">off</span>
|
---|
443 | to unlock the cursor, <span class="code">on</span> to lock the
|
---|
444 | cursor, or <span class="code">toggle</span> to toggle the current
|
---|
445 | state. The default is <span class="code">toggle</span>. If the
|
---|
446 | configuration has no <span class="code">lockCursorToScreen</span>
|
---|
447 | action and Scroll Lock is not used as a hot key then Scroll Lock
|
---|
448 | toggles cursor locking.
|
---|
449 | </p><p>
|
---|
450 | <li><span class="code">switchToScreen(<span class="arg">screen</span>)</span>
|
---|
451 | </p><p>
|
---|
452 | Jump to screen with name or alias <span class="arg">screen</span>.
|
---|
453 | </p><p>
|
---|
454 | <li><span class="code">switchInDirection(<span class="arg">dir</span>)</span>
|
---|
455 | </p><p>
|
---|
456 | Switch to the screen in the direction <span class="arg">dir</span>,
|
---|
457 | which may be one of <span class="code">left</span>,
|
---|
458 | <span class="code">right</span>, <span class="code">up</span> or
|
---|
459 | <span class="code">down</span>.
|
---|
460 | </p><p>
|
---|
461 | </ul>
|
---|
462 | </p><p>
|
---|
463 | Examples:
|
---|
464 | <ul>
|
---|
465 | <li><span class="code">keystroke(alt+left) = switchInDirection(left)</span>
|
---|
466 | </p><p>
|
---|
467 | Switches to the screen to left when the left arrow key is pressed
|
---|
468 | in combination with the Alt key.
|
---|
469 | </p><p>
|
---|
470 | <li><span class="code">keystroke(shift+control+alt+super) = switchToScreen(moe)</span>
|
---|
471 | </p><p>
|
---|
472 | Switches to screen <span class="code">moe</span> when all of the
|
---|
473 | Shift, Control, Alt, and Super modifier keys are pressed together.
|
---|
474 | </p><p>
|
---|
475 | <li><span class="code">keystroke(alt+f1) = ; lockCursorToScreen(toggle)</span>
|
---|
476 | </p><p>
|
---|
477 | Toggles locking the cursor to the screen when Alt+F1 is released.
|
---|
478 | </p><p>
|
---|
479 | <li><span class="code">mousebutton(2) = mouseDown(control+1) ; mouseUp(control+1)</span>
|
---|
480 | </p><p>
|
---|
481 | While on a secondary screen clicking the middle mouse button will
|
---|
482 | become a Control click of the primary button.
|
---|
483 | </p><p>
|
---|
484 | <li><span class="code">keystroke(super+f1) = keystroke(super+L,larry), keystroke(control+alt+delete,curly)</span>
|
---|
485 | </p><p>
|
---|
486 | Pressing Super+F1 (on any screen) will synthesize Super+L on screen
|
---|
487 | <span class="code">larry</span> and Control+Alt+Delete on screen
|
---|
488 | <span class="code">curly</span>.
|
---|
489 | </p><p>
|
---|
490 | </ul></span>
|
---|
491 | </p><p>
|
---|
492 | <a name="keynames">Valid key names</a> are:
|
---|
493 | <span class="code"><ul>
|
---|
494 | <li>AppMail
|
---|
495 | <li>AppMedia
|
---|
496 | <li>AppUser1
|
---|
497 | <li>AppUser2
|
---|
498 | <li>AudioDown
|
---|
499 | <li>AudioMute
|
---|
500 | <li>AudioNext
|
---|
501 | <li>AudioPlay
|
---|
502 | <li>AudioPrev
|
---|
503 | <li>AudioStop
|
---|
504 | <li>AudioUp
|
---|
505 | <li>BackSpace
|
---|
506 | <li>Begin
|
---|
507 | <li>Break
|
---|
508 | <li>Cancel
|
---|
509 | <li>CapsLock
|
---|
510 | <li>Clear
|
---|
511 | <li>Delete
|
---|
512 | <li>Down
|
---|
513 | <li>Eject
|
---|
514 | <li>End
|
---|
515 | <li>Escape
|
---|
516 | <li>Execute
|
---|
517 | <li>F1
|
---|
518 | <li>F2
|
---|
519 | <li>F3
|
---|
520 | <li>F4
|
---|
521 | <li>F5
|
---|
522 | <li>F6
|
---|
523 | <li>F7
|
---|
524 | <li>F8
|
---|
525 | <li>F9
|
---|
526 | <li>F10
|
---|
527 | <li>F11
|
---|
528 | <li>F12
|
---|
529 | <li>F13
|
---|
530 | <li>F14
|
---|
531 | <li>F15
|
---|
532 | <li>F16
|
---|
533 | <li>F17
|
---|
534 | <li>F18
|
---|
535 | <li>F19
|
---|
536 | <li>F20
|
---|
537 | <li>F21
|
---|
538 | <li>F22
|
---|
539 | <li>F23
|
---|
540 | <li>F24
|
---|
541 | <li>F25
|
---|
542 | <li>F26
|
---|
543 | <li>F27
|
---|
544 | <li>F28
|
---|
545 | <li>F29
|
---|
546 | <li>F30
|
---|
547 | <li>F31
|
---|
548 | <li>F32
|
---|
549 | <li>F33
|
---|
550 | <li>F34
|
---|
551 | <li>F35
|
---|
552 | <li>Find
|
---|
553 | <li>Help
|
---|
554 | <li>Home
|
---|
555 | <li>Insert
|
---|
556 | <li>KP_0
|
---|
557 | <li>KP_1
|
---|
558 | <li>KP_2
|
---|
559 | <li>KP_3
|
---|
560 | <li>KP_4
|
---|
561 | <li>KP_5
|
---|
562 | <li>KP_6
|
---|
563 | <li>KP_7
|
---|
564 | <li>KP_8
|
---|
565 | <li>KP_9
|
---|
566 | <li>KP_Add
|
---|
567 | <li>KP_Begin
|
---|
568 | <li>KP_Decimal
|
---|
569 | <li>KP_Delete
|
---|
570 | <li>KP_Divide
|
---|
571 | <li>KP_Down
|
---|
572 | <li>KP_End
|
---|
573 | <li>KP_Enter
|
---|
574 | <li>KP_Equal
|
---|
575 | <li>KP_F1
|
---|
576 | <li>KP_F2
|
---|
577 | <li>KP_F3
|
---|
578 | <li>KP_F4
|
---|
579 | <li>KP_Home
|
---|
580 | <li>KP_Insert
|
---|
581 | <li>KP_Left
|
---|
582 | <li>KP_Multiply
|
---|
583 | <li>KP_PageDown
|
---|
584 | <li>KP_PageUp
|
---|
585 | <li>KP_Right
|
---|
586 | <li>KP_Separator
|
---|
587 | <li>KP_Space
|
---|
588 | <li>KP_Subtract
|
---|
589 | <li>KP_Tab
|
---|
590 | <li>KP_Up
|
---|
591 | <li>Left
|
---|
592 | <li>LeftTab
|
---|
593 | <li>Linefeed
|
---|
594 | <li>Menu
|
---|
595 | <li>NumLock
|
---|
596 | <li>PageDown
|
---|
597 | <li>PageUp
|
---|
598 | <li>Pause
|
---|
599 | <li>Print
|
---|
600 | <li>Redo
|
---|
601 | <li>Return
|
---|
602 | <li>Right
|
---|
603 | <li>ScrollLock
|
---|
604 | <li>Select
|
---|
605 | <li>Sleep
|
---|
606 | <li>Space
|
---|
607 | <li>SysReq
|
---|
608 | <li>Tab
|
---|
609 | <li>Undo
|
---|
610 | <li>Up
|
---|
611 | <li>WWWBack
|
---|
612 | <li>WWWFavorites
|
---|
613 | <li>WWWForward
|
---|
614 | <li>WWWHome
|
---|
615 | <li>WWWRefresh
|
---|
616 | <li>WWWSearch
|
---|
617 | <li>WWWStop
|
---|
618 | <li>Space
|
---|
619 | <li>Exclaim
|
---|
620 | <li>DoubleQuote
|
---|
621 | <li>Number
|
---|
622 | <li>Dollar
|
---|
623 | <li>Percent
|
---|
624 | <li>Ampersand
|
---|
625 | <li>Apostrophe
|
---|
626 | <li>ParenthesisL
|
---|
627 | <li>ParenthesisR
|
---|
628 | <li>Asterisk
|
---|
629 | <li>Plus
|
---|
630 | <li>Comma
|
---|
631 | <li>Minus
|
---|
632 | <li>Period
|
---|
633 | <li>Slash
|
---|
634 | <li>Colon
|
---|
635 | <li>Semicolon
|
---|
636 | <li>Less
|
---|
637 | <li>Equal
|
---|
638 | <li>Greater
|
---|
639 | <li>Question
|
---|
640 | <li>At
|
---|
641 | <li>BracketL
|
---|
642 | <li>Backslash
|
---|
643 | <li>BracketR
|
---|
644 | <li>Circumflex
|
---|
645 | <li>Underscore
|
---|
646 | <li>Grave
|
---|
647 | <li>BraceL
|
---|
648 | <li>Bar
|
---|
649 | <li>BraceR
|
---|
650 | <li>Tilde
|
---|
651 | </ul></span>
|
---|
652 | Additionally, a name of the form <span class="code">\uXXXX</span> where
|
---|
653 | <span class="code">XXXX</span> is a hexadecimal number is interpreted as
|
---|
654 | a unicode character code.
|
---|
655 | Key and modifier names are case-insensitive. Keys that don't exist on
|
---|
656 | the keyboard or in the default keyboard layout will not work.
|
---|
657 | </p>
|
---|
658 | </body>
|
---|
659 |
|
---|
660 | </html>
|
---|