[evolution] e-table: Draw ECellText with cairo
- From: Matthew Barnes <mbarnes src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [evolution] e-table: Draw ECellText with cairo
- Date: Fri, 29 Oct 2010 18:40:24 +0000 (UTC)
commit 1e74b08c03fad5db67fae46ba14d69105a06955f
Author: Benjamin Otte <otte redhat com>
Date: Wed Oct 20 20:27:09 2010 +0200
e-table: Draw ECellText with cairo
widgets/table/e-cell-text.c | 84 +++++++++++++++---------------------------
1 files changed, 30 insertions(+), 54 deletions(-)
---
diff --git a/widgets/table/e-cell-text.c b/widgets/table/e-cell-text.c
index 5ac868a..b704263 100644
--- a/widgets/table/e-cell-text.c
+++ b/widgets/table/e-cell-text.c
@@ -124,7 +124,6 @@ typedef struct _CellEdit CellEdit;
typedef struct {
ECellView cell_view;
- GdkGC *gc;
GdkCursor *i_cursor;
GnomeCanvas *canvas;
@@ -371,7 +370,6 @@ ect_realize (ECellView *ecell_view)
GdkWindow *window;
window = gtk_widget_get_window (GTK_WIDGET (text_view->canvas));
- text_view->gc = gdk_gc_new (window);
text_view->i_cursor = gdk_cursor_new (GDK_XTERM);
@@ -389,9 +387,6 @@ ect_unrealize (ECellView *ecv)
ECellText *ect = (ECellText*) ecv->ecell;
GdkColormap *colormap;
- g_object_unref (text_view->gc);
- text_view->gc = NULL;
-
if (text_view->edit) {
ect_cancel_edit (text_view);
}
@@ -630,7 +625,7 @@ generate_layout (ECellTextView *text_view, gint model_col, gint view_col, gint r
}
static void
-draw_pango_rectangle (GdkDrawable *drawable, GdkGC *gc, gint x1, gint y1, PangoRectangle rect)
+draw_pango_rectangle (cairo_t *cr, gint x1, gint y1, PangoRectangle rect)
{
gint width = rect.width / PANGO_SCALE;
gint height = rect.height / PANGO_SCALE;
@@ -638,8 +633,9 @@ draw_pango_rectangle (GdkDrawable *drawable, GdkGC *gc, gint x1, gint y1, PangoR
width = 1;
if (height <= 0)
height = 1;
- gdk_draw_rectangle (drawable, gc, TRUE,
- x1 + rect.x / PANGO_SCALE, y1 + rect.y / PANGO_SCALE, width, height);
+ cairo_rectangle (cr,
+ x1 + rect.x / PANGO_SCALE, y1 + rect.y / PANGO_SCALE,
+ width, height);
}
static gboolean
@@ -705,23 +701,24 @@ ect_draw (ECellView *ecell_view, GdkDrawable *drawable,
ECellText *ect = E_CELL_TEXT (ecell_view->ecell);
CellEdit *edit = text_view->edit;
gboolean selected;
- GdkColor *foreground;
GtkWidget *canvas = GTK_WIDGET (text_view->canvas);
- GdkRectangle clip_rect;
GtkStyle *style;
gint x_origin, y_origin, vspacing;
+ cairo_t *cr;
style = gtk_widget_get_style (canvas);
selected = flags & E_CELL_SELECTED;
+ cr = gdk_cairo_create (drawable);
+
if (selected) {
if (gtk_widget_has_focus (canvas))
- foreground = &style->fg[GTK_STATE_SELECTED];
+ gdk_cairo_set_source_color (cr, &style->fg[GTK_STATE_SELECTED]);
else
- foreground = &style->fg[GTK_STATE_ACTIVE];
+ gdk_cairo_set_source_color (cr, &style->fg[GTK_STATE_ACTIVE]);
} else {
- foreground = &style->text[GTK_STATE_NORMAL];
+ gdk_cairo_set_source_color (cr, &style->text[GTK_STATE_NORMAL]);
if (ect->color_column != -1) {
gchar *color_spec;
@@ -732,12 +729,10 @@ ect_draw (ECellView *ecell_view, GdkDrawable *drawable,
cell_foreground = e_cell_text_get_color (text_view,
color_spec);
if (cell_foreground)
- foreground = cell_foreground;
+ gdk_cairo_set_source_color (cr, cell_foreground);
}
}
- gdk_gc_set_foreground (text_view->gc, foreground);
-
vspacing = get_vertical_spacing (canvas);
x1 += 4;
@@ -748,13 +743,8 @@ ect_draw (ECellView *ecell_view, GdkDrawable *drawable,
x_origin = x1 + ect->x + text_view->xofs - (edit ? edit->xofs_edit : 0);
y_origin = y1 + ect->y + text_view->yofs - (edit ? edit->yofs_edit : 0);
- clip_rect.x = x1;
- clip_rect.y = y1;
- clip_rect.width = x2 - x1;
- clip_rect.height = y2 - y1;
-
- gdk_gc_set_clip_rectangle (text_view->gc, &clip_rect);
- /* clip_rect = ▭*/
+ cairo_rectangle (cr, x1, y1, x2 - x1, y2 - y1);
+ cairo_clip (cr);
layout = generate_layout (text_view, model_col, view_col, row, x2 - x1);
@@ -762,16 +752,16 @@ ect_draw (ECellView *ecell_view, GdkDrawable *drawable,
layout = layout_with_preedit (text_view, row, edit->text ? edit->text : "?", x2 - x1);
}
- gdk_draw_layout (drawable, text_view->gc,
- x_origin, y_origin,
- layout);
+ cairo_move_to (cr, x_origin, y_origin);
+ pango_cairo_show_layout (cr, layout);
if (edit && edit->view_col == view_col && edit->row == row) {
if (edit->selection_start != edit->selection_end) {
- GdkRegion *clip_region, *rect_region;
- GdkGC *selection_gc;
- GdkGC *text_gc;
+ GdkRegion *clip_region;
gint indices[2];
+ GtkStateType state;
+
+ state = edit->has_selection ? GTK_STATE_SELECTED : GTK_STATE_ACTIVE;
indices[0] = MIN (edit->selection_start, edit->selection_end);
indices[1] = MAX (edit->selection_start, edit->selection_end);
@@ -779,47 +769,33 @@ ect_draw (ECellView *ecell_view, GdkDrawable *drawable,
clip_region = gdk_pango_layout_get_clip_region (layout,
x_origin, y_origin,
indices, 1);
+ gdk_cairo_region (cr, clip_region);
+ cairo_clip (cr);
+ gdk_region_destroy (clip_region);
- rect_region = gdk_region_rectangle (&clip_rect);
- gdk_region_intersect (clip_region, rect_region);
- gdk_region_destroy (rect_region);
-
- if (edit->has_selection) {
- selection_gc = style->base_gc[GTK_STATE_SELECTED];
- text_gc = style->text_gc[GTK_STATE_SELECTED];
- } else {
- selection_gc = style->base_gc[GTK_STATE_ACTIVE];
- text_gc = style->text_gc[GTK_STATE_ACTIVE];
- }
-
- gdk_gc_set_clip_region (selection_gc, clip_region);
- gdk_gc_set_clip_region (text_gc, clip_region);
-
- gdk_draw_rectangle (drawable, selection_gc, TRUE,
- x1, y1, x2 - x1, y2 - y1);
- gdk_draw_layout (drawable, text_gc,
- x_origin, y_origin,
- layout);
- gdk_gc_set_clip_region (text_gc, NULL);
- gdk_gc_set_clip_region (selection_gc, NULL);
+ gdk_cairo_set_source_color (cr, &style->base[state]);
+ cairo_paint (cr);
- gdk_region_destroy (clip_region);
+ gdk_cairo_set_source_color (cr, &style->text[state]);
+ cairo_move_to (cr, x_origin, y_origin);
+ pango_cairo_show_layout (cr, layout);
} else {
if (edit->show_cursor) {
PangoRectangle strong_pos, weak_pos;
pango_layout_get_cursor_pos (layout, edit->selection_start + edit->preedit_length, &strong_pos, &weak_pos);
- draw_pango_rectangle (drawable, text_view->gc, x_origin, y_origin, strong_pos);
+ draw_pango_rectangle (cr, x_origin, y_origin, strong_pos);
if (strong_pos.x != weak_pos.x ||
strong_pos.y != weak_pos.y ||
strong_pos.width != weak_pos.width ||
strong_pos.height != weak_pos.height)
- draw_pango_rectangle (drawable, text_view->gc, x_origin, y_origin, weak_pos);
+ draw_pango_rectangle (cr, x_origin, y_origin, weak_pos);
}
}
}
g_object_unref (layout);
+ cairo_destroy (cr);
}
/*
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]