Skip to content

Commit 97e8cd6

Browse files
author
墨航
committed
fix mac ver obsolete document
1 parent 8d64b28 commit 97e8cd6

13 files changed

+802
-641
lines changed

README.md

+173-243
Large diffs are not rendered by default.

design.md

+96
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,96 @@
1+
# Capslock Enhancement Design
2+
3+
⇪CapsLock,即大写锁定键,其起源可追溯至打字机时代。打字机是纯机械的设备,当按下Shift时,整套设备会与墨条纸带发生位移,使小写字母“上档”为大写字母。此等操作对小拇指是不小的负担,以致连续输入两到三个大写字母都比较吃力。于是在今天键盘上⇪Capslock的位置上出现了其原型Shiftlock功能键:可以在大小写状态之间切换与保持。这样的设计解决了一指禅选手的困境,更减轻了打字员的负担。
4+
5+
然而随着科技的进步,这样的问题已经不存在了。除了一指禅选手,Shift能够毫不费力的满足人们的需求。而⇪Capslock这个'多余'的按键,则因为历史惯性保留在了绝大多数键盘的黄金位置。
6+
7+
历史上有很多人注意到了这一点,不少人都琢磨着让这个占据宝地的按键发挥出更大的作用。一些键盘直接去掉了⇪Capslock键,而另一些则直接把它作为⌃Ctrl使用。在一些Unix Like(e.g )环境中,⇪Capslock还被用作语言切换的按键。有些人将⇪Capslock改为复合功能键:单独键入时是⎋ESC,而按住不放时是⌃Ctrl。
8+
9+
不过为什么要浪费这样一个绝佳的机会呢?我们所能做的远比这更多:
10+
11+
譬如创造一个类似⇧ Shift、⌃ Ctrl、⌥ Option、⊞ Win、⎇ Alt 、 ⌘ Command等修饰键的全新功能键:
12+
13+
​ ✱ Hyper
14+
15+
## Design
16+
17+
1. `CapsLock`单独按下与长按的区分
18+
19+
传统上扩展`Capslock`,要么是将其语言切换,要么是将其作为`Control`。但其实这两个功能并不矛盾,一个是单按触发,一个是按下时触发,所以完全可以合并在一起。
20+
21+
单独按下Capslock时,会触发**语言切换**功能,按住不放时,则激活一个新的功能键`Hyper`,替代传统的`Ctrl`实现更多更丰富的定制功能。当然,另一种做法是将单独按下改造为`ESC`,这就要视需求选择了。
22+
23+
2. 导航键
24+
25+
导航键包括:``,``````,`Home`,`End`,`PgUp`,`PgDn`,提供了一套通用的光标移动操作。不过这些键都远离核心键区,导致移动光标需要把右手移开,这一点煞是恼人。最好是将这些导航键映射到右手的核心键区,通过按下`Capslock`键启用,同时需要在移动光标的同时,对文本选取的功能(`Shift`)提供良好支持。
26+
27+
按下Capslock时,传统的VIM导航键`h,j,k,l`映射为方向键,而将这四个键上方的`u,i,o,p`分别映射为`PageUp`,`Home`, `End`,`PageDown `,提供全局的导航操作。另一方面,因为按下左手需要按下`Capslock`,右手需要控制导航键,都不适合按下两侧的`Shift`键进入文本选择模式,这时候比较好的选择是由左手大拇指同时按下⌘(Mac)或Alt(Win),将组合键映射为导航键+`Shift`提供文本选取支持。
28+
29+
这样,vim的导航不仅可以在vim的所有模式中使用,也可以在系统中全局使用了。
30+
31+
3. 删除键
32+
33+
删除是极其频繁的功能,包括前删(BackSpace)与后删(Delete)。不过Mac和Windows的操作不太一致有些恼人,而且这两个键也都是远离核心键区操作不便。
34+
35+
`Capslock`+`nm,.`映射到不同的删除功能上,首先这四个键在`h`,`j`,`k`,`l`正下方,操作非常方便。`Hyper + m`映射为前删`Delete`(Mac)或退格`BackSpace`(Win),`Hyper+ ,`设计为后删`ForwardDelete`(Mac)或`Delete`(Windows)。同时`n``.`则映射为相应的按下`Option`(Mac)或`Ctrl`(Win)的版本,即前删后删一个单词,类似vim的`dw``db`,提高长句删除效率。
36+
37+
这样一来,Mac与Windows的删除行为终于保持一致了,而且删除功能由右手最为灵活的食指和中指负责操作,能大大提高编辑效率。
38+
39+
4. 上档键
40+
41+
上档是CapsLock的传统功能。但通常Capslock对第二排数字键不起作用,这里不妨反其道行之,将Capslock+数字键映射为对应的上档符号,当然也可以考虑映射为其他的一些命令,例如IDE调试命令,配置切换命令等。同时,一些编程中的高频符号,比如括号,下划线,等于号,也可以从右上角拉下来,放到核心键区。
42+
43+
比如`CapsLock+; : _``Capslock + ' : =``Capslock + [ : (``Capslock + ] : )`。这样一来,高频符号下划线和等号就可以方便的录入了,而圆括号映射到方括号这里,让小中大括号一家终于团聚在一起,也减少了输入圆括号的手指位移。
44+
45+
5. 窗口控制
46+
47+
除了切换应用程序窗口`⌘Tab`(Mac), `Alt+Tab`(Win)外,还有许多经常用到的窗口操作:譬如关闭窗口(关闭应用程序),关闭标签页,切换标签页等。
48+
49+
CapsLock+Q是Quit,关闭窗口的意思,映射到`⌘Q`(Mac)或`Alt+F4`(Win)。
50+
51+
CapsLock+W是关闭当前标签,映射到`⌘W`(Mac)或`Ctr+W`(Win)
52+
53+
CapsLock+S是Switch的意思,切换当前标签页,映射到`^Tab`(Mac & Win)。
54+
55+
CapsLock+A是两个挨着的键,一起按就是另一个窗口管理软件的Moom的meta-key。可以方便的缩放摆弄窗口,很好用。
56+
57+
这几个快捷方式非常常用,在IDE或者浏览器里都很方便。
58+
59+
6. Bash控制
60+
61+
在Bash中,我们习惯Capslock作为Ctrl使用。但是最常用的,必不可少的其实只有几个:
62+
63+
CapsLock+Z映射到`^Z`,用于发送SIGTSTP挂起作业。
64+
65+
CapsLock+X映射到`^B`,是终端复用软件Tmux的metakey。
66+
67+
CapsLock+C映射到`^C`,用于发送SIGINT中断作业。
68+
69+
CapsLock+V映射到`,`,是Vim的`<Leader> key`,不过也可以作为应用按键
70+
71+
CapsLock+D映射到`^D`,用于发送`EOF`
72+
73+
当然,在Windows下面,这些键可以作为传统的编辑键:撤销,剪切,拷贝,粘贴……
74+
75+
7. 媒体控制:
76+
77+
在没有`Fn`的外接键盘上如何使用Mac的传统功能键?用`Hyper+FX`解忧愁。Capslock+F1就是调低亮度,依此类推。
78+
79+
8. 应用快捷键:
80+
81+
应用快捷键应当可以用一只手就轻松按出,这也限制了应用快捷键所能使用的键区。基本上适合作为应用快捷键的按键就是左手食指覆盖的键区了。
82+
83+
这里`ERTYFGB`作为应用快捷键,加上⌘总共可以设置14个高频应用程序的快捷方式。这里是我的设置:
84+
85+
`Hyper-E: Google Chrome.app``Hyper-⌘E: Finder`,E取自Explore的涵义。
86+
87+
`Hyper-R: iTerm``Hyper-⌘R: Ctrl+R (Run)`,R取自Run。
88+
89+
`Hyper-T: Sublime Text.app``Hyper-⌘T: Typora`,T取自Text,放置了常用的文本编辑器。
90+
91+
`Hyper-F: Dash.app``Dictionary`,F取自Find的涵义。最常用的查询软件。
92+
93+
`Hyper-G: IntelliJ IDEA.app``Hyper-⌘G: Clion`,G就是`Great`的意思,所以放了IDE
94+
95+
`Hyper-B`可以放一些别的东西,目前当做了呼叫Emoji窗口的快捷键(`^⇧Space`)。
96+

