aboutsummaryrefslogtreecommitdiff
path: root/man/man3/mousescrollsize.3
blob: 915a6bb1341660e9200a89751395ba33e65cce8b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
.TH MOUSESCROLLSIZE 3
.SH NAME
mousescrollsize \- compute mouse scroll increment
.SH SYNOPSIS
.B #include <draw.h>
.PP
int	mousescrollsize(int maxlines)
.SH DESCRIPTION
.I Mousescrollsize
computes the number of lines of text that should be scrolled
in response to a mouse scroll wheel click.
.I Maxlines
is the number of lines visible in the text window.
.PP
The default scroll increment is one line.
This default can be overridden by setting the
.B $mousescrollsize
environment variable to an integer, which specifies
a constant number of lines, or to a real number
followed by a percent character, indicating that the
scroll increment should be a percentage of the total
number of lines in the window.
For example, setting 
.B $mousescrollsize
to 
.B 50%
causes a half-window scroll increment.
.PP
.I Mousescrollsize
is used by
.IR 9term (1)
and
.IR acme (1)
to set their scrolling behavior.
.SH SOURCE
.B /usr/local/plan9/src/libdraw/scroll.c
.SH SEE ALSO
.IR 9term (1),
.IR acme (1)
.SH BUGS
.I Libdraw
expects up and down scroll wheel events to be expressed as clicks of mouse buttons 4 and 5,
but the XFree86 default is to ignore the scroll wheel.
To enable the scroll wheel, change your
.B InputDevice
section of
.B XF86Config-4
to look like:
.IP
.EX
Section "InputDevice"
	Identifier	"Mouse0"
	Driver	"mouse"
	Option	"Device" "/dev/psaux"

	# next four lines enable scroll wheel as buttons 4 and 5
	Option	"Buttons" "5"
	Option	"Emulate3Buttons" "off"
	Option	"Protocol" "ImPS/2"
	Option	"ZAxisMapping" "4 5"
EndSection
.EE