[glade] Draw animated dash line in round nodes too.
- From: Juan Pablo Ugarte <jpu src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [glade] Draw animated dash line in round nodes too.
- Date: Thu, 6 Oct 2011 19:28:17 +0000 (UTC)
commit 35a4cdb65a772584b8c0e9d80f26cd0995f6a049
Author: Juan Pablo Ugarte <juanpablougarte gmail com>
Date: Fri May 27 19:31:11 2011 -0300
Draw animated dash line in round nodes too.
gladeui/glade-design-layout.c | 59 +++++++++++++++++++++++++++++-----------
1 files changed, 43 insertions(+), 16 deletions(-)
---
diff --git a/gladeui/glade-design-layout.c b/gladeui/glade-design-layout.c
index ea61459..8d446f1 100644
--- a/gladeui/glade-design-layout.c
+++ b/gladeui/glade-design-layout.c
@@ -596,6 +596,14 @@ gdl_margins_set_selection (GladeDesignLayoutPrivate *priv, GtkWidget *selection)
}
}
+static inline void
+window_invalidate_rect (GdkWindow *window, GdkRectangle *rect, gint x, gint y)
+{
+ rect->x = x;
+ rect->y = y;
+ gdk_window_invalidate_rect (window, rect, FALSE);
+}
+
static gboolean
on_edit_alignment_timeout (gpointer data)
{
@@ -605,7 +613,8 @@ on_edit_alignment_timeout (gpointer data)
if (priv->activity == ACTIVITY_EDIT_ALIGNMENT)
{
GtkWidget *selection = priv->selection;
- gdouble x1, x3, y1, y3;
+ GdkWindow *window = priv->window;
+ gdouble x1, x2, x3, y1, y2, y3;
GtkAllocation alloc;
GdkRectangle rect;
gint x, y, w, h;
@@ -619,27 +628,24 @@ on_edit_alignment_timeout (gpointer data)
gtk_widget_translate_coordinates (selection, widget, 0, 0, &x, &y);
x1 = x - gtk_widget_get_margin_left (selection) - 7;
+ x2 = x + w/2 - 7;
x3 = x + w + gtk_widget_get_margin_right (selection) - 7;
y1 = y - gtk_widget_get_margin_top (selection) - 7;
+ y2 = y + h/2 - 7;
y3 = y + h + gtk_widget_get_margin_bottom (selection) - 7;
rect.width = rect.height = 14;
- rect.x = x1; rect.y = y1;
- gdk_window_invalidate_rect (priv->window, &rect, FALSE);
-
- rect.x = x3; rect.y = y1;
- gdk_window_invalidate_rect (priv->window, &rect, FALSE);
+ window_invalidate_rect (window, &rect, x1, y1);
+ window_invalidate_rect (window, &rect, x1, y2);
+ window_invalidate_rect (window, &rect, x1, y3);
+ window_invalidate_rect (window, &rect, x2, y1);
+ window_invalidate_rect (window, &rect, x2, y2);
+ window_invalidate_rect (window, &rect, x2, y3);
+ window_invalidate_rect (window, &rect, x3, y1);
+ window_invalidate_rect (window, &rect, x3, y2);
+ window_invalidate_rect (window, &rect, x3, y3);
- rect.x = x1; rect.y = y3;
- gdk_window_invalidate_rect (priv->window, &rect, FALSE);
-
- rect.x = x3; rect.y = y3;
- gdk_window_invalidate_rect (priv->window, &rect, FALSE);
-
- rect.x = x + w/2 - 7; rect.y = y + h/2 - 7;
- gdk_window_invalidate_rect (priv->window, &rect, FALSE);
-
priv->align_dash_start++;
if (priv->align_dash_start > 4) priv->align_dash_start = 0;
@@ -1461,7 +1467,7 @@ draw_selection_nodes (cairo_t *cr,
{
gdouble dashes[] = { 3, 2 };
- cairo_translate (cr, -6.5, -6.5);
+ cairo_translate (cr, -5.5, -5.5);
if (!(align & MARGIN_TOP && align & MARGIN_LEFT))
cairo_rectangle (cr, x1, y1, 12, 12);
@@ -1479,6 +1485,27 @@ draw_selection_nodes (cairo_t *cr,
cairo_translate (cr, 5.5, 5.5);
+ if (align != MARGIN_TOP)
+ {
+ cairo_new_sub_path (cr);
+ cairo_arc (cr, x2, y1, 7, 0, 2*G_PI);
+ }
+ if (align != MARGIN_BOTTOM)
+ {
+ cairo_new_sub_path (cr);
+ cairo_arc (cr, x2, y3, 7, 0, 2*G_PI);
+ }
+ if (align != MARGIN_LEFT)
+ {
+ cairo_new_sub_path (cr);
+ cairo_arc (cr, x1, y2, 7, 0, 2*G_PI);
+ }
+ if (align != MARGIN_RIGHT)
+ {
+ cairo_new_sub_path (cr);
+ cairo_arc (cr, x3, y2, 7, 0, 2*G_PI);
+ }
+
cairo_set_line_join (cr, CAIRO_LINE_JOIN_MITER);
cairo_set_line_cap (cr, CAIRO_LINE_CAP_BUTT);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]