JohnBeckett (talk | contribs) (tweak and finish merge) |
(Change <tt> to <code>, perhaps also minor tweak.) Tag: rollback |
||
Line 11: | Line 11: | ||
|category2= |
|category2= |
||
}} |
}} |
||
− | When scrolling or searching through a large file, it can be convenient to keep the cursor line near the middle of the screen (vertically centered within the window). This tip introduces the < |
+ | When scrolling or searching through a large file, it can be convenient to keep the cursor line near the middle of the screen (vertically centered within the window). This tip introduces the <code>scrolloff</code> option, and shows another possible technique using the <code>zz</code> command. |
==Scrolloff option== |
==Scrolloff option== |
||
− | The < |
+ | The <code>'scrolloff'</code> (scroll offset) option determines the number of context lines you would like to see above and below the cursor. The following command scrolls the text so that (when possible) there are always at least five lines visible above the cursor, and five lines visible below the cursor: |
<pre> |
<pre> |
||
:set scrolloff=5 |
:set scrolloff=5 |
||
</pre> |
</pre> |
||
− | The above command can be abbreviated as < |
+ | The above command can be abbreviated as <code>:set so=5</code>. Entering <code>:set so=0</code> restores the default behavior so the cursor can be moved to any line in the window without scrolling. |
==Centering with scrolloff== |
==Centering with scrolloff== |
||
− | Setting < |
+ | Setting <code>'scrolloff'</code> to a large value causes the cursor to stay in the middle line when possible: |
<pre> |
<pre> |
||
:set so=999 |
:set so=999 |
||
Line 33: | Line 33: | ||
− | If you change < |
+ | If you change <code>'scrolloff'</code> frequently, you may want to use a mapping. With the following in your [[vimrc]], and assuming the default backslash leader key, you can type <code>\zz</code> to toggle the value of <code>'scrolloff'</code> between <code>0</code> and <code>999</code>: |
<pre> |
<pre> |
||
:nnoremap <Leader>zz :let &scrolloff=999-&scrolloff<CR> |
:nnoremap <Leader>zz :let &scrolloff=999-&scrolloff<CR> |
||
</pre> |
</pre> |
||
− | In an expression, < |
+ | In an expression, <code>&scrolloff</code> refers to the value of the <code>'scrolloff'</code> option. The <code>:let</code> command assigns a value to <code>'scrolloff'</code>; that value is <code>999-0</code> if <code>'scrolloff'</code> was <code>0</code>, and is <code>999-999</code> if <code>'scrolloff'</code> was <code>999</code>. |
==Mapping wanted keys== |
==Mapping wanted keys== |
||
− | An alternative to setting < |
+ | An alternative to setting <code>'scrolloff'</code> would be to remap some commands so that they vertically center the cursor, for example, when moving down or up with <code>j</code> and <code>k</code>. Remap the commands like this: |
<pre> |
<pre> |
||
:nnoremap j jzz |
:nnoremap j jzz |
Revision as of 05:17, 13 July 2012
When scrolling or searching through a large file, it can be convenient to keep the cursor line near the middle of the screen (vertically centered within the window). This tip introduces the scrolloff
option, and shows another possible technique using the zz
command.
Scrolloff option
The 'scrolloff'
(scroll offset) option determines the number of context lines you would like to see above and below the cursor. The following command scrolls the text so that (when possible) there are always at least five lines visible above the cursor, and five lines visible below the cursor:
:set scrolloff=5
The above command can be abbreviated as :set so=5
. Entering :set so=0
restores the default behavior so the cursor can be moved to any line in the window without scrolling.
Centering with scrolloff
Setting 'scrolloff'
to a large value causes the cursor to stay in the middle line when possible:
:set so=999
To restore normal behavior, enter:
:set so=0
If you change 'scrolloff'
frequently, you may want to use a mapping. With the following in your vimrc, and assuming the default backslash leader key, you can type \zz
to toggle the value of 'scrolloff'
between 0
and 999
:
:nnoremap <Leader>zz :let &scrolloff=999-&scrolloff<CR>
In an expression, &scrolloff
refers to the value of the 'scrolloff'
option. The :let
command assigns a value to 'scrolloff'
; that value is 999-0
if 'scrolloff'
was 0
, and is 999-999
if 'scrolloff'
was 999
.
Mapping wanted keys
An alternative to setting 'scrolloff'
would be to remap some commands so that they vertically center the cursor, for example, when moving down or up with j
and k
. Remap the commands like this:
:nnoremap j jzz :nnoremap k kzz