GtkThemingEngine: Cairo-ify extension rendering from GtkStyle.
This commit is contained in:
parent
4772b67563
commit
7d2b51f147
@ -1433,7 +1433,6 @@ gtk_theming_engine_render_extension (GtkThemingEngine *engine,
|
|||||||
GtkStateType state;
|
GtkStateType state;
|
||||||
GdkColor *bg_color;
|
GdkColor *bg_color;
|
||||||
GdkColor lighter, darker;
|
GdkColor lighter, darker;
|
||||||
guint sides;
|
|
||||||
|
|
||||||
cairo_save (cr);
|
cairo_save (cr);
|
||||||
flags = gtk_theming_engine_get_state (engine);
|
flags = gtk_theming_engine_get_state (engine);
|
||||||
@ -1455,45 +1454,105 @@ gtk_theming_engine_render_extension (GtkThemingEngine *engine,
|
|||||||
color_shade (bg_color, 0.7, &darker);
|
color_shade (bg_color, 0.7, &darker);
|
||||||
color_shade (bg_color, 1.3, &lighter);
|
color_shade (bg_color, 1.3, &lighter);
|
||||||
|
|
||||||
add_path_rounded_rectangle (cr, 0,
|
switch (gap_side)
|
||||||
SIDE_BOTTOM | SIDE_RIGHT | SIDE_TOP | SIDE_LEFT,
|
{
|
||||||
x, y, width, height);
|
case GTK_POS_TOP:
|
||||||
cairo_close_path (cr);
|
gdk_cairo_set_source_color (cr, bg_color);
|
||||||
|
cairo_rectangle (cr, x + 1, y, width - 2, height);
|
||||||
|
cairo_fill (cr);
|
||||||
|
|
||||||
gdk_cairo_set_source_color (cr, bg_color);
|
gdk_cairo_set_source_color (cr, &lighter);
|
||||||
cairo_fill (cr);
|
add_path_line (cr, x, y, x, y + height - 2);
|
||||||
|
cairo_stroke (cr);
|
||||||
|
|
||||||
if (gap_side == GTK_POS_RIGHT)
|
gdk_cairo_set_source_color (cr, bg_color);
|
||||||
sides = SIDE_BOTTOM;
|
add_path_line (cr, x + 1, y, x + 1, y + height - 2);
|
||||||
else if (gap_side == GTK_POS_BOTTOM)
|
cairo_stroke (cr);
|
||||||
sides = SIDE_RIGHT;
|
|
||||||
else
|
|
||||||
sides = SIDE_BOTTOM | SIDE_RIGHT;
|
|
||||||
|
|
||||||
add_path_rounded_rectangle (cr, 0, sides,
|
gdk_cairo_set_source_color (cr, &darker);
|
||||||
x, y, width, height);
|
add_path_line (cr, x + 2, y + height - 2, x + width - 2, y + height - 2);
|
||||||
|
add_path_line (cr, x + width - 2, y, x + width - 2, y + height - 2);
|
||||||
|
cairo_stroke (cr);
|
||||||
|
|
||||||
cairo_set_source_rgb (cr, 0, 0, 0);
|
cairo_set_source_rgb (cr, 0, 0, 0);
|
||||||
cairo_stroke (cr);
|
add_path_line (cr, x + 1, y + height - 1, x + width - 2, y + height - 1);
|
||||||
|
add_path_line (cr, x + width - 1, y, x + width - 1, y + height - 2);
|
||||||
|
cairo_stroke (cr);
|
||||||
|
|
||||||
add_path_rounded_rectangle (cr, 0, sides,
|
break;
|
||||||
x, y, width - 1, height - 1);
|
case GTK_POS_BOTTOM:
|
||||||
|
gdk_cairo_set_source_color (cr, bg_color);
|
||||||
|
cairo_rectangle (cr, x + 1, y, width - 2, height);
|
||||||
|
cairo_fill (cr);
|
||||||
|
|
||||||
gdk_cairo_set_source_color (cr, &darker);
|
gdk_cairo_set_source_color (cr, &lighter);
|
||||||
cairo_stroke (cr);
|
add_path_line (cr, x + 1, y, x + width - 2, y);
|
||||||
|
add_path_line (cr, x, y + 1, x, y + height - 1);
|
||||||
|
cairo_stroke (cr);
|
||||||
|
|
||||||
if (gap_side == GTK_POS_LEFT)
|
gdk_cairo_set_source_color (cr, bg_color);
|
||||||
sides = SIDE_TOP;
|
add_path_line (cr, x + 1, y + 1, x + width - 2, y + 1);
|
||||||
else if (gap_side == GTK_POS_TOP)
|
add_path_line (cr, x + 1, y + 1, x + 1, y + height - 1);
|
||||||
sides = SIDE_LEFT;
|
cairo_stroke (cr);
|
||||||
else
|
|
||||||
sides = SIDE_TOP | SIDE_LEFT;
|
|
||||||
|
|
||||||
add_path_rounded_rectangle (cr, 0, sides,
|
gdk_cairo_set_source_color (cr, &darker);
|
||||||
x, y, width, height);
|
add_path_line (cr, x + width - 2, y + 2, x + width - 2, y + height - 1);
|
||||||
|
cairo_stroke (cr);
|
||||||
|
|
||||||
gdk_cairo_set_source_color (cr, &lighter);
|
cairo_set_source_rgb (cr, 0, 0, 0);
|
||||||
cairo_stroke (cr);
|
add_path_line (cr, x + width - 1, y + 1, x + width - 1, y + height - 1);
|
||||||
|
cairo_stroke (cr);
|
||||||
|
|
||||||
|
break;
|
||||||
|
case GTK_POS_LEFT:
|
||||||
|
gdk_cairo_set_source_color (cr, bg_color);
|
||||||
|
cairo_rectangle (cr, x, y + 1, width, height - 2);
|
||||||
|
cairo_fill (cr);
|
||||||
|
|
||||||
|
gdk_cairo_set_source_color (cr, &lighter);
|
||||||
|
add_path_line (cr, x, y, x + width - 2, y);
|
||||||
|
cairo_stroke (cr);
|
||||||
|
|
||||||
|
gdk_cairo_set_source_color (cr, bg_color);
|
||||||
|
add_path_line (cr, x + 1, y + 1, x + width - 2, y + 1);
|
||||||
|
cairo_stroke (cr);
|
||||||
|
|
||||||
|
gdk_cairo_set_source_color (cr, &darker);
|
||||||
|
add_path_line (cr, x, y + height - 2, x + width - 2, y + height - 2);
|
||||||
|
add_path_line (cr, x + width - 2, y + 2, x + width - 2, y + height - 2);
|
||||||
|
cairo_stroke (cr);
|
||||||
|
|
||||||
|
cairo_set_source_rgb (cr, 0, 0, 0);
|
||||||
|
add_path_line (cr, x, y + height - 1, x + width - 2, y + height - 1);
|
||||||
|
add_path_line (cr, x + width - 1, y + 1, x + width - 1, y + height - 2);
|
||||||
|
cairo_stroke (cr);
|
||||||
|
|
||||||
|
break;
|
||||||
|
case GTK_POS_RIGHT:
|
||||||
|
gdk_cairo_set_source_color (cr, bg_color);
|
||||||
|
cairo_rectangle (cr, x, y + 1, width, height - 2);
|
||||||
|
cairo_fill (cr);
|
||||||
|
|
||||||
|
gdk_cairo_set_source_color (cr, &lighter);
|
||||||
|
add_path_line (cr, x + 1, y, x + width - 1, y);
|
||||||
|
add_path_line (cr, x, y + 1, x, y + height - 2);
|
||||||
|
cairo_stroke (cr);
|
||||||
|
|
||||||
|
gdk_cairo_set_source_color (cr, bg_color);
|
||||||
|
add_path_line (cr, x + 1, y + 1, x + width - 1, y + 1);
|
||||||
|
add_path_line (cr, x + 1, y + 1, x + 1, y + height - 2);
|
||||||
|
cairo_stroke (cr);
|
||||||
|
|
||||||
|
gdk_cairo_set_source_color (cr, &darker);
|
||||||
|
add_path_line (cr, x + 2, y + height - 2, x + width - 1, y + height - 2);
|
||||||
|
cairo_stroke (cr);
|
||||||
|
|
||||||
|
cairo_set_source_rgb (cr, 0, 0, 0);
|
||||||
|
add_path_line (cr, x + 1, y + height - 1, x + width - 1, y + height - 1);
|
||||||
|
cairo_stroke (cr);
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
cairo_restore (cr);
|
cairo_restore (cr);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user