星期二, 八月 06, 2019

VIM学习笔记 工具箱-屏幕截图 (Toolkit-Screenshot)

在编写VIM学习笔记的过程中,我刻意增加了屏幕截图/录像的数量,以便能够更直观地说明各种命令的用法和效果。以下则为我用于制作屏幕截图/录像的几款工具:

屏幕截图

在屏幕截图领域,有无数优秀的软件。由于使用频率如此之高,我相信每个人也都有自己的偏好。而Greenshot则是我在试用多款软件之后,安定下来的选择。

Greenshot可以截取整个屏幕、指定窗口、和矩形区域。而“截取上次区域”功能,则可以快速截取之前选定的屏幕区域。比如:我想要说明针对同一文字区域执行命令的效果,那么首先在原始状态下通过鼠标拖拽截取屏幕,然后执行命令,接下来只要点击Shift + Print快捷键就可以针对上次选定的屏幕区域再次进行截图。这大大提高了多次重复截图的效率,而且确保了多次截图时像素位置和图片尺寸的一致性。

Greenshot可以将屏幕截图输出到剪贴板、打印机、文件或者内置的图片编辑器。通过选择以下快捷菜单,可以将屏幕截图同时发送到剪贴板和图片编辑器。那么你就可以在图片编辑器中查看屏幕截图的效果;然后选择继续编辑图片,或者保存为文件,或者直接关闭编辑器,然后将图片粘贴到其他应用程序当中。

Tools_Screen_Greenshot_Destination

在Greenshot内置的图片编辑器中,可以为图片增加注解、标识重点、绘制图形;还可以应用边框、阴影、锯齿、高亮和模糊等多种效果。更重要的是,图片可以保存为greenshot类型的文件。之后您可以多次打开greenshot文件,不断对屏幕截图进行修改,然后再将最终结果输出为PNG或JPG图片格式。这种对于屏幕截图进行多次调整的能力,在其他屏幕截图软件中并不多见。

Tools_Screen_Greenshot_Editor

Greenshot是免费的开源软件,支持Windows和Mac操作系统;在Linux下,我会使用开源的Flameshot;而在Mac下,则购买了久负盛名的SnagIt,同时也使用免费的Snappy

屏幕录像

对于多步骤的键盘操作,静态的屏幕截图就显得力不从心了,而使用ScreenToGif录制动态的屏幕录像,则能够更流畅地演示连续操作。

点击“录像机”按钮,然后将ScreenToGif窗口像取景框一样,移动到需要捕捉的屏幕区域之上;点击红色“录制”按钮,即可以进行屏幕录像:

Tools_Screen_ScreenToGif_Recorder

完成录制之后,可以在ScreenToGif内置的编辑器中,对屏幕录像进行逐帧调整。比如添加文本和图像元素,调整帧的顺序,删除多余的帧等等。也就是说,你可以通过后期制作,来提供更多视觉辅助,并修正操作演示中不够顺畅的步骤。屏幕录像编辑完成之后,可以导出为Gif动画或者Avi视频。

Tools_Screen_ScreenToGif_Editor

ScreenToGif是Windows下的开源软件。在Linux下,我会使用开源的OBS Studio;在Mac下,我使用开源的屏幕录像软件Kap

按键屏显

对于Vim中大量的按键操作,即使利用屏幕录像来演示,有时仍然显得词不达意。而使用Carnac,则可以在屏幕上实时显示按键操作,也就可以同步展示输入的命令,以及执行命令的结果。

通过设置按键屏显的位置、字体大小、颜色、背景和样式,可以更加美观和直观地辅助屏幕录像。

Tools_Screen_Carnac_Appearance

例如以下屏幕录像,演示了在将'j'映射为'gj'之后,向下移动键和j键,对于折行的不同处理(请参阅折行章节的详细说明)。俗话说,“一幅图画胜过千言万语”,而一段活动的影像更又胜强百倍了吧?