mac-new/setup

-5
This file was deleted.

mac-new/README.md mac-old/README.md

+40-43
Original file line numberDiff line numberDiff line change
@@ -1,45 +1,40 @@
1-
# CapsLock (karabiner-element)
1+
# Capslock (Mac OS X)
22

3-
* **Good News! [Karabiner-element](https://pqrs.org/osx/karabiner/) now works on MacOS 10.13 High Sierra. ** [Download](https://pqrs.org/osx/karabiner/files/Karabiner-Elements-11.1.0.dmg)
4-
* I upgrade My [CapsLock](https://github.com/Vonng/Capslock) karabiner configuration to newer `JSON Format`
53

64

5+
## Notice
76

8-
## Install
9-
10-
* You can put the json file into karabiner's config directory manually:
11-
12-
```bash
13-
mkdir -p "${HOME}/.config/karabiner/assets/complex_modifications/"
14-
cp ./capslock.json "${HOME}/.config/karabiner/assets/complex_modifications/capslock.json"
15-
```
7+
* Capslock for Mac is based on `karabiner` (and `seil`). But Karabiner **does not** work on **macOS Sierra(10.12)** at the moment.
8+
* It **works well** on EI Capitan(10.11) and Yosemite(10.10).
169

17-
* OR you can **[Click Here](karabiner://karabiner/assets/complex_modifications/import?url=https://raw.githubusercontent.com/Vonng/Capslock/master/mac-new/capslock.json) to open Karabiner-Element and auto import it !**
1810

19-
```
20-
karabiner://karabiner/assets/complex_modifications/import?url=https://raw.githubusercontent.com/Vonng/Capslock/master/mac-new/capslock.json
21-
```
2211

2312

13+
## Install
2414

15+
* Step 1: Download [`seil`](https://pqrs.org/osx/karabiner/seil.html.en) and install
16+
* Step 2: Download [`karabiner`](https://pqrs.org/osx/karabiner/) and install.
17+
* Step 3: Change capslock's keycode to 80 using `seil`
18+
![](images/seil-usage.png)
19+
* Step 4: `karabiner`
20+
* Switch to `Misc & Uninstall` panel.
21+
* Click `Open private.xml` button.
22+
* Copy and overwrite file: `private.xml`.
23+
![](images/karabiner-usage.png)
24+
* Step 5:
25+
* Switch back to `Change Key` panel
26+
* Click `Reload XML`
27+
* Enable functions you like :)
28+
![](images/karabiner-ui.png)
2529

2630

27-
* See [Karabiner-Elements Sample Scripts](https://github.com/pqrs-org/KE-complex_modifications) for instructions:
28-
* Open `karabiner-elements`
29-
* Select tab `Complex Modification`
30-
* Click `Add item` at bottom
31-
* Choose function you like.
32-
* Remember: Press CapsLock alone can be mapped to language-switcher(system-default) or escape (vimer-evangel). **But you can not enable both simultaneously.**
31+
Enjoy~ 😁
3332

3433

3534

3635
## Usage
3736

38-
Hold Capslock, it always work as a `Hyper Key`, For single press, you may only choose only one of `Escape` and `Languag-Switcher`.Design and functionality describes [here](https://github.com/Vonng/Capslock)
39-
40-
41-
42-
![](https://github.com/Vonng/Capslock/raw/master/mac/images/keyboard-layout.png)
37+
![](images/keyboard-layout.png)
4338

4439

4540

@@ -94,15 +89,16 @@ Hold Capslock, it always work as a `Hyper Key`, For single press, you may only c
9489

9590
Maybe you'd like overwrite these with your own favorite apps.
9691

97-
* `✱E ↦ Safari`
92+
* `✱E ↦ Google Chrome`
9893
* `✱⌘E ↦ Finder`
9994
* `✱R ↦ iTerm`
10095
* `✱⌘R ↦ ^R (IDE-Run)`
101-
* `✱T ↦ Visual Studio Code`
102-
* `✱⌘T ↦ Typora`
96+
* `✱T ↦ Typora`
97+
* `✱⌘T ↦ MWeb`
10398
* `✱F ↦ Dash`
10499
* `✱⌘F ↦ Dictionary`
105100
* `✱G ↦ IntelliJ IDEA`
101+
* `✱V ↦ Visual Studio Code`
106102

107103
108104

@@ -120,9 +116,6 @@ Maybe you'd like overwrite these with your own favorite apps.
120116
* `✱F10 ↦ Mute`
121117
* `✱F11 ↦ VolumeDown`
122118
* `✱F12 ↦ VolumeUp`
123-
* `✱F13(PrintScreen) ↦ MusicPrev`
124-
* `✱14(ScrollLock) ↦ MusicNext`
125-
* `✱F15(Pause) ↦ MusicPlay`
126119

127120
#### Shifter
128121

@@ -140,20 +133,24 @@ Maybe you'd like overwrite these with your own favorite apps.
140133
* `✱ScrollLock ↦ VolumeMute` (Mute)
141134
* `✱Pause ↦ MusicPlay` (Music play)
142135

143-
#### Misc
136+
#### Cursors
144137

145-
- `⎋ ↦ ⇪` (Escape turn ✱Hyper backs to ⇪CapsLock)
138+
* `↑ ↦ MouseUp`
146139

147-
- `✱␢ ↦ ⎋` (Space maps to ⎋ESC)
148140

149-
- `✱\ ↦ ⌃/` (Back slash maps to comment [IDE shortcut])
150-
151-
- `✱; ↦ ⇧- '!' ` (Semicolon to exclamation)
152-
153-
- `✱' ↦ =` (Single quote to equal)
154141

155-
- `✱~ ↦ ⌃⇧⌘4` (tilde to area screenshot to clipboard)
142+
* `✱↓ ↦ MouseDown`
143+
* `✱← ↦ MouseLeft`
144+
* `✱→ ↦ MouseRight`
145+
* `✱↩ ↦ MouseLButton`
146+
* `✱\ ↦ MouseRButton`
156147

157-
- `✱⌘ ↦ ⌃⇧4` (ScreenShot by area to desktop picture)
148+
#### Other
158149

159-
150+
- `✱⎋ ↦ ⇪` (Escape turn ✱Hyper backs to ⇪CapsLock)
151+
- `✱␢ ↦ ⎋` (Space maps to ⎋ESC)
152+
- `✱\ ↦ ⌃/` (Back slash maps to comment [IDE shortcut])
153+
- `✱; ↦ ⇧- '_' ` (Semicolon to lodash)
154+
- `✱' ↦ =` (Single quote to equal)
155+
- `✱~ ↦ ⌃⇧⌘4`(tilde to area screenhot)
156+
- `✱⌘~ ↦ ⌃⇧4` (⌘tilde to area screenhost to clipboard)
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.

mac-old/setup

+4
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,4 @@
1+
#!/bin/bash
2+
3+
cp ./private.xml "${HOME}/Library/Application Support/Karabiner/private.xml"
4+
echo "${HOME}/Library/Application\ Support/Karabiner/private.xml" Done

0 commit comments

Comments
 (0)