You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

70 lines
5.1 KiB

  1. # Space Cadet: The Future, Built In
  2. <!-- Deliberately not translated, leave it to a suitable translation -->
  3. <!---
  4. original document: 0.15.12:docs/feature_space_cadet.md
  5. git diff 0.15.12 HEAD -- docs/feature_space_cadet.md | cat
  6. -->
  7. *译注:Space Cadet来源于(在西方早期程序员中)著名的键盘Space Cadet Keyboard,具体信息参见下面的链接或[维基百科](https://en.wikipedia.org/wiki/Space-cadet_keyboard)*
  8. Steve Losh 在 [Space Cadet Shift](https://stevelosh.com/blog/2012/10/a-modern-space-cadet/) 详细地描述了该功能. 简而言之,点击左Shift时,会输出左括号;点击右Shift时,会输出右括号。如果按住Shift键,常规的Shift将正常工作。这功能实际上和听起来的一样爽,更爽的是现在连Control和Alt也支持!
  9. ## 使用指南
  10. 首先,在你的配列中完成以下任一项:
  11. - 替换左Shift为 `KC_LSPO`(左Shift,左括号),替换右Shift为 `KC_RSPC`(右Shift,右括号)。
  12. - 替换左Control为 `KC_LCPO`(左Control,左括号),替换右Control为 `KC_RCPC`(右Control,右括号)。
  13. - 替换左Alt为 `KC_LAPO`(左Alt,左括号),替换右Alt为 `KC_RAPC`(右Alt,右括号)。
  14. - 替换任意一个Shift为 `KC_SFTENT`(右Shift,回车)。
  15. ## 键码
  16. |键码 |描述 |
  17. |-----------|-----------------------------|
  18. |`KC_LSPO` |按住时左Shift,点击时 `(` |
  19. |`KC_RSPC` |按住时右Shift,点击时 `)` |
  20. |`KC_LCPO` |按住时左Control,点击时 `(` |
  21. |`KC_RCPC` |按住时右Control,点击时 `)` |
  22. |`KC_LAPO` |按住时左Alt,点击时 `(` |
  23. |`KC_RAPC` |按住时右Alt,点击时 `)` |
  24. |`KC_SFTENT`|按住时右Shift,点击时回车 |
  25. ## 须留意
  26. 同时按下两边的Shift键时会与Space Cadet功能冲突。请参见[指令功能](zh-cn/feature_command.md)以了解如何解决,也可以在 `rules.mk` 中禁用指令:
  27. ```make
  28. COMMAND_ENABLE = no
  29. ```
  30. ## 配置
  31. 默认情况下Space Cadet假设键盘布局为US ANSI,如果你的布局使用不同的括号符,可以在 `config.h` 中重定义。可以修改修饰键点击时发送的字符,亦或阻止修饰键工作。这个新的配置项依次绑定了三个键码:按住或组合其它键使用时的修饰键;点击时发送的修饰键点击(`Tap Modifier`)(在 `KC_TRNS` 中没有修饰键时);最后是点击时发送的键码。请记住,例如'KC_RSFT'按住时点击 `KC_KSPO``KC_TRNS` 时,修饰键依旧会对键码生效,即属于修饰键点击。
  32. |定义 |默认值 |描述 |
  33. |----------------|-------------------------------|----------------------------------------------------------------|
  34. |`LSPO_KEYS` |`KC_LSFT, LSPO_MOD, LSPO_KEY` |按住时发送`KC_LSFT`,点击时发送 `LSPO_MOD``LSPO_KEY` 定义的键码. |
  35. |`RSPC_KEYS` |`KC_RSFT, RSPC_MOD, RSPC_KEY` |按住时发送`KC_RSFT`,点击时发送 `RSPC_MOD``RSPC_KEY` 定义的键码. |
  36. |`LCPO_KEYS` |`KC_LCTL, KC_LSFT, KC_9` |按住时发送`KC_LCTL`,点击时发送 `KC_LSFT``KC_9`. |
  37. |`RCPC_KEYS` |`KC_RCTL, KC_RSFT, KC_0` |按住时发送`KC_RCTL`,点击时发送 `KC_RSFT``KC_0`. |
  38. |`LAPO_KEYS` |`KC_LALT, KC_LSFT, KC_9` |按住时发送`KC_LALT`,点击时发送 `KC_LSFT``KC_9`. |
  39. |`RAPC_KEYS` |`KC_RALT, KC_RSFT, KC_0` |按住时发送`KC_RALT`,点击时发送 `KC_RSFT``KC_0`. |
  40. |`SFTENT_KEYS` |`KC_RSFT, KC_TRNS, SFTENT_KEY` |按住时发送`KC_RSFT`,点击时发送 `SFTENT_KEY`. |
  41. |`SPACE_CADET_MODIFIER_CARRYOVER` |*未定义* |在尝试触发其它修饰键的修饰键点击前,暂存目前的修饰键。这在尝试触发Space Cadet前频繁发生修饰键提前松开时会有用。(译注[^1]) |
  42. ## 过时的配置项
  43. 以下是一些内部用于向后兼容的定义,目前仍可以使用,但上面的定义适用性要强得多。例如,若你点击 `KC_LSPO` 时不想按住修饰键,在旧定义中只有一个办法,使用 `DISABLE_SPACE_CADET_MODIFIER`。但现在可以定义为:`#define LSPO_KEYS KC_LSFT, KC_TRNS, KC_9`,效果是在按住按键时触发左Shift,点击则发送 `KC_9`
  44. |定义 |默认值 |描述 |
  45. |------------------------------|-------------|-------------------------------------|
  46. |`LSPO_KEY` |`KC_9` |点击左Shift时发送的键码 |
  47. |`RSPC_KEY` |`KC_0` |点击右Shift时发送的键码 |
  48. |`LSPO_MOD` |`KC_LSFT` |应用在 `LSPO_KEY` 上的修饰键 |
  49. |`RSPC_MOD` |`KC_RSFT` |应用在 `RSPC_KEY` 上的修饰键 |
  50. |`SFTENT_KEY` |`KC_ENT` |点击Shift时发送的键码 |
  51. |`DISABLE_SPACE_CADET_MODIFIER`|*未定义* |定义时将阻止修饰键应用在Space Cadet上 |
  52. [^1]这句实在是绕,不能确保翻译到位,请参考英文文档