j-gj

Carnac是Windows下的开源软件。在Linux下,我会使用开源的Screenkey;在Mac下,我使用开源KeyCastr

工具箱 — 屏幕截图相关
WindowsLinuxMac
屏幕截图logologologo
屏幕录像logologologo
按键屏显logologologo

Ver: 2.0 | YYQ<上一篇 | 目录 下一篇>

<

星期六, 八月 03, 2019

VIM学习笔记 命令行模式 (Command-line Mode)

命令行模式 (Command-line Mode)

输入:命令,使用/?搜索命令,都将进入命令行模式。用户可以在屏幕底部的命令行中输入命令,或者使用以下快捷键遍历之前的命令历史,然后点击<Enter>键来执行命令。

显示上一条命令
Ctrl + p
显示下一条命令
Ctrl + n
Ctrl + b移动到命令行开头
Ctrl + e移动到命令行末尾
Ctrl + ←向左移动一个单词
Shift + ←
Ctrl + →向右移动一个单词
Shift + →
Ctrl + w删除光标前的一个单词
Ctrl + u删除光标前的所有字符

输入部分命令,比如输入:set,然再点击上下光标键,将自动对命令历史纪录进行过滤,仅显示以“set”开头的命令历史纪录。在输入/?查找命令时,此特性同样有效。请注意,此时是大小写敏感的。

继续键入命令:set i之后,按下TabCtrl+D键,将显示以“i”开头的set命令;继续按Tab键,则可以在这些命令列表间移动,按下回车键就可以执行该命令。

set_i_tab

进入命令行模式之后,点击Ctrl+rCtrl+w键可以将当前光标下的word粘贴到命令行中;点击Ctrl+rCtrl+a键可以将当前光标下的WORD粘贴到命令行;点击Ctrl+r%键可以将当前文件名粘贴到命令行。

利用以上快捷键,可以大大简化命令行的输入。比如想要替换光标下的单词,那么只要输入:substitute命令,然后再点击Ctrl+r和Ctrl+w键,就可以将光标下的单词插入到命令行中,而不需要手工输入替换的文字了。

:%s/<Ctrl+r><Ctrl+w>//g

比如在编辑vimrc配置文件时,会面对大量的设置命令,只需要将光标移动到配置选项之上,输入:help命令,然后点击Ctrl+r和Ctrl+w键,就可以查询该关键字的帮助信息:

:help <Ctrl+r><Ctrl+w>

使用:help c_CTRL-R_CTRL-W命令,可以查看关于Ctrl+r和Ctrl+w键的帮助信息。使用:help cmdline-editing命令,可以查看关于命令行编辑的帮助信息。使用:help :命令,可以查看关于命令行模式的帮助信息。

命令行窗口 (Command-line Window)

可以使用以下四种方式,来打开命令行窗口:

  1. 在命令行模式下,使用CTRL-F快捷键打开命令行窗口,并显示命令历史纪录;
    请注意,您可以使用:set cedit命令,更改此快捷键。
  2. 在常规模式下,使用q:命令打开命令行窗口,并显示命令历史纪录;
    command-line-window
  3. 在常规模式下,使用q/命令打开命令行窗口,并显示向前查找(search forward)的历史纪录;
    command-line-window
  4. 在常规模式下,使用q?命令打开命令行窗口,并显示向后查找(search backward)的历史纪录;
    command-line-window

我们可以将命令行窗口,视为常规的缓冲区 (Buffer)来操作。使用kj键,可以在命令历史纪录中上下移动;也可以使用/命令查找命令历史纪录,并在此基础上进行修改,然后点击<Enter>键来执行命令(命令行窗口也将同时关闭)。

如果同时打开多个缓冲区 (Buffer),那么可以在一个缓冲区的命令行窗口使用yy命令复制一条命令,然后在另一个缓冲区的命令行窗口中粘贴并执行该命令,或者在命令行中使用:@"<CR>来执行复制的命令。也就是说,你可以很方便地在多个缓冲区中,重复执行命令(比如相同的:%s/old/new/g替换操作),而不必多次手工输入命令。

