# Custom layouts You select a key layout for Unexpected Keyboard by calling up the Settings page (swipe the gear icon) and, at the top of the page, either tapping an existing layout or tapping _Add an alternate layout_. This displays a menu of available layouts. You can define your own layout by choosing _Custom layout_ at the bottom of this menu. Unexpected Keyboard now displays code in the XML format. You make changes by replacing this with different code and tapping OK. We recommend you keep your work in a file outside Unexpected Keyboard (named something like `MyChanges.xml`). If you installed a new version of Unexpected from a different website (with a different signature), then the work you did solely by editing the XML inside Unexpected would be lost. Put initial contents into your file in one of these ways: * Copypaste the code Unexpected displays for _Custom layout_. * Make a copy of one of the built-in layouts found in [`/srcs/layouts`](https://github.com/Julow/Unexpected-Keyboard/tree/master/srcs/layouts). * Use the [web-based editor](https://unexpected-keyboard-layout-editor.lixquid.com/). Interact with this web page to define keys and swipes and move keys to desired positions, and it will write the XML code for you. You can make the web page put the XML in a text file or copy it to the clipboard. When you have prepared suitable XML code in one of these ways, copy it to the clipboard and paste it into Unexpected Keyboard. ## XML language overview A layout XML file comprises tags that start with `<` and end with `>`. * Every layout file starts with this declaration: `` * Certain tags come in pairs—an opening tag and a closing tag—and apply to everything between them. * The ``...`` pair says that the material between them is the definition of your keyboard. There can be only one of these. * The ``...`` pair encloses the definition of a single row. * An optional ``...`` pair contains instructions if you want to change the behavior of a modifier key such as Shift. * Stand-alone tags include ``, which defines a single key. A tag can have properties, defined using an equals sign and a pair of ASCII double quotes. For example, `` defines the "a" key. The `key0` property of the `key` tag says which key you are defining, and the tag's location inside ``...`` specifies where it will go in the row. ### Example Here is a complete keyboard file with a single row containing an "a" key on the left and a "b" key on the right: ## Keyboard metadata The ``...`` pair follows the declaration tag and encloses the whole keyboard. The following properties may be used (The first two appear in the example above): * `name`: The name of the keyboard. The name you specify will appear in the Settings menu. If not present, the layout will just appear as “Custom layout”. * `script`: The (main) writing system that the keyboard supports. The possible values are `arabic`, `armenian`, `bengali`, `cyrillic`, `devanagari`, `gujarati`, `hangul`, `hebrew`, `latin`, `persian`, `shavian`, and `urdu`. It defaults to `latin`. * `numpad_script`: The script to use for the numpad. This is useful for scripts where a different, non-ASCII set of numerals is used, like Devanagari and Arabic. It defaults to the same as `script`. * `bottom_row`: Whether or not to show the common bottom row. It accepts `true` or `false`, and defaults to `true`. If your custom layout defines the bottom row, then specify `bottom_row=false` to disable the built-in bottom row. ## Row The ``...`` pair encloses one row on the keyboard. It has only one optional property: * `height`: The height of the row: a positive floating-point value. A row's default height is 1.0 (one quarter of the keyboard height specified on the Settings menu). The `height` property makes the row taller or shorter than this. For example, if you define a 5-row keyboard but one row has `height="0.7"`, then the keyboard's total height is 4.7 units. If the total is different from 4.0, the keyboard will be taller or shorter than that specified in Settings. ## Key The `` tag defines a key on the keyboard. Its position in the sequence of keys inside ``...`` indicates its position in the row from left to right. What the key does is defined by optional properties. ### Taps What the key does when tapped is defined by the optional `key0` property. For example, `` defines the "a" key. Unexpected Keyboard provides a legend in the middle of the key. When the Shift modifier is tapped, the "a" key becomes the "A" key and the legend temporarily changes. The Fn modifier makes a different change. You can override this behavior with a modmap (see below). ### Swipes The following optional properties define the effects of swipes: * `n`, `ne`, `e`, `se`, `s`, `sw`, `w`, `nw`: What the key should do when it is swiped in the direction of that compass point. ("North" means upward and "East" is to the right.)
nwnne
w e
swsse
* `key1` through `key8` is an older way to achieve the same effects. The directions are ordered as follows:
key1key7key2
key5 key6
key3key8key4
You can define a swipe only once with either compass-point or numeric notation. Unexpected Keyboard automatically puts a small legend in that direction from the center of the key. * `slider`: If `slider="true"`, and the key also has `w` and `e` properties, then the key tracks horizontal finger motion precisely and sends the `w` and `e` keystrokes repeatedly. In built-in layouts, this makes the space bar send left and right characters as the user slides on the space bar. * `anticircle`: The key value to send when doing an anti-clockwise gesture on the key. (The clockwise gesture applies a Shift modifier and the round-trip gesture applies a Fn modifier. These results can be redefined using a modmap, as explained below.) ### Layout A key may have the following properties to control the row's layout: * `width`: The width of the key, a positive floating-point value. It defaults to 1.0 * `shift`: How much empty space to add to the left of this key, a non-negative floating-point value. It defaults to 0.0 Normally, a key's width is 1.0 unit. Unexpected Keyboard occupies the full width of the screen, and the row defining the highest number of units (in widths plus shifts) is as wide as the screen. A row whose width is a smaller number of units has empty space on the right. ### Extra legend * `indication`: An optional extra legend to show under the main label. For example, `` displays ABC at the bottom of the 2 key, as on a pinpad or some telephones. If the key also defines a downward swipe with `s` or `key8`, the legends overlap. ## Possible key values The properties that define the effects of tapping or swiping a key may be one of the built-in strings documented on [this page](Possible-key-values). For example, `se="cut"` says that a southeast swipe produces the "cut" key (Ctrl-C). Some of those strings begin with `loc `. These are place-holders; the tap or swipe does nothing unless enabled through the "Add keys to keyboard" option in the Settings menu, or implicitly enabled by the language the device is set to use. For example, `ne="loc accent_aigu"` says that a northeast swipe produces the acute accent combinatorial key—if enabled. If the string defining a tap or a swipe is anything other than one of the built-in strings, the defined string is output *verbatim.* This is what most of the taps and swipes on a typical keyboard do. So `key0="a"` simply outputs the letter a. The string can output multiple characters, but cannot combine the built-in strings to specify a sequence of keystrokes. ## Modmap The ``...`` pair encloses custom mappings for modifier keys. The modmap is placed inside the ``...`` pair, but outside any row. A layout can have at most one modmap. A modmap can contain the following tags, each of which must have an `a` and a `b` property: * `` —This says that, if the Shift modifier is on (or the user made a clockwise gesture on a key), and if the key would normally generate the value after "a", it must instead generate the value after "b". * `` —This says that, if the Fn modifier is on (or the user made a round-trip gesture on a key), and if the key would normally generate the value after "a", it must instead generate the value after "b". The "a" and "b" values are as specified above in **Possible key values**. A `` tag modifies a gesture only if no `` tag did. There can be as many of these tags inside `` as needed. ### Examples ① Turkish keyboards use the Latin alphabet, but when "i" is shifted, it should produce "İ". This is achieved with the following modmap: ② By default, `Fn`+`e` produces the € character. This can be inhibited with the following modmap, which maps the modified `e` key to itself: These two examples are each shown in a modmap, for completeness. However, a layout can have at most one modmap, containing all the desired `` and `` tags. ## Portrait vs. landscape Unexpected Keyboard remembers *separately* which layout has last been used in portrait and landscape orientation. So you may have one custom layout for portrait orientation, but another custom layout for landscape orientation, and Unexpected Keyboard will switch between them without your intervention. ## Contributing your layout The Unexpected Keyboard project enthusiastically accepts user contributions, including custom layouts. (See the guidance for layouts at [CONTRIBUTING.md](https://github.com/Julow/Unexpected-Keyboard/blob/master/CONTRIBUTING.md#Adding-a-layout)). * Submit a layout that has innovations of possible interest to other users at [Unexpected-Keyboard-layouts](https://github.com/Julow/Unexpected-Keyboard-layouts). * Propose that your layout be included in the set of built-in layouts by making a Pull Request for an addition to [srcs/layouts](https://github.com/Julow/Unexpected-Keyboard/tree/master/srcs/layouts). Please show that such a layout is standard in your locale or has a substantial number of users.