Skip to content

A Glyphs plugin for using the arrow keys to change the node selection.

License

Notifications You must be signed in to change notification settings

florianpircher/Keyboard-Selection-Travel

Repository files navigation

Keyboard Selection Travel

This is a plugin for the Glyphs font editor. Move the selection visually.

Installation

Download on the Plugin Manager

Install the plugin using the button above or search for “Keyboard Selection Travel” in the Plugin Manager. Relaunch Glyphs for the plugin to be loaded.

Usage

Demo.mp4
  1. In Edit view, select a point (on-curve point /, off-curve point , or anchor ) and hold down the Control key.
  2. Keyboard Selection Travel marks all available travel destinations with a small gray triangle (▲︎, ▼︎, ◀︎, or ▶︎).
  3. Press the Up ▲︎ arrow key while still holding the Control key to move the selection to the point marked with the up triangle ▲︎.

The same goes for the Down ▼︎, Left ◀︎, and Right ▶︎ arrow keys.

If you don’t like any of the marked travel destinations, press the Command key (while still holding down Control). The next closest travel destinations will be marked with gray triangles. Release the Command key and press one of the arrow keys to travel the selection to that destination.

If multiple points are selected, Keyboard Selection Travel will move all selections independently.

Preferences

Keyboard Selection Travel offers a range of configurable preferences.

Show Hints

The ShowHints preference controls whether travel hints (small arrow-head icons) are shown when holding down the Control key. This preference is activated by default.

Run the following line in the Macro Panel to set the preference to False (or True to activate, or None to reset):

Glyphs.boolDefaults["com.FlorianPircher.Keyboard-Selection-Travel.ShowHints"] = False

Hint Size

The HintSize preference controls the visual size of travel hints. Set the preference to -1 for automatic size (default), 0 for small, 1 for regular, or 2 for large.

Run the following line in the Macro Panel to set the preference to -1, 0, 1, or 2 (or None to reset):

Glyphs.defaults["com.FlorianPircher.Keyboard-Selection-Travel.HintSize"] = 2

Hint Color

The HintColor preference controls the color of travel hints. Set the preference to 10 for the default gray color or to one of the following numbers: 0: red, 1: orange, 2: brown, 3: yellow, 4: green, 7: blue, 8: purple, 9: pink, 10: gray.

Run the following line in the Macro Panel to set the preference (or set it to None to reset it):

Glyphs.defaults["com.FlorianPircher.Keyboard-Selection-Travel.HintColor"] = 1

Ignore Anchors

The IgnoreAnchors preference excludes anchors from the travel destinations. This preference is deactivated by default.

Run the following line in the Macro Panel to set the preference to True (or False to deactivate, or None to reset):

Glyphs.boolDefaults["com.FlorianPircher.Keyboard-Selection-Travel.IgnoreAnchors"] = True

Ignore Tools

The IgnoreTools preference defines a list of tools for which the plugin should be disabled. This list stores the class names of the tools for which Keyboard Selection Travel should be disabled. The default values list contains the two entries GlyphsToolText and GlyphsToolHand (the Text and Hand tool). Run the following code in the Macro Panel to get the class name of the currently active tool:

print(Glyphs.documents[0].windowController().toolDrawDelegate().className())

Run the following line in the Macro Panel to set the preference (or set to None to reset it):

Glyphs.defaults["com.FlorianPircher.Keyboard-Selection-Travel.IgnoreTools"] = ["GlyphsToolText", "GlyphsToolTrueTypeInstructor"]

Use Alternative Shortcuts

The UseAlternativeShortcuts preference accepts shortcuts with only the Control key or with Control and Shift held simultaneously. This is helpful in case Command-Arrow key is already used by some other command (another plugin, some script, a macOS system command, etc.). This preference is deactivated by default.

Run the following line in the Macro Panel to set the preference to True (or False to deactivate, or None to reset):

Glyphs.boolDefaults["com.FlorianPircher.Keyboard-Selection-Travel.UseAlternativeShortcuts"] = True

Troubleshooting

Make sure to restart Glyphs after installing Keyboard Selection Travel for the plugin to be loaded.

In some cases pressing the arrow keys while holding down Control might still not work. This is because the Control-Up/Down/Left/Right shortcuts are used by the system (typically to move to a different space or to activate Mission Control) or by some other app.

Fix these issue by disabling the other shortcuts. If you want to keep them, you can also change the Keyboard Selection Travel shortcuts to Control-Shift-Up/Down/Left/Right by enabling the UseAlternativeShortcuts preference (see the section above for details).

How does it work?

Keyboard Selection Travel evaluates all unselected points according to a distance function. Each point is assigned a distance to the currently selected point. The point with the smallest distance is selected.

Let’s say you have one point selected and press Control-Up. This action moves the selection to the closest points above the current selection. The closest point is determined by assigning each unselected point a distance and picking the point with the smallest distance.

The distance between two points can be computed in many different ways. The rectilinear distance is the sum of the vertical offset and the horizontal offset: $|x_1 - x_2| + |y_1 - y_2|$. The Euclidean distance is the length of a straight line from one point to the other: $\sqrt{(x_1 - x_2)^2 + (y_1 - y_2)^2}$. Both distances are unsuitable since they do not distinguish between vertical offset and horizontal offset.

In the animation above, observe the moving selection on the digit 2 on the left. When it jumps up (Control-Up) from the base to the terminal at the top, the selection does not move to any handle from the base, even though those all have a smaller rectilinear distance and Euclidean distance than the point at the end of the terminal. For this to work, the distance function must treat the vertical offset of points differently from their horizontal offset.

The distance function used by this plugin can be visualized like so:

This is the visualization for left-right movement; up-down movement would look the same but rotated by 90 degrees. The currently selected node is placed in the center. All other points are evaluated with respect to this center. Closer points are brighter; points further aways are drawn darker.

As you can see, points of the same height as the selected point are particularly bright. Still, the brightness tapers off into the distance, giving closer points with a bit more deviation from the main axis a chance.

Such a distance function can never be perfect, and I will happily engage in proposals for better distance functions. The function shown above works sufficiently well, at least in my testing.

Licenses

Licensed under the Apache License, Version 2.0.

About

A Glyphs plugin for using the arrow keys to change the node selection.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published