使用以下命令,可以设置命令行窗口的高度(默认值为7):

:set cmdwinheight=n

使用:q命令,可以关闭命令行窗口。

使用:help command-line-window命令,可以查看命令行窗口的更多帮助信息。

Ver: 2.0 | YYQ<上一篇 | 目录 下一篇>

星期日, 七月 07, 2019

VIM学习笔记 替换模式(Replace Mode)

进入替换模式

使用大写R命令,将进入替换模式(屏幕底部显示“--REPLACE--”)。此时新输入的文本将直接替代/覆盖已经存在的内容,直至点击ESC键返回常规模式。

ReplaceMode_Edit.gif
Source: medium.com/vim-drops

使用小写r命令,将进入单字符替换模式,此时新输入的字符将替代光标之下的当前字符,然后自动返回到常规模式。

通过在r命令中增加数字前缀,可以一次性替换多个字符。例如,将光标定位到“||”字符处,然后执行2r&命令,可以将其替换为“&&”。

使用gR命令,将进入虚拟替换模式(virtual replace mode)(屏幕底部显示“--VREPLACE--”),其与替换模式最主要的区别在于,对<Tab>键和换行符的不同处理方式。

区别1:对于<Tab>键的处理方式

在替换模式(REPLACE)下,在原有<Tab>键处输入字母'a',将直接替代<Tab>键所占用的所有空格的位置,文本格式遭到破坏:

REPLACE_A
Source: medium.com/vim-drops

在虚拟替换模式(VREPLACE)下,在原有<Tab>键处输入字母'a',将仅仅替代单个空格,文本格式保持不变:

VREPLACE_A
Source: medium.com/vim-drops

从以上实例可以发现:替换模式(REPLACE)将<Tab>键作为一个整体来处理(不管其真实占用多少个空格位置);而虚拟替换模式(VREPLACE)则将<Tab>键拆分为多个独立的空格来分别处理。如果文本以<Tab>分隔排布,在编辑过程中希望保持原有的文本缩进和排版格式,那么建议使用虚拟替换模式。

区别2:对于<NL>换行的处理方式

在替换模式(REPLACE)下,输入<Enter>回车键将增加新行:

REPLACE_NL

在虚拟替换模式(VREPLACE)下,输入<Enter>回车键将用新行替代当前行内容(即清空当前行):

VREPLACE_NL

使用gr命令,可以进入单字符虚拟替换模式。在替换光标下的当前字符之后,将自动返回到常规模式。

请注意,只有包含+vreplace特性的Vim版本才支持虚拟替换模式。请使用:version命令,查看特性列表中是否已包括此项。

请使用以下命令,查看关于虚拟替换模式的更多帮助信息:

:help vreplace-mode

退出替换模式

按下ESC键即可离开替换模式,返回到常规模式。

命令小结
R进入替换模式
r进入单字符替换模式
gR进入虚拟替换模式
gr进入单字符虚拟替换模式

Ver: 2.0 | YYQ<上一篇 | 目录 下一篇>

星期五, 七月 05, 2019

VIM学习笔记 插入模式 (Insert Mode)

进入插入模式

在常规模式下执行i命令,或者使用:startinsert命令,可以进入插入模式。

灵活使用以下命令,可以直接在你想要的位置进入插入模式:

i在光标之前,进入插入模式
I在本行开头,进入插入模式
a在光标之后,进入插入模式
A在本行结尾,进入插入模式
o在本行之后新增一行,并进入插入模式
O在本行之前新增一行,并进入插入模式
s删除当前字符,并进入插入模式
S删除当前行中的所有文本,并进入插入模式

通过在i,I,a,A命令中增加数字前缀,可以批量插入内容,以避免重复输入。例如:输入50i*命令,然后点击Esc键,将一次性插入50个星号;使用25a*-Esc命令,则将一次性插入25个星号和短线的组合。

