ctrl+shift+p filters: :st2 :st3 :win :osx :linux
Browse

Box​Drawing

by vwheeler63 ST4 New

Sublime Text Package enabling users to draw lines and boxes with arrow-key combinations

Details

Installs

  • Total 0
  • Win 0
  • Mac 0
  • Linux 0
Apr 9 Apr 8 Apr 7 Apr 6 Apr 5 Apr 4 Apr 3 Apr 2 Apr 1 Mar 31 Mar 30 Mar 29 Mar 28 Mar 27 Mar 26 Mar 25 Mar 24 Mar 23 Mar 22 Mar 21 Mar 20 Mar 19 Mar 18 Mar 17 Mar 16 Mar 15 Mar 14 Mar 13 Mar 12 Mar 11 Mar 10 Mar 9 Mar 8 Mar 7 Mar 6 Mar 5 Mar 4 Mar 3 Mar 2 Mar 1 Feb 28 Feb 27 Feb 26 Feb 25 Feb 24
Windows 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
Mac 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
Linux 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Readme

Source
raw.​githubusercontent.​com

BoxDrawing

BoxDrawing is a Sublime Text package enabling the user, normally with these arrow-key combinations:

  • [Alt-Arrow] (single line)
  • [Alt-Shift-Arrow] (double line), or
  • [Ctrl-Alt-Shift-Arrow] (erase)

to draw lines and boxes like these:

┌─┬┐  ╔═╦╗  ╓─╥╖  ╒═╤╕
│ ││  ║ ║║  ║ ║║  │ ││
├─┼┤  ╠═╬╣  ╟─╫╢  ╞═╪╡
└─┴┘  ╚═╩╝  ╙─╨╜  ╘═╧╛ ┌─────────────┐
╭───────────────────╮  │    ╔═══════╕│            ┌───┐
│  ╔═══╗ Some Text  │  │╓───╫┐ ╔══╗ ││ ┌──┬───┐  ┌┴┬┐ │
│  ╚═╦═╝ in the box │░ │║   ║│ ║  ║ ││ ╞══╡   │  ├─┼┼─┘
╞═╤══╩══╤═══════════╡░ │║   ║│ ║  ║ ││ │  │   │  │ ││
│ ├──┬──┤           │░ │╙───╫┘ ╚══╝ ││ └──┴───┘  └─┴┘
│ └──┴──┘           │░ └────╫───────┼┘
╰───────────────────╯░      ╙───────┘
  ▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒░

+------------+----------------+--------------+
| Column One | Column Two     | Column Three |
+============+================+==============+
|            |                |              |
+------------+----------------+--------------+
|            |                |              |
+------------+----------------+--------------+
|            |                |              |
+------------+----------------+--------------+
|            |                |              |
+------------+----------------+--------------+

Features

  • Draw using intuitive key combinations with arrow keys.
  • Arrow-key bindings are temporary, while Box Drawing is turned ON. You turn it OFF again when you are done.
  • Intuitively overwrites characters where directed as if always in “overwrite” mode.
  • There is no need to add spaces to short lines. The package extends short lines with spaces automatically when needed, enabling you to conveniently draw wherever you direct it.
  • Initially uses ASCII or one of the Unicode box-drawing character sets, depending on a user-configurable setting. (See below.)
  • Conveniently switch between character sets with one keystroke.
  • Box drawing with the ASCII character set is compatible with the requirements of reStructuredText tables. (The ASCII table above is an example.)
  • The current state of the BoxDrawing Package can be seen:
    • Tools > BoxDrawing > sub-menu items, and
    • in the status bar for 4 seconds after each state change.
  • Supports these character sets:
    • ASCII
    • Unicode [Square Corners]
    • Unicode [Round Corners]
    • Unicode [2 Dashes]
    • Unicode [3 Dashes]
    • Unicode [4 Dashes]
    • Shadow Characters

Installation

The preferred method of installing BoxDrawing is: from Sublime Text's Command Palette, execute Package Control: Install Package and select BoxDrawing.

If you instead clone BoxDrawing's repository into your <data_path>/Packages/BoxDrawing/ directory, ensure that the name of the directory uses a capital 'B' and capital 'D' as shown. Otherwise, Sublime Text will not find certain files it needs.

