… | |
… | |
110 | { |
110 | { |
111 | /* create the scrollbar window */ |
111 | /* create the scrollbar window */ |
112 | scrollBar.win = XCreateSimpleWindow (dpy, |
112 | scrollBar.win = XCreateSimpleWindow (dpy, |
113 | parent[0], |
113 | parent[0], |
114 | window_sb_x, 0, |
114 | window_sb_x, 0, |
115 | scrollbar_TotalWidth (), |
115 | scrollBar.total_width (), |
116 | szHint.height, |
116 | szHint.height, |
117 | 0, |
117 | 0, |
118 | pix_colors[Color_fg], |
118 | pix_colors[Color_fg], |
119 | pix_colors[Color_border]); |
119 | pix_colors[Color_border]); |
120 | XDefineCursor (dpy, scrollBar.win, scrollBar.leftptr_cursor); |
120 | XDefineCursor (dpy, scrollBar.win, scrollBar.leftptr_cursor); |
… | |
… | |
149 | if (update) |
149 | if (update) |
150 | { |
150 | { |
151 | top = view_start - top_row; |
151 | top = view_start - top_row; |
152 | bot = top + (nrow - 1); |
152 | bot = top + (nrow - 1); |
153 | len = max (nrow - 1 - top_row, 1); |
153 | len = max (nrow - 1 - top_row, 1); |
154 | adj = (((bot - top) * scrollbar_size ()) % len) > 0 ? 1 : 0; |
154 | adj = (((bot - top) * scrollBar.size ()) % len) > 0 ? 1 : 0; |
155 | |
155 | |
156 | scrollBar.top = (scrollBar.beg + (top * scrollbar_size ()) / len); |
156 | scrollBar.top = (scrollBar.beg + (top * scrollBar.size ()) / len); |
157 | scrollBar.len = ((bot - top) * scrollbar_size ()) / len + |
157 | scrollBar.len = ((bot - top) * scrollBar.size ()) / len + |
158 | scrollbar_minheight () + adj; |
158 | scrollBar.min_height () + adj; |
159 | scrollBar.bot = (scrollBar.top + scrollBar.len); |
159 | scrollBar.bot = (scrollBar.top + scrollBar.len); |
160 | /* no change */ |
160 | /* no change */ |
161 | if (scrollBar.top == scrollBar.last_top |
161 | if (scrollBar.top == scrollBar.last_top |
162 | && scrollBar.bot == scrollBar.last_bot |
162 | && scrollBar.bot == scrollBar.last_bot |
163 | && (scrollBar.state == scrollBar.last_state |
163 | && (scrollBar.state == scrollBar.last_state |
… | |
… | |
229 | if (thickness && (i = atoi (thickness)) >= SB_WIDTH_MINIMUM) |
229 | if (thickness && (i = atoi (thickness)) >= SB_WIDTH_MINIMUM) |
230 | width = min (i, SB_WIDTH_MAXIMUM); |
230 | width = min (i, SB_WIDTH_MAXIMUM); |
231 | |
231 | |
232 | # ifdef RXVT_SCROLLBAR |
232 | # ifdef RXVT_SCROLLBAR |
233 | if (! term->option (Opt_scrollBar_floating) && style == R_SB_RXVT) |
233 | if (! term->option (Opt_scrollBar_floating) && style == R_SB_RXVT) |
234 | scrollBar.shadow = SHADOW_WIDTH; |
234 | shadow = SHADOW_WIDTH; |
235 | # endif |
235 | # endif |
236 | |
236 | |
237 | this->style = style; |
237 | this->style = style; |
238 | this->width = width; |
238 | this->width = width; |
239 | |
239 | |
240 | /* scrollBar.align = R_SB_ALIGN_CENTRE; */ |
240 | /* align = R_SB_ALIGN_CENTRE; */ |
241 | if (scrollalign) |
241 | if (scrollalign) |
242 | { |
242 | { |
243 | if (strncasecmp (scrollalign, "top", 3) == 0) |
243 | if (strncasecmp (scrollalign, "top", 3) == 0) |
244 | align = R_SB_ALIGN_TOP; |
244 | align = R_SB_ALIGN_TOP; |
245 | else if (strncasecmp (scrollalign, "bottom", 6) == 0) |
245 | else if (strncasecmp (scrollalign, "bottom", 6) == 0) |