… | |
… | |
151 | rxvt_term::rxvt_term () |
151 | rxvt_term::rxvt_term () |
152 | : |
152 | : |
153 | #if ENABLE_TRANSPARENCY || ENABLE_PERL |
153 | #if ENABLE_TRANSPARENCY || ENABLE_PERL |
154 | rootwin_ev (this, &rxvt_term::rootwin_cb), |
154 | rootwin_ev (this, &rxvt_term::rootwin_cb), |
155 | #endif |
155 | #endif |
156 | #if ENABLE_TRANSPARENCY |
156 | #if HAVE_BG_PIXMAP |
157 | check_our_parents_ev(this, &rxvt_term::check_our_parents_cb), |
157 | update_background_ev(this, &rxvt_term::update_background_cb), |
158 | #endif |
158 | #endif |
159 | #ifdef HAVE_SCROLLBARS |
159 | #ifdef HAVE_SCROLLBARS |
160 | scrollbar_ev (this, &rxvt_term::x_cb), |
160 | scrollbar_ev (this, &rxvt_term::x_cb), |
161 | #endif |
161 | #endif |
162 | #ifdef CURSOR_BLINK |
162 | #ifdef CURSOR_BLINK |
… | |
… | |
506 | if (option (Opt_scrollBar)) |
506 | if (option (Opt_scrollBar)) |
507 | resize_scrollbar (); /* create and map scrollbar */ |
507 | resize_scrollbar (); /* create and map scrollbar */ |
508 | #endif |
508 | #endif |
509 | #ifdef HAVE_BG_PIXMAP |
509 | #ifdef HAVE_BG_PIXMAP |
510 | { |
510 | { |
511 | bool changed = false; |
|
|
512 | bgPixmap.set_target (this); |
511 | bgPixmap.set_target (this); |
513 | |
512 | |
514 | #ifdef ENABLE_TRANSPARENCY |
513 | #ifdef ENABLE_TRANSPARENCY |
515 | if (option (Opt_transparent)) |
514 | if (option (Opt_transparent)) |
516 | { |
515 | { |
… | |
… | |
521 | #endif |
520 | #endif |
522 | if (ISSET_PIXCOLOR (Color_tint)) |
521 | if (ISSET_PIXCOLOR (Color_tint)) |
523 | bgPixmap.set_tint (pix_colors_focused [Color_tint]); |
522 | bgPixmap.set_tint (pix_colors_focused [Color_tint]); |
524 | if (rs [Rs_shade]) |
523 | if (rs [Rs_shade]) |
525 | bgPixmap.set_shade (rs [Rs_shade]); |
524 | bgPixmap.set_shade (rs [Rs_shade]); |
526 | changed = true; |
|
|
527 | |
525 | |
528 | bgPixmap.set_root_pixmap (); |
526 | bgPixmap.set_root_pixmap (); |
529 | XSelectInput (dpy, display->root, PropertyChangeMask); |
527 | XSelectInput (dpy, display->root, PropertyChangeMask); |
530 | rootwin_ev.start (display, display->root); |
528 | rootwin_ev.start (display, display->root); |
531 | } |
529 | } |
… | |
… | |
542 | bgPixmap.set_geometry (p); |
540 | bgPixmap.set_geometry (p); |
543 | } |
541 | } |
544 | else |
542 | else |
545 | bgPixmap.set_defaultGeometry (); |
543 | bgPixmap.set_defaultGeometry (); |
546 | |
544 | |
547 | changed = bgPixmap.set_file (rs[Rs_backgroundPixmap]); |
545 | bgPixmap.set_file (rs[Rs_backgroundPixmap]); |
548 | } |
546 | } |
|
|
547 | /* do not want to render Pixmap yet if we are size/position dependant - |
|
|
548 | * wait for ConfigureNotify at least |
|
|
549 | * TODO: this does not work for some reason when transparency is disabled !!!! |
|
|
550 | */ |
|
|
551 | if (!bgPixmap.window_size_sensitive ()) |
|
|
552 | update_background(); |
549 | #endif |
553 | #endif |
550 | if (changed) |
|
|
551 | { |
|
|
552 | bgPixmap.render_background (); |
|
|
553 | scr_touch (true); |
|
|
554 | } |
|
|
555 | } |
554 | } |
556 | #endif |
555 | #endif |
557 | |
556 | |
558 | #if ENABLE_PERL |
557 | #if ENABLE_PERL |
559 | rootwin_ev.start (display, display->root); |
558 | rootwin_ev.start (display, display->root); |
… | |
… | |
1149 | |
1148 | |
1150 | XMoveResizeWindow (dpy, vt, |
1149 | XMoveResizeWindow (dpy, vt, |
1151 | window_vt_x, window_vt_y, |
1150 | window_vt_x, window_vt_y, |
1152 | width, height); |
1151 | width, height); |
1153 | |
1152 | |
|
|
1153 | #ifdef XPM_BACKGROUND |
|
|
1154 | /* TODO: replace with update_pixmap() that should unify transparency and bg image handling ! */ |
|
|
1155 | if (bgPixmap.window_size_sensitive ()) |
|
|
1156 | update_background (); |
|
|
1157 | #endif |
|
|
1158 | |
1154 | scr_clear (); |
1159 | scr_clear (); |
1155 | #ifdef XPM_BACKGROUND |
|
|
1156 | /* TODO: should that really be here ? */ |
|
|
1157 | bgPixmap.render_background (); |
|
|
1158 | #endif |
|
|
1159 | } |
1160 | } |
1160 | |
1161 | |
1161 | if (fix_screen || old_height == 0) |
1162 | if (fix_screen || old_height == 0) |
1162 | scr_reset (); |
1163 | scr_reset (); |
1163 | |
1164 | |
1164 | // TODO, with nvidia-8178, resizes kill the alpha channel, report if not fixed in newer version |
1165 | // TODO, with nvidia-8178, resizes kill the alpha channel, report if not fixed in newer version |
1165 | //scr_touch (false); |
1166 | //scr_touch (false); |
1166 | |
1167 | |
1167 | #ifdef HAVE_BG_PIXMAP |
1168 | #ifdef HAVE_BG_PIXMAP |
|
|
1169 | // TODO: this don't seem to have any effect - do we still need it ? If so - in which case exactly ? |
1168 | if (bgPixmap.pixmap) |
1170 | // if (bgPixmap.pixmap) |
1169 | scr_touch (false); |
1171 | // scr_touch (false); |
1170 | #endif |
1172 | #endif |
1171 | |
1173 | |
1172 | #ifdef USE_XIM |
1174 | #ifdef USE_XIM |
1173 | IMSetPosition (); |
1175 | IMSetPosition (); |
1174 | #endif |
1176 | #endif |