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);