ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/rxvt-unicode/src/scrollbar.C
(Generate patch)

Comparing rxvt-unicode/src/scrollbar.C (file contents):
Revision 1.12 by pcg, Sun Feb 1 01:34:41 2004 UTC vs.
Revision 1.14 by pcg, Fri Feb 13 12:16:21 2004 UTC

35rxvt_term::scrollbar_mapping (int map) 35rxvt_term::scrollbar_mapping (int map)
36{ 36{
37 int change = 0; 37 int change = 0;
38 38
39#ifdef HAVE_SCROLLBARS 39#ifdef HAVE_SCROLLBARS
40 if (map && !scrollbar_visible()) 40 if (map && !scrollbar_visible ())
41 { 41 {
42 scrollBar.setIdle (); 42 scrollBar.setIdle ();
43 if (!scrollBar.win) 43 if (!scrollBar.win)
44 resize_scrollbar (); 44 resize_scrollbar ();
45 if (scrollBar.win) 45 if (scrollBar.win)
46 { 46 {
47 XMapWindow(Xdisplay, scrollBar.win); 47 XMapWindow (display->display, scrollBar.win);
48 change = 1; 48 change = 1;
49 } 49 }
50 } 50 }
51 else if (!map && scrollbar_visible()) 51 else if (!map && scrollbar_visible ())
52 { 52 {
53 scrollBar.state = 0; 53 scrollBar.state = 0;
54 XUnmapWindow(Xdisplay, scrollBar.win); 54 XUnmapWindow (display->display, scrollBar.win);
55 change = 1; 55 change = 1;
56 } 56 }
57#endif 57#endif
58 return change; 58 return change;
59} 59}
107#endif 107#endif
108 108
109 if (!scrollBar.win) 109 if (!scrollBar.win)
110 { 110 {
111 /* create the scrollbar window */ 111 /* create the scrollbar window */
112 scrollBar.win = XCreateSimpleWindow(Xdisplay, 112 scrollBar.win = XCreateSimpleWindow (display->display,
113 TermWin.parent[0], 113 TermWin.parent[0],
114 window_sb_x, 0, 114 window_sb_x, 0,
115 scrollbar_TotalWidth(), 115 scrollbar_TotalWidth (),
116 szHint.height, 116 szHint.height,
117 0, 117 0,
118 PixColors[Color_fg], 118 PixColors[Color_fg],
119 PixColors[Color_bg]); 119 PixColors[Color_bg]);
120#ifdef DEBUG_X 120#ifdef DEBUG_X
121 XStoreName(Xdisplay, scrollBar.win, "scrollbar"); 121 XStoreName (display->display, scrollBar.win, "scrollbar");
122#endif 122#endif
123 XDefineCursor(Xdisplay, scrollBar.win, leftptr_cursor); 123 XDefineCursor (display->display, scrollBar.win, leftptr_cursor);
124
124 XSelectInput(Xdisplay, scrollBar.win, 125 XSelectInput (display->display, scrollBar.win,
125 (ExposureMask | ButtonPressMask | ButtonReleaseMask 126 ExposureMask | ButtonPressMask | ButtonReleaseMask
126 | Button1MotionMask | Button2MotionMask 127 | Button1MotionMask | Button2MotionMask
127 | Button3MotionMask)); 128 | Button3MotionMask);
129 scrollbar_ev.start (display, scrollBar.win);
130
128 delayed_init = 1; 131 delayed_init = 1;
129 } 132 }
133
130 scrollbar_show (1); 134 scrollbar_show (1);
135
131 if (delayed_init) 136 if (delayed_init)
132 XMapWindow (Xdisplay, scrollBar.win); 137 XMapWindow (display->display, scrollBar.win);
133#endif 138#endif
134} 139}
135 140
136/* 141/*
137 * Update current scrollbar view w.r.t. slider heights, etc. 142 * Update current scrollbar view w.r.t. slider heights, etc.
141{ 146{
142 int ret = 0; 147 int ret = 0;
143#ifdef HAVE_SCROLLBARS 148#ifdef HAVE_SCROLLBARS
144 int top, bot, len, adj; 149 int top, bot, len, adj;
145 150
146 if (!scrollbar_visible()) 151 if (!scrollbar_visible ())
147 return 0; 152 return 0;
148 153
149 if (update) 154 if (update)
150 { 155 {
151 top = (TermWin.nscrolled - TermWin.view_start); 156 top = (TermWin.nscrolled - TermWin.view_start);
152 bot = top + (TermWin.nrow - 1); 157 bot = top + (TermWin.nrow - 1);
153 len = max((TermWin.nscrolled + (TermWin.nrow - 1)), 1); 158 len = max ((TermWin.nscrolled + (TermWin.nrow - 1)), 1);
154 adj = (((bot - top) * scrollbar_size()) % len) > 0 ? 1 : 0; 159 adj = (((bot - top) * scrollbar_size ()) % len) > 0 ? 1 : 0;
155 160
156 scrollBar.top = (scrollBar.beg + (top * scrollbar_size()) / len); 161 scrollBar.top = (scrollBar.beg + (top * scrollbar_size ()) / len);
157 scrollbar_len = ((bot - top) * scrollbar_size()) / len + 162 scrollbar_len = ((bot - top) * scrollbar_size ()) / len +
158 scrollbar_minheight() + adj; 163 scrollbar_minheight () + adj;
159 scrollBar.bot = (scrollBar.top + scrollbar_len); 164 scrollBar.bot = (scrollBar.top + scrollbar_len);
160 /* no change */ 165 /* no change */
161 if (scrollBar.top == last_top 166 if (scrollBar.top == last_top
162 && scrollBar.bot == last_bot 167 && scrollBar.bot == last_bot
163 && (scrollBar.state == last_state || !scrollbar_isUpDn())) 168 && (scrollBar.state == last_state || !scrollbar_isUpDn ()))
164 return 0; 169 return 0;
165 } 170 }
166 171
167 ret = (this->*scrollBar.update) (update, last_top, last_bot, scrollbar_len); 172 ret = (this->*scrollBar.update) (update, last_top, last_bot, scrollbar_len);
168 173
195 200
196# if (defined(NEXT_SCROLLBAR) || defined(XTERM_SCROLLBAR) || defined(PLAIN_SCROLLBAR)) 201# if (defined(NEXT_SCROLLBAR) || defined(XTERM_SCROLLBAR) || defined(PLAIN_SCROLLBAR))
197 if (scrollstyle) 202 if (scrollstyle)
198 { 203 {
199# ifdef NEXT_SCROLLBAR 204# ifdef NEXT_SCROLLBAR
200 if (STRNCASECMP(scrollstyle, "next", 4) == 0) 205 if (STRNCASECMP (scrollstyle, "next", 4) == 0)
201 style = R_SB_NEXT; 206 style = R_SB_NEXT;
202# endif 207# endif
203# ifdef XTERM_SCROLLBAR 208# ifdef XTERM_SCROLLBAR
204 if (STRNCASECMP(scrollstyle, "xterm", 5) == 0) 209 if (STRNCASECMP (scrollstyle, "xterm", 5) == 0)
205 style = R_SB_XTERM; 210 style = R_SB_XTERM;
206# endif 211# endif
207# ifdef PLAIN_SCROLLBAR 212# ifdef PLAIN_SCROLLBAR
208 if (STRNCASECMP(scrollstyle, "plain", 5) == 0) 213 if (STRNCASECMP (scrollstyle, "plain", 5) == 0)
209 style = R_SB_PLAIN; 214 style = R_SB_PLAIN;
210# endif 215# endif
211 216
212 } 217 }
213# endif 218# endif
219 width = SB_WIDTH_PLAIN; 224 width = SB_WIDTH_PLAIN;
220 else /* if (style == R_SB_RXVT) */ 225 else /* if (style == R_SB_RXVT) */
221 width = SB_WIDTH_RXVT; 226 width = SB_WIDTH_RXVT;
222 227
223 if (style != R_SB_NEXT) /* dishonour request - for now */ 228 if (style != R_SB_NEXT) /* dishonour request - for now */
224 if (thickness && (i = atoi(thickness)) >= SB_WIDTH_MINIMUM) 229 if (thickness && (i = atoi (thickness)) >= SB_WIDTH_MINIMUM)
225 width = min(i, SB_WIDTH_MAXIMUM); 230 width = min (i, SB_WIDTH_MAXIMUM);
226 231
227# if defined(RXVT_SCROLLBAR) 232# if defined(RXVT_SCROLLBAR)
228 if (!(Options & Opt_scrollBar_floating) && style == R_SB_RXVT) 233 if (! (Options & Opt_scrollBar_floating) && style == R_SB_RXVT)
229 sb_shadow = SHADOW; 234 sb_shadow = SHADOW;
230# endif 235# endif
231 236
232 scrollBar.style = style; 237 scrollBar.style = style;
233 scrollBar.width = width; 238 scrollBar.width = width;
234 239
235 /* scrollbar_align = R_SB_ALIGN_CENTRE; */ 240 /* scrollbar_align = R_SB_ALIGN_CENTRE; */
236 if (scrollalign) 241 if (scrollalign)
237 { 242 {
238 if (STRNCASECMP(scrollalign, "top", 3) == 0) 243 if (STRNCASECMP (scrollalign, "top", 3) == 0)
239 scrollbar_align = R_SB_ALIGN_TOP; 244 scrollbar_align = R_SB_ALIGN_TOP;
240 else if (STRNCASECMP(scrollalign, "bottom", 6) == 0) 245 else if (STRNCASECMP (scrollalign, "bottom", 6) == 0)
241 scrollbar_align = R_SB_ALIGN_BOTTOM; 246 scrollbar_align = R_SB_ALIGN_BOTTOM;
242 } 247 }
243#endif 248#endif
244} 249}
245 250

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines