在尝试匹配终端的调色板和GVim的调色板时,我注意到了这一点:


当我打开GVim和Vim时,我看到:

(这是相同的文件,我的vimrc。)
如果我执行:set t_Co=256,则GVim中什么也没有发生(除了闪烁),而终端中的颜色现在看起来有所不同。如果现在执行:set bg=dark,则没有任何区别(再次GVim闪烁)。
如果再次执行:set bg=light,然后再次执行:set bg=dark,则会得到:



我的vimrc中同时存在:set bg=dark:set t_Co=256。为什么我的:set bg:set t_Co不会卡住,为什么在:set bg=dark之后再设置:set bg=light会使原来没有的地方有所不同?

我使用的是Arch Linux,终端是GNOME Terminal,并且我没有.gvimrc

$ vim --version
VIM - Vi IMproved 7.4 (2013 Aug 10, compiled Feb  4 2015 08:03:11)
Included patches: 1-617
Compiled by Arch Linux
Huge version with GTK2 GUI.  Features included (+) or not (-):
+acl             +farsi           +mouse_netterm   +syntax
+arabic          +file_in_path    +mouse_sgr       +tag_binary
+autocmd         +find_in_path    -mouse_sysmouse  +tag_old_static
+balloon_eval    +float           +mouse_urxvt     -tag_any_white
+browse          +folding         +mouse_xterm     -tcl
++builtin_terms  -footer          +multi_byte      +terminfo
+byte_offset     +fork()          +multi_lang      +termresponse
+cindent         +gettext         -mzscheme        +textobjects
+clientserver    -hangul_input    +netbeans_intg   +title
+clipboard       +iconv           +path_extra      +toolbar
+cmdline_compl   +insert_expand   +perl            +user_commands
+cmdline_hist    +jumplist        +persistent_undo +vertsplit
+cmdline_info    +keymap          +postscript      +virtualedit
+comments        +langmap         +printer         +visual
+conceal         +libcall         +profile         +visualextra
+cryptv          +linebreak       -python          +viminfo
+cscope          +lispindent      +python3         +vreplace
+cursorbind      +listcmds        +quickfix        +wildignore
+cursorshape     +localmap        +reltime         +wildmenu
+dialog_con_gui  +lua             +rightleft       +windows
+diff            +menu            +ruby            +writebackup
+digraphs        +mksession       +scrollbind      +X11
+dnd             +modify_fname    +signs           -xfontset
-ebcdic          +mouse           +smartindent     +xim
+emacs_tags      +mouseshape      -sniff           +xsmp_interact
+eval            +mouse_dec       +startuptime     +xterm_clipboard
+ex_extra        +mouse_gpm       +statusline      -xterm_save
+extra_search    -mouse_jsbterm   -sun_workshop    -xpm
   system vimrc file: "/etc/vimrc"
     user vimrc file: "$HOME/.vimrc"
 2nd user vimrc file: "~/.vim/vimrc"
      user exrc file: "$HOME/.exrc"
  system gvimrc file: "/etc/gvimrc"
    user gvimrc file: "$HOME/.gvimrc"
2nd user gvimrc file: "~/.vim/gvimrc"
    system menu file: "$VIMRUNTIME/menu.vim"
  fall-back for $VIM: "/usr/share/vim"
Compilation: gcc -c -I. -Iproto -DHAVE_CONFIG_H -DFEAT_GUI_GTK  -pthread -I/usr/include/gtk-2.0 -I/usr/lib/gtk-2.0/include -I/usr/include/pango-1.0 -I/usr/include/atk-1.0 -I/usr/include/cairo -I/usr/include/pixman-1 -I/usr/include/libdrm -I/usr/include/gdk-pixbuf-2.0 -I/usr/include/libpng16 -I/usr/include/pango-1.0 -I/usr/include/glib-2.0 -I/usr/lib/glib-2.0/include -I/usr/include/freetype2 -I/usr/include/libpng16 -I/usr/include/harfbuzz -I/usr/include/freetype2 -I/usr/include/libpng16 -I/usr/include/harfbuzz  -D_FORTIFY_SOURCE=2  -march=x86-64 -mtune=generic -O2 -pipe -fstack-protector-strong --param=ssp-buffer-size=4 -U_FORTIFY_SOURCE -D_FORTIFY_SOURCE=1      
Linking: gcc   -L. -Wl,-O1,--sort-common,--as-needed,-z,relro -fstack-protector -rdynamic -Wl,-export-dynamic -Wl,-E -Wl,-rpath,/usr/lib/perl5/core_perl/CORE  -Wl,-O1,--sort-common,--as-needed,-z,relro -L/usr/local/lib -Wl,--as-needed -o vim   -lgtk-x11-2.0 -lgdk-x11-2.0 -lpangocairo-1.0 -latk-1.0 -lcairo -lgdk_pixbuf-2.0 -lgio-2.0 -lpangoft2-1.0 -lpango-1.0 -lgobject-2.0 -lglib-2.0 -lfontconfig -lfreetype  -lSM -lICE -lXt -lX11 -lXdmcp -lSM -lICE  -lm -lncurses -lelf -lnsl   -lacl -lattr -lgpm -ldl  -L/usr/lib -llua -Wl,-E -Wl,-rpath,/usr/lib/perl5/core_perl/CORE -Wl,-O1,--sort-common,--as-needed,-z,relro -fstack-protector -L/usr/local/lib  -L/usr/lib/perl5/core_perl/CORE -lperl -lnsl -ldl -lm -lcrypt -lutil -lpthread -lc  -L/usr/lib/python3.4/config-3.4m -lpython3.4m -lpthread -ldl -lutil -lm  -lruby -lpthread -lgmp -ldl -lcrypt -lm  -L/usr/lib


#1 楼


Elflord Colorcheme做set background=dark。由于它是在您的set bg=light之后获取的,因此它将覆盖它。

set t_Co=256是没有意义的。它在GVim中没有任何作用,您应该正确设置终端仿真器。

此外,elflord仅在颜色终端中使用基本的ANSI颜色,因此如果强制Vim执行查看256色,或者将TERM设置为256色;您的colorcheme绝对不会使用该扩展调色板。相反,发生的是您原来的TERM可能是xtermscreen或其他一些将Vim限制为8种颜色的值。但是Elflord使用“深色”和“浅色”两种颜色,需要在8以上的TERM。因此,强制使用256种颜色将更改您的颜色。


建议:


请勿更改't_Co'的值。
请勿更改set background




评论


如果elflord将bg设置为暗,那么如果将其设置为亮并再次返回,为什么外观会发生变化?注意我的vimrc没有设置bg = light。

–muru
15年2月18日在8:23

set bg更改某些高光组的颜色和属性,以便它们在深色或浅色背景下效果更好。它通常是任意的,并且可能会或可能不会起作用,具体取决于您使用的颜色方案。搞混这个选项不是一个好主意。

– romainl
15年2月18日在9:20

我听了您关于bg和t_Co的建议。我只是想知道为什么艾尔弗洛德(elflord)的设置bg = dark和mine会导致如此不同(但可重复)的结果?

–muru
15年2月18日在9:24

这是应用它们的顺序。因为一个不是与另一个在“暗”和“亮”之间多次切换的完全相反,所以这不是两个确定和稳定状态之间的切换。

– romainl
15年2月18日在9:33