通过在小写s命令中增加数字前缀,可以替换多个字符。例如:希望将“www.vim.org”更改为其它网址,可以首先将光标移动到字符“v”处,然后执行3s命令,删除3个字符并进入插入模式输入其它域名。

通过在大写S命令中增加数字前缀,可以替换多行内容。例如:执行3S命令,将删除2行文本,并将第3行文本清空,然后进入插入模式。

在插入模式中编辑

在插入模式下,不能使用h,j,k,l键来移动光标,而必须使用光标移动键。使用以下命令,可以查看使用特殊快捷键进行移动和操作的说明:

:help ins-special-special

在插入模式下,可以使用各种快捷键来操作文本,而不需要首先退回到常规模式,然后再执行命令。例如:使用ctrl-U键,可以删除光标之前的所有文字;而ctrl-W键,则可以删除光标之前的一个字符;使用ctrl-T键,可以增加缩进;而ctrl-D键,则可以减少缩进。请使用以下命令,查看插入模式下快捷键的更多帮助信息:

:help ins-special-keys

使用CTRL-O快捷键,可以进入命令模式执行Vim命令,然后重新回到插入模式,以避免多次切换模式的繁琐。例如,首先使用CTRL-O进入命令模式,然后执行dw命令来删除单词,在执行完毕之后将重新回到插入模式。

退出插入模式

按下ESC键即可离开插入模式,返回到常规模式。建议您在输入完毕文字之后,立即退回到常规模式,以利用各种命令来提高编辑效率。

插入模式帮助信息

使用以下命令,可以查看关于插入模式的帮助信息:

:help insert.txt

使用以下命令,可以查看关于快速插入文本的更多技巧。比如:补全、重复插入、从另一行拷贝、插入一个寄存器内容、缩写插入特殊字符等等:

:help usr_24.txt

Ver: 2.0 | YYQ<上一篇 | 目录 下一篇>

星期一, 七月 01, 2019

VIM学习笔记 QuickFix

某些Vim命令,将会使用QuickFix列表在不同文件的不同位置间导航。例如:使用:make命令进行编译时,遍历编译错误;使用:vimgrep命令进行搜索时,遍历匹配结果;使用:helpgrep命令查找帮助信息时,遍历匹配的主题。

执行以下命令,将在当前文件夹中的所有HTML文件中,搜索字符串“options”:

:vimgrep options *.html

在屏幕底部,将显示查找到的第一个匹配结果:

quickfix_vimgrep_search

打开QuickFix窗口

输入:copen:cwindow命令,将在水平分隔窗口中,打开QuickFix列表以显示所有匹配结果:

quickfix_list

你可以使用ctrl+Wj快捷键,移动到QuickFix窗口。关于在多个窗口之间的跳转操作,请参阅窗口(Window)章节。

在QuickFix列表中导航

使用以下快捷键,可以在QuickFix列表中进行移动或搜索;当到达想要查看的列表项时,点击Enter键,将会打开匹配文件并精确定位到查找结果所处的位置。

k向上移动
j向下移动
Ctrl+b向上翻页pageUp
Ctrl+f向下翻页PageDown
/string向前(Forward)查找字符串string
?string向后(Backward)查找字符串string

注意,如果您在Windows和Mac下,无法利用Ctrl+f键进行翻页,那么请重新恢复Ctrl-F设置

你也可以使用以下命令,直接跳转到匹配文件的查找结果所处位置:

:cnext移动到下一个匹配处
:cprevious移动到上一个匹配处
:cfirst移动到第一个匹配处
:clast移动到最后一个匹配处

quickfix_list_enter

关闭QuickFix窗口

使用以下命令,可以关闭QuickFix窗口:

:cclose

使用:help quickfix命令,可以查看关于QuickFix的更多帮助信息。

