使用 neovim 的浮动窗口让你再次爱上 fzf

2019-04-13 11:56:59 +08:00
 simple26

fzf 是一个非常高效实用且美观的命令行工具,并且配置有对应的 vim 插件 fzf.vim, 相信很多人都用过。这里就不在赘述,如果你还没有用过,很推荐一试。

自从 neovim 的浮动窗口 PR https://github.com/neovim/neovim/pull/6619 被合到 master 以后,很多插件都利用了这个特性实现了很多很酷的功能,比如 coc.nvim,另外 vim-which-keyvista.vim 也利用了这一特性 。

浮动窗口的一个很大的特点就是不会像之前 split 的方式扰动你的窗口布局,晃动你的视线,而 fzf 也可以利用这一特性进一步提升体验!

比如下面这个效果图,我们可以让 fzf 在中间进行显示,有点类似于 IDEA 的搜索窗口:

要实现上面的效果,需要配置 3 个地方。首先是 2 个配置项:

    " 让输入上方,搜索列表在下方
    let $FZF_DEFAULT_OPTS = '--layout=reverse'

    " 打开 fzf 的方式选择 floating window
    let g:fzf_layout = { 'window': 'call OpenFloatingWin()' }

还有 1 个函数指定如何打开浮动窗口:

function! OpenFloatingWin()
  let height = &lines - 3
  let width = float2nr(&columns - (&columns * 2 / 10))
  let col = float2nr((&columns - width) / 2)

  " 设置浮动窗口打开的位置,大小等。
  " 这里的大小配置可能不是那么的 flexible 有继续改进的空间
  let opts = {
        \ 'relative': 'editor',
        \ 'row': height * 0.3,
        \ 'col': col + 30,
        \ 'width': width * 2 / 3,
        \ 'height': height / 2
        \ }

  let buf = nvim_create_buf(v:false, v:true)
  let win = nvim_open_win(buf, v:true, opts)

  " 设置浮动窗口高亮
  call setwinvar(win, '&winhl', 'Normal:Pmenu')

  setlocal
        \ buftype=nofile
        \ nobuflisted
        \ bufhidden=hide
        \ nonumber
        \ norelativenumber
        \ signcolumn=no
endfunction

关于浮动窗口的更多信息,可以 :help api-floatwin.

另外,如果你的浮动窗口设置高亮无效,看看是否有设置 g:fzf_colors,这可能会重置浮动窗口的高亮,有浮动窗口的话就不用设置了。

因为还没有 release, 目前要体验这个特性的话需要自己从 neovim master 编译,macOS 用户直接 安装 HEAD 版本的 neovim 就行了。安装好 neovim,然后进行如上配置应该就可以了,对于 https://github.com/liuchengxu/space-vim 用户直接升级 space-vim 即可。

4413 次点击
所在节点    Vim
13 条回复
yuuko
2019-04-13 13:38:26 +08:00
不错
bookit
2019-04-13 15:02:06 +08:00
这样可以模拟多数现代编辑器的功能了,期待 ing
BBCCBB
2019-04-13 17:33:17 +08:00
这个浮动窗口真是 nice
FrankFang128
2019-04-13 17:36:47 +08:00
直接用 IDE 的路过,不想配这些东西了。
genesislive
2019-04-13 17:42:15 +08:00
图片加载不出来
glues
2019-04-13 18:02:14 +08:00
🐂🍺
simple26
2019-04-13 18:37:38 +08:00
@FrankFang128 我也用 IDE 各有所长
yujincheng08
2019-04-13 22:11:40 +08:00
😉LanguageClient 也用上了,很爽
omph
2019-04-13 22:17:33 +08:00
neovim 显示中文的时候,光标是错位的,很难编辑,vim 就没有问题,可惜了
yujincheng08
2019-04-13 22:24:13 +08:00
@omph 我没这问题呀。是不是版本太低?👀
omph
2019-04-13 22:32:27 +08:00
@yujincheng08 用的源里的,neovim 0.3.4-2,应该挺新的吧
yujincheng08
2019-04-13 22:33:32 +08:00
@omph 我也是这个版本,但是没有问题。可能是字体原因?
x1314aq
2019-04-27 09:47:25 +08:00
要是能在编辑的同时支持动态收缩 floating windows 就更好了

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/554751

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX