X-Git-Url: http://pileus.org/git/?a=blobdiff_plain;f=gtk%2Fgtkroundedbox.c;h=653d27feefaa2008e2f0a5a1dac8171d3cfadad8;hb=d84f5ae17e5b891b30dd54ddc10fd22c2a609e0e;hp=41b76f56fb64842705a7cece0a99339315edf1e6;hpb=fdb3abefc374a80648c9019894d7edc9e86182b3;p=~andy%2Fgtk
diff --git a/gtk/gtkroundedbox.c b/gtk/gtkroundedbox.c
index 41b76f56f..653d27fee 100644
--- a/gtk/gtkroundedbox.c
+++ b/gtk/gtkroundedbox.c
@@ -12,15 +12,18 @@
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the
- * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- * Boston, MA 02111-1307, USA.
+ * License along with this library. If not, see .
*/
#include "config.h"
#include "gtkroundedboxprivate.h"
+#include "gtkcsscornervalueprivate.h"
+#include "gtkcsstypesprivate.h"
+#include "gtkstylecontextprivate.h"
+#include "gtkthemingengineprivate.h"
+
#include
/**
@@ -56,64 +59,89 @@ gtk_rounded_box_clamp_border_radius (GtkRoundedBox *box)
gdouble factor = 1.0;
/* note: division by zero leads to +INF, which is > factor, so will be ignored */
- factor = MIN (factor, box->box.width / (box->top_left.horizontal +
- box->top_right.horizontal));
- factor = MIN (factor, box->box.height / (box->top_right.vertical +
- box->bottom_right.vertical));
- factor = MIN (factor, box->box.width / (box->bottom_right.horizontal +
- box->bottom_left.horizontal));
- factor = MIN (factor, box->box.height / (box->top_left.vertical +
- box->bottom_left.vertical));
-
- box->top_left.horizontal *= factor;
- box->top_left.vertical *= factor;
- box->top_right.horizontal *= factor;
- box->top_right.vertical *= factor;
- box->bottom_right.horizontal *= factor;
- box->bottom_right.vertical *= factor;
- box->bottom_left.horizontal *= factor;
- box->bottom_left.vertical *= factor;
+ factor = MIN (factor, box->box.width / (box->corner[GTK_CSS_TOP_LEFT].horizontal +
+ box->corner[GTK_CSS_TOP_RIGHT].horizontal));
+ factor = MIN (factor, box->box.height / (box->corner[GTK_CSS_TOP_RIGHT].vertical +
+ box->corner[GTK_CSS_BOTTOM_RIGHT].vertical));
+ factor = MIN (factor, box->box.width / (box->corner[GTK_CSS_BOTTOM_RIGHT].horizontal +
+ box->corner[GTK_CSS_BOTTOM_LEFT].horizontal));
+ factor = MIN (factor, box->box.height / (box->corner[GTK_CSS_TOP_LEFT].vertical +
+ box->corner[GTK_CSS_BOTTOM_LEFT].vertical));
+
+ box->corner[GTK_CSS_TOP_LEFT].horizontal *= factor;
+ box->corner[GTK_CSS_TOP_LEFT].vertical *= factor;
+ box->corner[GTK_CSS_TOP_RIGHT].horizontal *= factor;
+ box->corner[GTK_CSS_TOP_RIGHT].vertical *= factor;
+ box->corner[GTK_CSS_BOTTOM_RIGHT].horizontal *= factor;
+ box->corner[GTK_CSS_BOTTOM_RIGHT].vertical *= factor;
+ box->corner[GTK_CSS_BOTTOM_LEFT].horizontal *= factor;
+ box->corner[GTK_CSS_BOTTOM_LEFT].vertical *= factor;
}
-void
-_gtk_rounded_box_apply_border_radius (GtkRoundedBox *box,
- GtkThemingEngine *engine,
- GtkStateFlags state,
- GtkJunctionSides junction)
+static void
+_gtk_rounded_box_apply_border_radius (GtkRoundedBox *box,
+ GtkCssValue **corner,
+ GtkJunctionSides junction)
{
- GtkCssBorderCornerRadius *top_left_radius, *top_right_radius;
- GtkCssBorderCornerRadius *bottom_left_radius, *bottom_right_radius;
-
- gtk_theming_engine_get (engine, state,
- /* Can't use border-radius as it's an int for
- * backwards compat */
- "border-top-left-radius", &top_left_radius,
- "border-top-right-radius", &top_right_radius,
- "border-bottom-right-radius", &bottom_right_radius,
- "border-bottom-left-radius", &bottom_left_radius,
- NULL);
-
- if (top_left_radius && (junction & GTK_JUNCTION_CORNER_TOPLEFT) == 0)
- box->top_left = *top_left_radius;
- if (top_right_radius && (junction & GTK_JUNCTION_CORNER_TOPRIGHT) == 0)
- box->top_right = *top_right_radius;
- if (bottom_right_radius && (junction & GTK_JUNCTION_CORNER_BOTTOMRIGHT) == 0)
- box->bottom_right = *bottom_right_radius;
- if (bottom_left_radius && (junction & GTK_JUNCTION_CORNER_BOTTOMLEFT) == 0)
- box->bottom_left = *bottom_left_radius;
+ if (corner[GTK_CSS_TOP_LEFT] && (junction & GTK_JUNCTION_CORNER_TOPLEFT) == 0)
+ {
+ box->corner[GTK_CSS_TOP_LEFT].horizontal = _gtk_css_corner_value_get_x (corner[GTK_CSS_TOP_LEFT],
+ box->box.width);
+ box->corner[GTK_CSS_TOP_LEFT].vertical = _gtk_css_corner_value_get_y (corner[GTK_CSS_TOP_LEFT],
+ box->box.height);
+ }
+ if (corner[GTK_CSS_TOP_RIGHT] && (junction & GTK_JUNCTION_CORNER_TOPRIGHT) == 0)
+ {
+ box->corner[GTK_CSS_TOP_RIGHT].horizontal = _gtk_css_corner_value_get_x (corner[GTK_CSS_TOP_RIGHT],
+ box->box.width);
+ box->corner[GTK_CSS_TOP_RIGHT].vertical = _gtk_css_corner_value_get_y (corner[GTK_CSS_TOP_RIGHT],
+ box->box.height);
+ }
+ if (corner[GTK_CSS_BOTTOM_RIGHT] && (junction & GTK_JUNCTION_CORNER_BOTTOMRIGHT) == 0)
+ {
+ box->corner[GTK_CSS_BOTTOM_RIGHT].horizontal = _gtk_css_corner_value_get_x (corner[GTK_CSS_BOTTOM_RIGHT],
+ box->box.width);
+ box->corner[GTK_CSS_BOTTOM_RIGHT].vertical = _gtk_css_corner_value_get_y (corner[GTK_CSS_BOTTOM_RIGHT],
+ box->box.height);
+ }
+ if (corner[GTK_CSS_BOTTOM_LEFT] && (junction & GTK_JUNCTION_CORNER_BOTTOMLEFT) == 0)
+ {
+ box->corner[GTK_CSS_BOTTOM_LEFT].horizontal = _gtk_css_corner_value_get_x (corner[GTK_CSS_BOTTOM_LEFT],
+ box->box.width);
+ box->corner[GTK_CSS_BOTTOM_LEFT].vertical = _gtk_css_corner_value_get_y (corner[GTK_CSS_BOTTOM_LEFT],
+ box->box.height);
+ }
gtk_rounded_box_clamp_border_radius (box);
+}
+
+void
+_gtk_rounded_box_apply_border_radius_for_context (GtkRoundedBox *box,
+ GtkStyleContext *context,
+ GtkJunctionSides junction)
+{
+ GtkCssValue *corner[4];
- g_free (top_left_radius);
- g_free (top_right_radius);
- g_free (bottom_right_radius);
- g_free (bottom_left_radius);
+ corner[GTK_CSS_TOP_LEFT] = _gtk_style_context_peek_property (context, GTK_CSS_PROPERTY_BORDER_TOP_LEFT_RADIUS);
+ corner[GTK_CSS_TOP_RIGHT] = _gtk_style_context_peek_property (context, GTK_CSS_PROPERTY_BORDER_TOP_RIGHT_RADIUS);
+ corner[GTK_CSS_BOTTOM_LEFT] = _gtk_style_context_peek_property (context, GTK_CSS_PROPERTY_BORDER_BOTTOM_LEFT_RADIUS);
+ corner[GTK_CSS_BOTTOM_RIGHT] = _gtk_style_context_peek_property (context, GTK_CSS_PROPERTY_BORDER_BOTTOM_RIGHT_RADIUS);
+
+ _gtk_rounded_box_apply_border_radius (box, corner, junction);
+}
+
+void
+_gtk_rounded_box_apply_border_radius_for_engine (GtkRoundedBox *box,
+ GtkThemingEngine *engine,
+ GtkJunctionSides junction)
+{
+ _gtk_rounded_box_apply_border_radius_for_context (box, _gtk_theming_engine_get_context (engine), junction);
}
static void
-gtk_css_border_radius_grow (GtkCssBorderCornerRadius *corner,
- double horizontal,
- double vertical)
+gtk_css_border_radius_grow (GtkRoundedBoxCorner *corner,
+ double horizontal,
+ double vertical)
{
corner->horizontal += horizontal;
corner->vertical += vertical;
@@ -124,6 +152,7 @@ gtk_css_border_radius_grow (GtkCssBorderCornerRadius *corner,
corner->vertical = 0;
}
}
+
void
_gtk_rounded_box_grow (GtkRoundedBox *box,
double top,
@@ -142,7 +171,7 @@ _gtk_rounded_box_grow (GtkRoundedBox *box,
box->box.width += left + right;
}
- if (box->box.height + bottom + right < 0)
+ if (box->box.height + bottom + top < 0)
{
box->box.y -= top * box->box.height / (top + bottom);
box->box.height = 0;
@@ -153,10 +182,10 @@ _gtk_rounded_box_grow (GtkRoundedBox *box,
box->box.height += top + bottom;
}
- gtk_css_border_radius_grow (&box->top_left, left, top);
- gtk_css_border_radius_grow (&box->top_right, right, bottom);
- gtk_css_border_radius_grow (&box->bottom_right, right, top);
- gtk_css_border_radius_grow (&box->bottom_left, left, bottom);
+ gtk_css_border_radius_grow (&box->corner[GTK_CSS_TOP_LEFT], left, top);
+ gtk_css_border_radius_grow (&box->corner[GTK_CSS_TOP_RIGHT], right, bottom);
+ gtk_css_border_radius_grow (&box->corner[GTK_CSS_BOTTOM_RIGHT], right, top);
+ gtk_css_border_radius_grow (&box->corner[GTK_CSS_BOTTOM_LEFT], left, bottom);
}
void
@@ -223,29 +252,127 @@ _gtk_rounded_box_path (const GtkRoundedBox *box,
cairo_new_sub_path (cr);
_cairo_ellipsis (cr,
- box->box.x + box->top_left.horizontal,
- box->box.y + box->top_left.vertical,
- box->top_left.horizontal,
- box->top_left.vertical,
+ box->box.x + box->corner[GTK_CSS_TOP_LEFT].horizontal,
+ box->box.y + box->corner[GTK_CSS_TOP_LEFT].vertical,
+ box->corner[GTK_CSS_TOP_LEFT].horizontal,
+ box->corner[GTK_CSS_TOP_LEFT].vertical,
G_PI, 3 * G_PI / 2);
_cairo_ellipsis (cr,
- box->box.x + box->box.width - box->top_right.horizontal,
- box->box.y + box->top_right.vertical,
- box->top_right.horizontal,
- box->top_right.vertical,
+ box->box.x + box->box.width - box->corner[GTK_CSS_TOP_RIGHT].horizontal,
+ box->box.y + box->corner[GTK_CSS_TOP_RIGHT].vertical,
+ box->corner[GTK_CSS_TOP_RIGHT].horizontal,
+ box->corner[GTK_CSS_TOP_RIGHT].vertical,
- G_PI / 2, 0);
_cairo_ellipsis (cr,
- box->box.x + box->box.width - box->bottom_right.horizontal,
- box->box.y + box->box.height - box->bottom_right.vertical,
- box->bottom_right.horizontal,
- box->bottom_right.vertical,
+ box->box.x + box->box.width - box->corner[GTK_CSS_BOTTOM_RIGHT].horizontal,
+ box->box.y + box->box.height - box->corner[GTK_CSS_BOTTOM_RIGHT].vertical,
+ box->corner[GTK_CSS_BOTTOM_RIGHT].horizontal,
+ box->corner[GTK_CSS_BOTTOM_RIGHT].vertical,
0, G_PI / 2);
_cairo_ellipsis (cr,
- box->box.x + box->bottom_left.horizontal,
- box->box.y + box->box.height - box->bottom_left.vertical,
- box->bottom_left.horizontal,
- box->bottom_left.vertical,
+ box->box.x + box->corner[GTK_CSS_BOTTOM_LEFT].horizontal,
+ box->box.y + box->box.height - box->corner[GTK_CSS_BOTTOM_LEFT].vertical,
+ box->corner[GTK_CSS_BOTTOM_LEFT].horizontal,
+ box->corner[GTK_CSS_BOTTOM_LEFT].vertical,
G_PI / 2, G_PI);
+
+ cairo_close_path (cr);
+}
+
+double
+_gtk_rounded_box_guess_length (const GtkRoundedBox *box,
+ GtkCssSide side)
+{
+ double length;
+ GtkCssSide before, after;
+
+ before = side;
+ after = (side + 1) % 4;
+
+ if (side & 1)
+ length = box->box.height
+ - box->corner[before].vertical
+ - box->corner[after].vertical;
+ else
+ length = box->box.width
+ - box->corner[before].horizontal
+ - box->corner[after].horizontal;
+
+ length += G_PI * 0.125 * (box->corner[before].horizontal
+ + box->corner[before].vertical
+ + box->corner[after].horizontal
+ + box->corner[after].vertical);
+
+ return length;
+}
+
+void
+_gtk_rounded_box_path_side (const GtkRoundedBox *box,
+ cairo_t *cr,
+ GtkCssSide side)
+{
+ switch (side)
+ {
+ case GTK_CSS_TOP:
+ _cairo_ellipsis (cr,
+ box->box.x + box->corner[GTK_CSS_TOP_LEFT].horizontal,
+ box->box.y + box->corner[GTK_CSS_TOP_LEFT].vertical,
+ box->corner[GTK_CSS_TOP_LEFT].horizontal,
+ box->corner[GTK_CSS_TOP_LEFT].vertical,
+ 5 * G_PI / 4, 3 * G_PI / 2);
+ _cairo_ellipsis (cr,
+ box->box.x + box->box.width - box->corner[GTK_CSS_TOP_RIGHT].horizontal,
+ box->box.y + box->corner[GTK_CSS_TOP_RIGHT].vertical,
+ box->corner[GTK_CSS_TOP_RIGHT].horizontal,
+ box->corner[GTK_CSS_TOP_RIGHT].vertical,
+ - G_PI / 2, -G_PI / 4);
+ break;
+ case GTK_CSS_RIGHT:
+ _cairo_ellipsis (cr,
+ box->box.x + box->box.width - box->corner[GTK_CSS_TOP_RIGHT].horizontal,
+ box->box.y + box->corner[GTK_CSS_TOP_RIGHT].vertical,
+ box->corner[GTK_CSS_TOP_RIGHT].horizontal,
+ box->corner[GTK_CSS_TOP_RIGHT].vertical,
+ - G_PI / 4, 0);
+ _cairo_ellipsis (cr,
+ box->box.x + box->box.width - box->corner[GTK_CSS_BOTTOM_RIGHT].horizontal,
+ box->box.y + box->box.height - box->corner[GTK_CSS_BOTTOM_RIGHT].vertical,
+ box->corner[GTK_CSS_BOTTOM_RIGHT].horizontal,
+ box->corner[GTK_CSS_BOTTOM_RIGHT].vertical,
+ 0, G_PI / 4);
+ break;
+ case GTK_CSS_BOTTOM:
+ _cairo_ellipsis (cr,
+ box->box.x + box->box.width - box->corner[GTK_CSS_BOTTOM_RIGHT].horizontal,
+ box->box.y + box->box.height - box->corner[GTK_CSS_BOTTOM_RIGHT].vertical,
+ box->corner[GTK_CSS_BOTTOM_RIGHT].horizontal,
+ box->corner[GTK_CSS_BOTTOM_RIGHT].vertical,
+ G_PI / 4, G_PI / 2);
+ _cairo_ellipsis (cr,
+ box->box.x + box->corner[GTK_CSS_BOTTOM_LEFT].horizontal,
+ box->box.y + box->box.height - box->corner[GTK_CSS_BOTTOM_LEFT].vertical,
+ box->corner[GTK_CSS_BOTTOM_LEFT].horizontal,
+ box->corner[GTK_CSS_BOTTOM_LEFT].vertical,
+ G_PI / 2, 3 * G_PI / 4);
+ break;
+ case GTK_CSS_LEFT:
+ _cairo_ellipsis (cr,
+ box->box.x + box->corner[GTK_CSS_BOTTOM_LEFT].horizontal,
+ box->box.y + box->box.height - box->corner[GTK_CSS_BOTTOM_LEFT].vertical,
+ box->corner[GTK_CSS_BOTTOM_LEFT].horizontal,
+ box->corner[GTK_CSS_BOTTOM_LEFT].vertical,
+ 3 * G_PI / 4, G_PI);
+ _cairo_ellipsis (cr,
+ box->box.x + box->corner[GTK_CSS_TOP_LEFT].horizontal,
+ box->box.y + box->corner[GTK_CSS_TOP_LEFT].vertical,
+ box->corner[GTK_CSS_TOP_LEFT].horizontal,
+ box->corner[GTK_CSS_TOP_LEFT].vertical,
+ G_PI, 5 * G_PI / 4);
+ break;
+ default:
+ g_assert_not_reached ();
+ break;
+ }
}
void
@@ -256,29 +383,29 @@ _gtk_rounded_box_path_top (const GtkRoundedBox *outer,
cairo_new_sub_path (cr);
_cairo_ellipsis (cr,
- outer->box.x + outer->top_left.horizontal,
- outer->box.y + outer->top_left.vertical,
- outer->top_left.horizontal,
- outer->top_left.vertical,
+ outer->box.x + outer->corner[GTK_CSS_TOP_LEFT].horizontal,
+ outer->box.y + outer->corner[GTK_CSS_TOP_LEFT].vertical,
+ outer->corner[GTK_CSS_TOP_LEFT].horizontal,
+ outer->corner[GTK_CSS_TOP_LEFT].vertical,
5 * G_PI / 4, 3 * G_PI / 2);
_cairo_ellipsis (cr,
- outer->box.x + outer->box.width - outer->top_right.horizontal,
- outer->box.y + outer->top_right.vertical,
- outer->top_right.horizontal,
- outer->top_right.vertical,
+ outer->box.x + outer->box.width - outer->corner[GTK_CSS_TOP_RIGHT].horizontal,
+ outer->box.y + outer->corner[GTK_CSS_TOP_RIGHT].vertical,
+ outer->corner[GTK_CSS_TOP_RIGHT].horizontal,
+ outer->corner[GTK_CSS_TOP_RIGHT].vertical,
- G_PI / 2, -G_PI / 4);
_cairo_ellipsis_negative (cr,
- inner->box.x + inner->box.width - inner->top_right.horizontal,
- inner->box.y + inner->top_right.vertical,
- inner->top_right.horizontal,
- inner->top_right.vertical,
+ inner->box.x + inner->box.width - inner->corner[GTK_CSS_TOP_RIGHT].horizontal,
+ inner->box.y + inner->corner[GTK_CSS_TOP_RIGHT].vertical,
+ inner->corner[GTK_CSS_TOP_RIGHT].horizontal,
+ inner->corner[GTK_CSS_TOP_RIGHT].vertical,
-G_PI / 4, - G_PI / 2);
_cairo_ellipsis_negative (cr,
- inner->box.x + inner->top_left.horizontal,
- inner->box.y + inner->top_left.vertical,
- inner->top_left.horizontal,
- inner->top_left.vertical,
+ inner->box.x + inner->corner[GTK_CSS_TOP_LEFT].horizontal,
+ inner->box.y + inner->corner[GTK_CSS_TOP_LEFT].vertical,
+ inner->corner[GTK_CSS_TOP_LEFT].horizontal,
+ inner->corner[GTK_CSS_TOP_LEFT].vertical,
3 * G_PI / 2, 5 * G_PI / 4);
cairo_close_path (cr);
@@ -292,29 +419,29 @@ _gtk_rounded_box_path_right (const GtkRoundedBox *outer,
cairo_new_sub_path (cr);
_cairo_ellipsis (cr,
- outer->box.x + outer->box.width - outer->top_right.horizontal,
- outer->box.y + outer->top_right.vertical,
- outer->top_right.horizontal,
- outer->top_right.vertical,
+ outer->box.x + outer->box.width - outer->corner[GTK_CSS_TOP_RIGHT].horizontal,
+ outer->box.y + outer->corner[GTK_CSS_TOP_RIGHT].vertical,
+ outer->corner[GTK_CSS_TOP_RIGHT].horizontal,
+ outer->corner[GTK_CSS_TOP_RIGHT].vertical,
- G_PI / 4, 0);
_cairo_ellipsis (cr,
- outer->box.x + outer->box.width - outer->bottom_right.horizontal,
- outer->box.y + outer->box.height - outer->bottom_right.vertical,
- outer->bottom_right.horizontal,
- outer->bottom_right.vertical,
+ outer->box.x + outer->box.width - outer->corner[GTK_CSS_BOTTOM_RIGHT].horizontal,
+ outer->box.y + outer->box.height - outer->corner[GTK_CSS_BOTTOM_RIGHT].vertical,
+ outer->corner[GTK_CSS_BOTTOM_RIGHT].horizontal,
+ outer->corner[GTK_CSS_BOTTOM_RIGHT].vertical,
0, G_PI / 4);
_cairo_ellipsis_negative (cr,
- inner->box.x + inner->box.width - inner->bottom_right.horizontal,
- inner->box.y + inner->box.height - inner->bottom_right.vertical,
- inner->bottom_right.horizontal,
- inner->bottom_right.vertical,
+ inner->box.x + inner->box.width - inner->corner[GTK_CSS_BOTTOM_RIGHT].horizontal,
+ inner->box.y + inner->box.height - inner->corner[GTK_CSS_BOTTOM_RIGHT].vertical,
+ inner->corner[GTK_CSS_BOTTOM_RIGHT].horizontal,
+ inner->corner[GTK_CSS_BOTTOM_RIGHT].vertical,
G_PI / 4, 0);
_cairo_ellipsis_negative (cr,
- inner->box.x + inner->box.width - inner->top_right.horizontal,
- inner->box.y + inner->top_right.vertical,
- inner->top_right.horizontal,
- inner->top_right.vertical,
+ inner->box.x + inner->box.width - inner->corner[GTK_CSS_TOP_RIGHT].horizontal,
+ inner->box.y + inner->corner[GTK_CSS_TOP_RIGHT].vertical,
+ inner->corner[GTK_CSS_TOP_RIGHT].horizontal,
+ inner->corner[GTK_CSS_TOP_RIGHT].vertical,
0, - G_PI / 4);
cairo_close_path (cr);
@@ -328,29 +455,29 @@ _gtk_rounded_box_path_bottom (const GtkRoundedBox *outer,
cairo_new_sub_path (cr);
_cairo_ellipsis (cr,
- outer->box.x + outer->box.width - outer->bottom_right.horizontal,
- outer->box.y + outer->box.height - outer->bottom_right.vertical,
- outer->bottom_right.horizontal,
- outer->bottom_right.vertical,
+ outer->box.x + outer->box.width - outer->corner[GTK_CSS_BOTTOM_RIGHT].horizontal,
+ outer->box.y + outer->box.height - outer->corner[GTK_CSS_BOTTOM_RIGHT].vertical,
+ outer->corner[GTK_CSS_BOTTOM_RIGHT].horizontal,
+ outer->corner[GTK_CSS_BOTTOM_RIGHT].vertical,
G_PI / 4, G_PI / 2);
_cairo_ellipsis (cr,
- outer->box.x + outer->bottom_left.horizontal,
- outer->box.y + outer->box.height - outer->bottom_left.vertical,
- outer->bottom_left.horizontal,
- outer->bottom_left.vertical,
+ outer->box.x + outer->corner[GTK_CSS_BOTTOM_LEFT].horizontal,
+ outer->box.y + outer->box.height - outer->corner[GTK_CSS_BOTTOM_LEFT].vertical,
+ outer->corner[GTK_CSS_BOTTOM_LEFT].horizontal,
+ outer->corner[GTK_CSS_BOTTOM_LEFT].vertical,
G_PI / 2, 3 * G_PI / 4);
_cairo_ellipsis_negative (cr,
- inner->box.x + inner->bottom_left.horizontal,
- inner->box.y + inner->box.height - inner->bottom_left.vertical,
- inner->bottom_left.horizontal,
- inner->bottom_left.vertical,
+ inner->box.x + inner->corner[GTK_CSS_BOTTOM_LEFT].horizontal,
+ inner->box.y + inner->box.height - inner->corner[GTK_CSS_BOTTOM_LEFT].vertical,
+ inner->corner[GTK_CSS_BOTTOM_LEFT].horizontal,
+ inner->corner[GTK_CSS_BOTTOM_LEFT].vertical,
3 * G_PI / 4, G_PI / 2);
_cairo_ellipsis_negative (cr,
- inner->box.x + inner->box.width - inner->bottom_right.horizontal,
- inner->box.y + inner->box.height - inner->bottom_right.vertical,
- inner->bottom_right.horizontal,
- inner->bottom_right.vertical,
+ inner->box.x + inner->box.width - inner->corner[GTK_CSS_BOTTOM_RIGHT].horizontal,
+ inner->box.y + inner->box.height - inner->corner[GTK_CSS_BOTTOM_RIGHT].vertical,
+ inner->corner[GTK_CSS_BOTTOM_RIGHT].horizontal,
+ inner->corner[GTK_CSS_BOTTOM_RIGHT].vertical,
G_PI / 2, G_PI / 4);
cairo_close_path (cr);
@@ -364,29 +491,29 @@ _gtk_rounded_box_path_left (const GtkRoundedBox *outer,
cairo_new_sub_path (cr);
_cairo_ellipsis (cr,
- outer->box.x + outer->bottom_left.horizontal,
- outer->box.y + outer->box.height - outer->bottom_left.vertical,
- outer->bottom_left.horizontal,
- outer->bottom_left.vertical,
+ outer->box.x + outer->corner[GTK_CSS_BOTTOM_LEFT].horizontal,
+ outer->box.y + outer->box.height - outer->corner[GTK_CSS_BOTTOM_LEFT].vertical,
+ outer->corner[GTK_CSS_BOTTOM_LEFT].horizontal,
+ outer->corner[GTK_CSS_BOTTOM_LEFT].vertical,
3 * G_PI / 4, G_PI);
_cairo_ellipsis (cr,
- outer->box.x + outer->top_left.horizontal,
- outer->box.y + outer->top_left.vertical,
- outer->top_left.horizontal,
- outer->top_left.vertical,
+ outer->box.x + outer->corner[GTK_CSS_TOP_LEFT].horizontal,
+ outer->box.y + outer->corner[GTK_CSS_TOP_LEFT].vertical,
+ outer->corner[GTK_CSS_TOP_LEFT].horizontal,
+ outer->corner[GTK_CSS_TOP_LEFT].vertical,
G_PI, 5 * G_PI / 4);
_cairo_ellipsis_negative (cr,
- inner->box.x + inner->top_left.horizontal,
- inner->box.y + inner->top_left.vertical,
- inner->top_left.horizontal,
- inner->top_left.vertical,
+ inner->box.x + inner->corner[GTK_CSS_TOP_LEFT].horizontal,
+ inner->box.y + inner->corner[GTK_CSS_TOP_LEFT].vertical,
+ inner->corner[GTK_CSS_TOP_LEFT].horizontal,
+ inner->corner[GTK_CSS_TOP_LEFT].vertical,
5 * G_PI / 4, G_PI);
_cairo_ellipsis_negative (cr,
- inner->box.x + inner->bottom_left.horizontal,
- inner->box.y + inner->box.height - inner->bottom_left.vertical,
- inner->bottom_left.horizontal,
- inner->bottom_left.vertical,
+ inner->box.x + inner->corner[GTK_CSS_BOTTOM_LEFT].horizontal,
+ inner->box.y + inner->box.height - inner->corner[GTK_CSS_BOTTOM_LEFT].vertical,
+ inner->corner[GTK_CSS_BOTTOM_LEFT].horizontal,
+ inner->corner[GTK_CSS_BOTTOM_LEFT].vertical,
G_PI, 3 * G_PI / 4);
cairo_close_path (cr);