Ver: 2.0 | YYQ<上一篇 | 目录 下一篇>

星期三, 六月 26, 2019

VIM学习笔记 Ctrl-F设置

Ctrl-F默认设置

在Linux下的Vim中,Ctrl-F键默认设置为,向前(Forward)滚动屏幕;

而在Windows和Mac下的Vim中,Ctrl-F键默认设置为,打开查找对话框。

此设置是在2017年2月9日发布的8.0.0321版本中开始生效的。通过查看 "C:\Program Files (x86)\Vim\vim81\mswin.vim" 文件,可以发现 Ctrl-F 被设置为打开查找对话框。

恢复Ctrl-F设置

为了保持不同操作系统之间的操作一致性,建议在配置文件(vimrc)中增加以下代码,以重新将Ctrl-F键设置为向前滚动屏幕:

unmap <C-F>

注意,以上设置命令必须放置在以下载入代码之后,以确保设置不会被覆盖:

source $VIMRUNTIME/mswin.vim

Ver: 2.0 | YYQ<上一篇 | 目录 下一篇>

星期日, 六月 23, 2019

VIM学习笔记 图形界面选项(guioptions)

GUI选项

使用以下命令,可以通过guioptions选项来设置GUI特征:

:set guioptions=options

其中 options 是一个字母集合,每个字母代表一个选项:

选项描述
aAutoselect如果设定了此选项,那么在可视化模式下选中文本,Vim会将所选文本放置到系统的全局寄存器中。这就意味着,可以将当前选中的文本用命令 "*p 粘贴到其他文件。如果没有设定此选项,那么就需要使用命令 "*y 将所选择的文本复制到系统寄存器中。在系统寄存中的文本,也可以被其他程序所使用。
P类似Autoselect,但使用"+寄存器,而不是"*寄存器。
fForeground在Linux系统上,gvim可以执行fork()命令,让编辑器在后台运行。通过设置此选项,可以禁用此行为。如果在一个脚本程序中,需要执行gvim命令使得用户可以编辑文件而且要等待到编辑工作结束,此选项就会显得更为有用。(注意:这个选项需要在初始文件中进行设置)
iIcon如果设置了这个选项,gvim就会在X Windows系统上运行而且最小化时会显示一个图标。如果没有设置这个选项,只会显示正在编辑的文件名称而不会显示图标。
mMenu显示菜单栏。
MNomenu如果设置了此选项,那么系统菜单的定义文件$VIMRUNTIME/menu.vim就不会被读入。(注意:此选项需要在初始文件中进行设置)
gGray将不可用的菜单显示为灰色。如果没有设置此选项,那么不可用的菜单就会从菜单栏或是工具栏中移除。
guioption
tTear off启用Tear off菜单(可以将菜单从界面中分离出来)
guioption
TTool bar显示工具栏。
rAlways Right scrollbar总是在编辑器右侧放置滚动条。
RDisplay Right scrollbar如果窗口垂直分隔,将在编辑器右侧放置滚动条。
lAlways Left scrollbar总是在编辑器左侧放置滚动条。
LDisplay Left scrollbar如果窗口垂直分隔,将在编辑器左侧放置滚动条。
bBottom scrollbar在编辑器底部放置滚动条。
vVertical dialog boxes对话框中的按钮采用垂直排列。
guioption

GUI选项实例

使用以下命令,可以隐藏菜单栏、工具栏和滚动条,以获得更大的屏幕空间用于文本编辑;同时,摆脱了对于菜单和工具栏的依赖,也可以死心塌地的使用命令了:

:set guioptions-=m
:set guioptions-=T
:set guioptions-=r
:set guioptions-=l
:set guioptions-=b

guioptions

如果想要重新显示隐藏的窗口部件,可以使用以下命令:

:set guioptions+=T

使用:help guioptions命令,可以查看关于GUI选项的更多帮助信息。

Ver: 2.0 | YYQ<上一篇 | 目录 下一篇>