Usage

  1. In any type of document, ensure there is just 1 selection (caret) and that no text is selected.

  2. Turn Box-Drawing ON using [Alt-Keypad /] or Tools > BoxDrawing > Enabled or from the Command Palette BoxDrawing: Toggle ON/OFF. (A temporary Status-Bar message “Box Drawing ON/OFF ()” shows which mode the current View is in.) The Tools > BoxDrawing > Enabled menu item always shows the ON/OFF state for the current View by showing a checkmark () next to that menu item when Box Drawing is enabled.

  3. Draw using single lines using the arrow keys while the [Alt] key is held down.

  4. Draw using double lines using the arrow keys while the [Alt-Shift] keys are held down.

  5. Erase using the arrow keys while the [Alt-Shift-Ctrl] keys are held down.

  6. Change current character set using [Alt-Keypad *] or Tools > BoxDrawing > Change Character Set (<char_set>) or from the Command Palette BoxDrawing: Change Character Set. (A temporary Status-Bar message “Box Drawing ON/OFF: ” shows which character set is now current.) The Tools > BoxDrawing > Change Character Set (<char_set>) menu item always shows the current character set in parentheses.

  7. When you are done drawing, turn Box-Drawing OFF again with [Alt-Keypad /] or Tools > BoxDrawing > Enabled or from the Command Palette BoxDrawing: Toggle ON/OFF.

Settings

The following setting items can be found and individually overridden via the usual method for Sublime Text Package settings: Preferences > Package Settings > BoxDrawing > Settings. The comments in the default settings file explain what each one means and lists valid values. Their default values are shown below.

  • default_character_set_id: 6 (means ASCII, as shown in comments)
  • debugging: false

Key Bindings

This Package provides the following customizable key bindings:

Key Combination Meaning
Alt-Keypad / Turn Box Drawing ON or OFF
Alt-Keypad * Switch character sets (ASCII <==> Unicode)
Alt-(Left\ Right\
Alt-Shift-(Left\ Right\
Ctrl-Alt-Shift-(Left\ Right\

When Box-Drawing is ON for a particular View, the Package temporarily overrides the normal key bindings for the arrow-key combinations for that View only. When Box Drawing is turned OFF again, normal key bindings for the arrow keys are resumed. [Alt-Keypad /] and [Alt-Keypad *] both remain bound to the ON/OFF and switch character sets Commands full time.

By default, [Alt-(Left|Right)] key combinations are mapped to “move left/right by sub-words” with “extending selection” behavior added when the [Shift] key is held down.

And by default, [Alt-(Up|Down)] is mapped in the reStructuredText Package to “move up/down by 1 section”, with a possible [Shift] modifier limiting the move to only the same level of section or higher.

If you need to re-map any of the above key bindings, you can do so via:

`Preferences > Package Settings > BoxDrawing > Key Bindings`.

Menu Items

BoxDrawing adds the following menu items to Sublime Text when installed:

  • Tools >

    • BoxDrawing >
      • [✓] Enabled
      • Change Character Set (ASCII)
  • Preferences >

    • Package Settings >
      • README
      • Settings
      • Key Bindings

Commands

BoxDrawing adds the following Commands to Sublime Text when installed:

Action Key Binding Command Palette
Open README —not bound— BoxDrawing: Open Readme
Edit BoxDrawing Settings —not bound— Preferences: BoxDrawing Settings
Edit BoxDrawing Key Bindings —not bound— Preferences: BoxDrawing Key Bindings
Turn Box-Drawing ON or OFF Alt-Keypad / BoxDrawing: Toggle ON/OFF
Toggle between ASCII and Unicode Alt-Keypad * BoxDrawing: Toggle ASCII <==> Unicode
DrawOneCharacter(up, single) Alt-Up[1] BoxDrawing: Draw Single Line Up
DrawOneCharacter(right, single) Alt-Right[1] BoxDrawing: Draw Single Line Right
DrawOneCharacter(down, single) Alt-Down[1] BoxDrawing: Draw Single Line Down
DrawOneCharacter(left, single) Alt-Left[1] BoxDrawing: Draw Single Line Left
DrawOneCharacter(up, double) Alt-Shift-Up[1] BoxDrawing: Draw Double Line Up
DrawOneCharacter(right, double) Alt-Shift-Right[1] BoxDrawing: Draw Double Line Right
DrawOneCharacter(down, double) Alt-Shift-Down[1] BoxDrawing: Draw Double Line Down
DrawOneCharacter(left, double) Alt-Shift-Left[1] BoxDrawing: Draw Double Line Left
DrawOneCharacter(up, none) Ctrl-Alt-Shift-Up[1] BoxDrawing: Draw Erase Up
DrawOneCharacter(right, none) Ctrl-Alt-Shift-Right[1] BoxDrawing: Draw Erase Right
DrawOneCharacter(down, none) Ctrl-Alt-Shift-Down[1] BoxDrawing: Draw Erase Down
DrawOneCharacter(left, none) Ctrl-Alt-Shift-Left[1] BoxDrawing: Draw Erase Left

[1]: when BoxDrawing is ON

Notes

  1. While Sublime Text supports having multiple carets, BoxDrawing will draw box characters only when:
- Box Drawing is ON for that View,
- there is one caret, and
- no text is selected.
  1. While the Shadow Character Set is selected, there is no ERASE function. Instead, the modifier key combinations select which shadow character is written to the Buffer:
- `[Alt]` => ligh shadow character
- `[Alt-Shift]` => medium shadow character
- `[Alt-Shift-Ctrl]` => dark shadow character