[vte/vte-next: 72/223] Draw the background colour



commit 2bb8cd95dfb4841e3b2ef170f4f2e58f05fc1755
Author: Christian Persch <chpe gnome org>
Date:   Mon May 16 14:08:32 2011 +0200

    Draw the background colour

 src/vte.c     |    6 ++++--
 src/vtedraw.c |   36 ++++++++++++++++++++++++++++--------
 src/vtedraw.h |    3 ++-
 3 files changed, 34 insertions(+), 11 deletions(-)
---
diff --git a/src/vte.c b/src/vte.c
index 5e3c292..de90773 100644
--- a/src/vte.c
+++ b/src/vte.c
@@ -10223,7 +10223,8 @@ vte_terminal_paint_im_preedit_string(VteTerminal *terminal)
 				col * width + terminal->pvt->padding.left,
 				row * height + terminal->pvt->padding.top,
 				width * columns,
-				height);
+				height,
+                                &terminal->pvt->palette[VTE_DEF_BG]);
 		fore = screen->defaults.attr.fore;
 		back = screen->defaults.attr.back;
 		vte_terminal_draw_cells_with_attributes(terminal,
@@ -10333,7 +10334,8 @@ vte_terminal_draw(GtkWidget *widget,
         }
 
         _vte_draw_clear (terminal->pvt->draw, 0, 0,
-                         allocated_width, allocated_height);
+                         allocated_width, allocated_height,
+                         &terminal->pvt->palette[VTE_DEF_BG]);
 
         /* Calculate the bounding rectangle. */
         {
diff --git a/src/vtedraw.c b/src/vtedraw.c
index b360a5e..9f30f89 100644
--- a/src/vtedraw.c
+++ b/src/vtedraw.c
@@ -802,19 +802,39 @@ _vte_draw_set_background_scroll (struct _vte_draw *draw,
 }
 
 void
-_vte_draw_clear (struct _vte_draw *draw, gint x, gint y, gint width, gint height)
+_vte_draw_clear (struct _vte_draw *draw,
+                 gint x,
+                 gint y,
+                 gint width,
+                 gint height,
+                 const GdkRGBA *background)
 {
 	_vte_debug_print (VTE_DEBUG_DRAW, "draw_clear (%d, %d, %d, %d)\n",
 			  x,y,width, height);
 
-        if (draw->bg_pattern == NULL)
-                return;
-
         g_assert(draw->cr);
-        cairo_rectangle (draw->cr, x, y, width, height);
-	cairo_set_operator (draw->cr, CAIRO_OPERATOR_SOURCE);
-	cairo_set_source (draw->cr, draw->bg_pattern);
-	cairo_fill (draw->cr);
+
+        cairo_save (draw->cr);
+
+        if (draw->bg_pattern != NULL) {
+                cairo_rectangle (draw->cr, x, y, width, height);
+
+                cairo_set_operator (draw->cr, CAIRO_OPERATOR_SOURCE);
+                cairo_set_source (draw->cr, draw->bg_pattern);
+                cairo_fill (draw->cr);
+        }
+
+        if (background) {
+                cairo_rectangle (draw->cr, x, y, width, height);
+
+                cairo_set_operator (draw->cr,
+                                    draw->bg_pattern ? CAIRO_OPERATOR_OVER
+                                                     : CAIRO_OPERATOR_SOURCE);
+                gdk_cairo_set_source_rgba (draw->cr, background);
+                cairo_fill (draw->cr);
+        }
+
+        cairo_restore (draw->cr);
 }
 
 void
diff --git a/src/vtedraw.h b/src/vtedraw.h
index 3cbf14c..8aff72d 100644
--- a/src/vtedraw.h
+++ b/src/vtedraw.h
@@ -70,7 +70,8 @@ void _vte_draw_set_background_scroll(struct _vte_draw *draw,
 				     gint x, gint y);
 
 void _vte_draw_clear(struct _vte_draw *draw,
-		     gint x, gint y, gint width, gint height);
+		     gint x, gint y, gint width, gint height,
+                     const GdkRGBA *background);
 
 void _vte_draw_set_text_font(struct _vte_draw *draw,
                              GtkWidget *widget,



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]