[gtk+/gtk-style-context: 126/540] GtkThemingEngine: Add cairo-ified rendering primitives.
- From: Carlos Garnacho <carlosg src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/gtk-style-context: 126/540] GtkThemingEngine: Add cairo-ified rendering primitives.
- Date: Fri, 3 Dec 2010 02:46:39 +0000 (UTC)
commit 1250391f79973436fd619232ed2337724f84d058
Author: Carlos Garnacho <carlosg gnome org>
Date: Mon Jul 19 11:51:17 2010 +0200
GtkThemingEngine: Add cairo-ified rendering primitives.
Functions to add paths for lines, rectangle sides, and the gap side in notebooks
have been added.
gtk/gtkthemingengine.c | 192 ++++++++++++++---------------------------------
1 files changed, 57 insertions(+), 135 deletions(-)
---
diff --git a/gtk/gtkthemingengine.c b/gtk/gtkthemingengine.c
index c6ec3b0..a581029 100644
--- a/gtk/gtkthemingengine.c
+++ b/gtk/gtkthemingengine.c
@@ -709,131 +709,66 @@ gtk_theming_engine_render_arrow (GtkThemingEngine *engine,
}
static void
-add_path_rounded_rectangle (cairo_t *cr,
- gdouble radius,
- guint sides,
- gdouble x,
- gdouble y,
- gdouble width,
- gdouble height)
+add_path_line (cairo_t *cr,
+ gdouble x1,
+ gdouble y1,
+ gdouble x2,
+ gdouble y2)
{
- gdouble r = 0;
+ /* Adjust endpoints */
+ if (y1 == y2)
+ {
+ y1 += 0.5;
+ y2 += 0.5;
+ x2 += 1;
+ }
+ else if (x1 == x2)
+ {
+ x1 += 0.5;
+ x2 += 0.5;
+ y2 += 1;
+ }
- if (sides & SIDE_BOTTOM)
+ cairo_move_to (cr, x1, y1);
+ cairo_line_to (cr, x2, y2);
+}
+
+static void
+add_path_rectangle_sides (cairo_t *cr,
+ gdouble x,
+ gdouble y,
+ gdouble width,
+ gdouble height,
+ guint sides)
+{
+ if (sides & SIDE_TOP)
{
- /* Bottom left corner */
- if (r == 0)
- cairo_move_to (cr, x + 0.5, y + height - 0.5);
- else
- cairo_arc_negative (cr,
- x + r + 0.5,
- y + height - r - 0.5,
- r,
- 135 * (G_PI / 180),
- 90 * (G_PI / 180));
-
- /* Bottom side */
- cairo_line_to (cr, x + width - r - 0.5, y + height - 0.5);
-
- /* Bottom right corner */
- if (r > 0)
- cairo_arc_negative (cr,
- x + width - r - 0.5,
- y + height - r - 0.5,
- r,
- 90 * (G_PI / 180),
- 45 * (G_PI / 180));
+ cairo_move_to (cr, x, y + 0.5);
+ cairo_line_to (cr, x + width, y + 0.5);
}
if (sides & SIDE_RIGHT)
{
- /* Bottom right corner */
- if (r == 0)
- {
- if ((sides & SIDE_BOTTOM) == 0)
- cairo_move_to (cr, x + width - 0.5, y + height - 0.5);
- }
- else
- cairo_arc_negative (cr,
- x + width - r - 0.5,
- y + height - r - 0.5,
- r,
- 45 * (G_PI / 180), 0);
-
- /* Right side */
- cairo_line_to (cr, x + width - 0.5, y + r);
-
- /* Top right corner */
- if (r > 0)
- cairo_arc_negative (cr,
- x + width - r - 0.5,
- y + r + 0.5,
- r,
- 0, 315 * (G_PI / 180));
+ cairo_move_to (cr, x + width - 0.5, y);
+ cairo_line_to (cr, x + width - 0.5, y + height);
}
- if (sides & SIDE_TOP)
+ if (sides & SIDE_BOTTOM)
{
- /* Top right corner */
- if (r == 0)
- {
- if ((sides & SIDE_RIGHT) == 0)
- cairo_move_to (cr, x + width - 1, y + 0.5);
- }
- else
- cairo_arc_negative (cr,
- x + width - r - 0.5,
- y + r + 0.5,
- r,
- 315 * (G_PI / 180),
- 270 * (G_PI / 180));
-
- /* Top side */
- cairo_line_to (cr, x + 0.5 + r, y + 0.5);
-
- /* Top left corner */
- if (r > 0)
- cairo_arc_negative (cr,
- x + r + 0.5,
- y + r + 0.5,
- r,
- 270 * (G_PI / 180),
- 225 * (G_PI / 180));
+ cairo_move_to (cr, x, y + height - 0.5);
+ cairo_line_to (cr, x + width, y + height - 0.5);
}
if (sides & SIDE_LEFT)
{
- /* Top left corner */
- if (r == 0)
- {
- if ((sides & SIDE_TOP) == 0)
- cairo_move_to (cr, x + 0.5, y + 0.5);
- }
- else
- cairo_arc_negative (cr,
- x + + r + 0.5,
- y + r + 0.5,
- r,
- 225 * (G_PI / 180),
- 180 * (G_PI / 180));
-
- /* Left side */
- cairo_line_to (cr, x + 0.5, y + height - r);
-
- if (r > 0)
- cairo_arc_negative (cr,
- x + r + 0.5,
- y + height - r + 0.5,
- r,
- 180 * (G_PI / 180),
- 135 * (G_PI / 180));
+ cairo_move_to (cr, x + 0.5, y + height);
+ cairo_line_to (cr, x + 0.5, y);
}
}
static void
add_path_gap_side (cairo_t *cr,
GtkPositionType gap_side,
- gdouble radius,
gdouble x,
gdouble y,
gdouble width,
@@ -841,37 +776,24 @@ add_path_gap_side (cairo_t *cr,
gdouble xy0_gap,
gdouble xy1_gap)
{
- if (gap_side == GTK_POS_TOP)
+ switch (gap_side)
{
- cairo_move_to (cr, x, y);
- cairo_line_to (cr, x + xy0_gap, y);
-
- cairo_move_to (cr, x + xy1_gap, y);
- cairo_line_to (cr, x + width, y);
- }
- else if (gap_side == GTK_POS_BOTTOM)
- {
- cairo_move_to (cr, x, y + height);
- cairo_line_to (cr, x + xy0_gap, y + height);
-
- cairo_move_to (cr, x + xy1_gap, y + height);
- cairo_line_to (cr, x + width, y + height);
- }
- else if (gap_side == GTK_POS_LEFT)
- {
- cairo_move_to (cr, x, y);
- cairo_line_to (cr, x, y + xy0_gap);
-
- cairo_move_to (cr, x, y + xy1_gap);
- cairo_line_to (cr, x, y + height);
- }
- else
- {
- cairo_move_to (cr, x + width, y);
- cairo_line_to (cr, x + width, y + xy0_gap);
-
- cairo_move_to (cr, x + width, y + xy1_gap);
- cairo_line_to (cr, x + width, y + height);
+ case GTK_POS_TOP:
+ add_path_line (cr, x, y, x + xy0_gap, y);
+ add_path_line (cr, x + xy1_gap, y, x + width, y);
+ break;
+ case GTK_POS_BOTTOM:
+ add_path_line (cr, x, y + height, x + xy0_gap, y + height);
+ add_path_line (cr, x + xy1_gap, y + height, x + width, y + height);
+ break;
+ case GTK_POS_LEFT:
+ add_path_line (cr, x, y, x, y + xy0_gap);
+ add_path_line (cr, x, y + xy1_gap, x, y + height);
+ break;
+ case GTK_POS_RIGHT:
+ add_path_line (cr, x + width, y, x + width, y + xy0_gap);
+ add_path_line (cr, x + width, y + xy1_gap, x + width, y + height);
+ break;
}
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]