[glade/margins: 15/15] Replaced drag&drop alignment editing by making each node activatable.
- From: Juan Pablo Ugarte <jpu src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [glade/margins: 15/15] Replaced drag&drop alignment editing by making each node activatable.
- Date: Tue, 14 Jun 2011 19:17:48 +0000 (UTC)
commit 2a91390be972f04bad2749829cb71421fb9a3b67
Author: Juan Pablo Ugarte <juanpablougarte gmail com>
Date: Mon Jun 6 19:12:17 2011 -0300
Replaced drag&drop alignment editing by making each node activatable.
gladeui/glade-design-layout.c | 438 +++++++++++++++--------------------------
1 files changed, 157 insertions(+), 281 deletions(-)
---
diff --git a/gladeui/glade-design-layout.c b/gladeui/glade-design-layout.c
index ea61459..05e8f93 100644
--- a/gladeui/glade-design-layout.c
+++ b/gladeui/glade-design-layout.c
@@ -50,7 +50,6 @@ typedef enum
ACTIVITY_RESIZE_WIDTH,
ACTIVITY_RESIZE_HEIGHT,
ACTIVITY_RESIZE_WIDTH_AND_HEIGHT,
- ACTIVITY_EDIT_ALIGNMENT,
ACTIVITY_MARGINS,
ACTIVITY_MARGINS_VERTICAL, /* These activities are only used to set the cursor */
ACTIVITY_MARGINS_HORIZONTAL,
@@ -94,10 +93,8 @@ struct _GladeDesignLayoutPrivate
gint m_dy, m_dx;
gint max_width, max_height;
Margins margin;
- GdkRectangle align_control;
GtkAlign valign, halign;
- Margins current_align_node;
- gint align_dash_start;
+ GtkPositionType node_over;
/* state machine */
Activity activity; /* the current activity */
@@ -161,10 +158,7 @@ gdl_get_activity_from_pointer (GladeDesignLayout *layout, gint x, gint y)
GladeDesignLayoutPrivate *priv = GLADE_DESIGN_LAYOUT_GET_PRIVATE (layout);
if (priv->selection)
- {
- if (RECTANGLE_POINT_IN (priv->align_control, x, y))
- return ACTIVITY_EDIT_ALIGNMENT;
-
+ {
priv->margin = gdl_get_margins_from_pointer (priv->selection,
x - priv->child_offset,
y - priv->child_offset);
@@ -288,71 +282,46 @@ glade_design_layout_update_child (GladeDesignLayout *layout,
gtk_widget_queue_resize (GTK_WIDGET (layout));
}
-static void
-update_align_control_rectangle (GtkWidget *widget,
- GladeDesignLayoutPrivate *priv)
+static GtkPositionType
+gdl_get_node_from_pointer (GtkWidget *widget, gint x, gint y)
{
- gint top, bottom, left, right;
- GtkAlign valign, halign;
GtkAllocation alloc;
+ gint xx, yy;
- gtk_widget_get_allocation (widget, &alloc);
+ if (widget == NULL) return -1;
- top = gtk_widget_get_margin_top (widget);
- bottom = gtk_widget_get_margin_bottom (widget);
- left = gtk_widget_get_margin_left (widget);
- right = gtk_widget_get_margin_right (widget);
- valign = gtk_widget_get_valign (widget);
- halign = gtk_widget_get_halign (widget);
+ gtk_widget_get_allocation (widget, &alloc);
- priv->current_align_node = 0;
- priv->align_control.x = priv->child_offset - OUTLINE_WIDTH;
- priv->align_control.y = priv->child_offset - OUTLINE_WIDTH;
- priv->align_control.width = OUTLINE_WIDTH*2;
- priv->align_control.height = OUTLINE_WIDTH*2;
+ xx = alloc.x + alloc.width/2;
+ yy = alloc.y + alloc.height/2;
- switch (halign)
+ if (ABS (xx - x) < 6)
{
- case GTK_ALIGN_START:
- priv->align_control.x += alloc.x - left;
- priv->current_align_node |= MARGIN_LEFT;
- break;
- case GTK_ALIGN_END:
- priv->align_control.x += alloc.x + alloc.width + right;
- priv->current_align_node |= MARGIN_RIGHT;
- break;
- case GTK_ALIGN_FILL:
- case GTK_ALIGN_CENTER:
- priv->align_control.x += alloc.x + alloc.width/2;
- break;
- }
+ gint y1, y2;
- switch (valign)
- {
- case GTK_ALIGN_START:
- priv->align_control.y += alloc.y - top;
- priv->current_align_node |= MARGIN_TOP;
- break;
- case GTK_ALIGN_END:
- priv->align_control.y += alloc.y + alloc.height + bottom;
- priv->current_align_node |= MARGIN_BOTTOM;
- break;
- case GTK_ALIGN_FILL:
- case GTK_ALIGN_CENTER:
- priv->align_control.y += alloc.y + alloc.height/2;
- break;
+ y1 = alloc.y - gtk_widget_get_margin_top (widget);
+ y2 = alloc.y + alloc.height + gtk_widget_get_margin_bottom (widget);
+
+ if (ABS (y1 - y) < 6)
+ return GTK_POS_TOP;
+ else if (ABS (y2 - y) < 6)
+ return GTK_POS_BOTTOM;
}
-}
+ else if (ABS (yy - y) < 6)
+ {
+ gint x1, x2;
-#define ALIGN_NODE_WIDTH 6
+ x1 = alloc.x - gtk_widget_get_margin_left (widget);
+ x2 = alloc.x + alloc.width + gtk_widget_get_margin_right (widget);
-#define CHECK_X_AXIS_ALIGN(halign,x,alloc,left,right) if (ABS(x - (alloc.x - left)) < ALIGN_NODE_WIDTH) \
- halign = GTK_ALIGN_START; \
- else if (ABS(x - (alloc.x + alloc.width/2)) < ALIGN_NODE_WIDTH) \
- halign = GTK_ALIGN_FILL; \
- else if (ABS(x - (alloc.x + alloc.width + right)) < ALIGN_NODE_WIDTH) \
- halign = GTK_ALIGN_END; \
- else return FALSE;
+ if (ABS (x1 - x) < 6)
+ return GTK_POS_LEFT;
+ else if (ABS (x2 - x) < 6)
+ return GTK_POS_RIGHT;
+ }
+
+ return -1;
+}
static gboolean
glade_design_layout_motion_notify_event (GtkWidget *widget, GdkEventMotion *ev)
@@ -387,45 +356,6 @@ glade_design_layout_motion_notify_event (GtkWidget *widget, GdkEventMotion *ev)
allocation.height = MAX (0, y - priv->dy - PADDING - OUTLINE_WIDTH);
allocation.width = MAX (0, x - priv->dx - PADDING - OUTLINE_WIDTH);
break;
- case ACTIVITY_EDIT_ALIGNMENT:
- {
- GtkWidget *selection = priv->selection;
- gint top, bottom, left, right;
- GtkAlign valign, halign;
- GtkAllocation alloc;
-
- gtk_widget_get_allocation (selection, &alloc);
- alloc.x += priv->child_offset;
- alloc.y += priv->child_offset;
-
- top = gtk_widget_get_margin_top (selection);
- bottom = gtk_widget_get_margin_bottom (selection);
- left = gtk_widget_get_margin_left (selection);
- right = gtk_widget_get_margin_right (selection);
-
- valign = gtk_widget_get_valign (selection);
- halign = gtk_widget_get_halign (selection);
-
- if (ABS(y - (alloc.y - top)) < ALIGN_NODE_WIDTH)
- {
- valign = GTK_ALIGN_START;
- CHECK_X_AXIS_ALIGN (halign, x, alloc, left, right);
- }
- else if (ABS(y - (alloc.y + alloc.height/2)) < ALIGN_NODE_WIDTH)
- {
- valign = GTK_ALIGN_FILL;
- CHECK_X_AXIS_ALIGN (halign, x, alloc, left, right);
- }
- else if (ABS(y - (alloc.y + alloc.height + bottom)) < ALIGN_NODE_WIDTH)
- {
- valign = GTK_ALIGN_END;
- CHECK_X_AXIS_ALIGN (halign, x, alloc, left, right);
- }
-
- gtk_widget_set_valign (selection, valign);
- gtk_widget_set_halign (selection, halign);
- }
- break;
case ACTIVITY_MARGINS:
{
gboolean shift = ev->state & GDK_SHIFT_MASK;
@@ -480,6 +410,18 @@ glade_design_layout_motion_notify_event (GtkWidget *widget, GdkEventMotion *ev)
{
Activity activity = gdl_get_activity_from_pointer (GLADE_DESIGN_LAYOUT (widget), x, y);
+ if (priv->selection)
+ {
+ GtkPositionType node = gdl_get_node_from_pointer (priv->selection, x - priv->child_offset, y - priv->child_offset);
+
+ if (priv->node_over != node)
+ {
+ /* TODO: only invalidate node area */
+ gdk_window_invalidate_rect (priv->window, NULL, FALSE);
+ priv->node_over = node;
+ }
+ }
+
if (activity == ACTIVITY_MARGINS)
activity = gdl_margin_get_activity (priv->margin);
@@ -549,23 +491,10 @@ glade_project_is_toplevel_active (GladeProject *project, GtkWidget *toplevel)
}
static void
-on_selection_size_allocation (GtkWidget *widget,
- GdkRectangle *allocation,
- GladeDesignLayoutPrivate *priv)
-{
- update_align_control_rectangle (widget, priv);
-}
-
-static void
gdl_margins_set_selection (GladeDesignLayoutPrivate *priv, GtkWidget *selection)
{
if (priv->selection == selection) return;
- if (priv->selection)
- g_signal_handlers_disconnect_by_func (priv->selection,
- G_CALLBACK (on_selection_size_allocation),
- priv);
-
priv->selection = selection;
if (selection)
@@ -579,14 +508,8 @@ gdl_margins_set_selection (GladeDesignLayoutPrivate *priv, GtkWidget *selection)
priv->valign = gtk_widget_get_valign (selection);
priv->halign = gtk_widget_get_halign (selection);
- update_align_control_rectangle (selection, priv);
-
glade_project_set_pointer_mode (priv->project, GLADE_POINTER_MARGIN_MODE);
- g_signal_connect (selection, "size-allocate",
- G_CALLBACK (on_selection_size_allocation),
- priv);
-
gtk_widget_queue_draw (selection);
}
else
@@ -597,59 +520,6 @@ gdl_margins_set_selection (GladeDesignLayoutPrivate *priv, GtkWidget *selection)
}
static gboolean
-on_edit_alignment_timeout (gpointer data)
-{
- GtkWidget *widget = data;
- GladeDesignLayoutPrivate *priv = GLADE_DESIGN_LAYOUT_GET_PRIVATE (widget);
-
- if (priv->activity == ACTIVITY_EDIT_ALIGNMENT)
- {
- GtkWidget *selection = priv->selection;
- gdouble x1, x3, y1, y3;
- GtkAllocation alloc;
- GdkRectangle rect;
- gint x, y, w, h;
-
- gtk_widget_get_allocation (selection, &alloc);
- if (alloc.x < 0 || alloc.y < 0) return TRUE;
-
- w = alloc.width;
- h = alloc.height;
-
- gtk_widget_translate_coordinates (selection, widget, 0, 0, &x, &y);
-
- x1 = x - gtk_widget_get_margin_left (selection) - 7;
- x3 = x + w + gtk_widget_get_margin_right (selection) - 7;
- y1 = y - gtk_widget_get_margin_top (selection) - 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);
-
- 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;
-
- return TRUE;
- }
-
- return FALSE;
-}
-
-static gboolean
glade_design_layout_button_press_event (GtkWidget *widget, GdkEventButton *ev)
{
GladeDesignLayoutPrivate *priv;
@@ -693,10 +563,6 @@ glade_design_layout_button_press_event (GtkWidget *widget, GdkEventButton *ev)
gdl_set_cursor (priv, priv->cursors[gdl_margin_get_activity (priv->margin)]);
return FALSE;
break;
- case ACTIVITY_EDIT_ALIGNMENT:
- priv->align_dash_start = 0;
- g_timeout_add (100, on_edit_alignment_timeout, widget);
- gtk_widget_queue_draw (widget);
default:
gdl_set_cursor (priv, priv->cursors[priv->activity]);
break;
@@ -716,6 +582,75 @@ glade_design_layout_button_press_event (GtkWidget *widget, GdkEventButton *ev)
_glade_design_view_thaw (priv->view);
}
}
+ else if (ev->type == GDK_2BUTTON_PRESS && priv->activity == ACTIVITY_MARGINS)
+ {
+ GtkWidget *selection = priv->selection;
+ gboolean top, bottom, left, right;
+ GtkAlign valign, halign;
+ GladeWidget *gwidget;
+
+ valign = gtk_widget_get_valign (selection);
+ halign = gtk_widget_get_halign (selection);
+
+ if (valign == GTK_ALIGN_FILL)
+ top = bottom = TRUE;
+ else
+ {
+ top = (valign == GTK_ALIGN_START);
+ bottom = (valign == GTK_ALIGN_END);
+ }
+
+ if (halign == GTK_ALIGN_FILL)
+ left = right = TRUE;
+ else
+ {
+ left = (halign == GTK_ALIGN_START);
+ right = (halign == GTK_ALIGN_END);
+ }
+
+ switch (gdl_get_node_from_pointer (selection, x - priv->child_offset, y - priv->child_offset))
+ {
+ case GTK_POS_TOP:
+ valign = (top) ? ((bottom) ? GTK_ALIGN_END : GTK_ALIGN_CENTER) :
+ ((bottom) ? GTK_ALIGN_FILL : GTK_ALIGN_START);
+ break;
+ case GTK_POS_BOTTOM:
+ valign = (bottom) ? ((top) ? GTK_ALIGN_START : GTK_ALIGN_CENTER) :
+ ((top) ? GTK_ALIGN_FILL : GTK_ALIGN_END);
+ break;
+ case GTK_POS_LEFT:
+ halign = (left) ? ((right) ? GTK_ALIGN_END : GTK_ALIGN_CENTER) :
+ ((right) ? GTK_ALIGN_FILL : GTK_ALIGN_START);
+ break;
+ case GTK_POS_RIGHT:
+ halign = (right) ? ((left) ? GTK_ALIGN_START : GTK_ALIGN_CENTER) :
+ ((left) ? GTK_ALIGN_FILL : GTK_ALIGN_END);
+ break;
+ default:
+ return FALSE;
+ break;
+ }
+
+ if ((gwidget = glade_widget_get_from_gobject (selection)))
+ {
+ GladeProperty *property;
+
+ glade_command_push_group (_("Editing alignments of %s"),
+ glade_widget_get_name (gwidget));
+
+ if (gtk_widget_get_valign (selection) != valign)
+ {
+ if ((property = glade_widget_get_property (gwidget, "valign")))
+ glade_command_set_property (property, valign);
+ }
+ if (gtk_widget_get_halign (selection) != halign)
+ {
+ if ((property = glade_widget_get_property (gwidget, "halign")))
+ glade_command_set_property (property, halign);
+ }
+ glade_command_pop_group ();
+ }
+ }
return FALSE;
}
@@ -769,35 +704,10 @@ glade_design_layout_button_release_event (GtkWidget *widget,
glade_command_pop_group ();
}
- else if (priv->selection && priv->activity == ACTIVITY_EDIT_ALIGNMENT)
- {
- GladeWidget *gwidget = glade_widget_get_from_gobject (priv->selection);
- GladeProperty *property;
- GtkAlign valign, halign;
-
- glade_command_push_group (_("Editing alignments of %s"),
- glade_widget_get_name (gwidget));
-
- valign = gtk_widget_get_valign (priv->selection);
- halign = gtk_widget_get_halign (priv->selection);
-
- if (priv->valign != valign)
- {
- if ((property = glade_widget_get_property (gwidget, "valign")))
- glade_command_set_property (property, valign);
- }
- if (priv->halign != halign)
- {
- if ((property = glade_widget_get_property (gwidget, "halign")))
- glade_command_set_property (property, halign);
- }
- glade_command_pop_group ();
-
- gtk_widget_queue_draw (widget);
- }
priv->activity = ACTIVITY_NONE;
gdl_set_cursor (priv, NULL);
+ priv->node_over = -1;
return FALSE;
}
@@ -1175,25 +1085,10 @@ draw_selection (cairo_t *cr,
draw_margin_selection (cr, xw, xw, xw_right, xw_right, y, yh, yh_bottom, y_top,
r, g, b, xw_right, y);
- /* Draw Boxes */
+ /* Draw Selection box */
cairo_set_source_rgba (cr, r, g, b, .75);
- if (top || bottom || left || right)
- {
- gdouble dashes[] = { 4.0, 4.0 };
- cairo_rectangle (cr,
- x - left,
- y - top,
- w + left + right,
- h + top + bottom);
- cairo_stroke (cr);
- cairo_set_dash (cr, dashes, 2, 0);
- }
-
- /* Draw Widget allocation box */
- cairo_rectangle (cr, x, y, w, h);
+ cairo_rectangle (cr, x - left, y - top, w + left + right, h + top + bottom);
cairo_stroke (cr);
-
- cairo_set_dash (cr, NULL, 0, 0);
}
#define DIMENSION_OFFSET 10
@@ -1245,8 +1140,8 @@ draw_pixel_value (cairo_t *cr,
if (rotate)
{
- xx = x - 2;
- yy = y + extents.width/2;
+ xx = x - 1.5;
+ yy = y + .5 + extents.width/2;
cairo_rotate (cr, G_PI/-2);
cairo_device_to_user (cr, &xx, &yy);
}
@@ -1381,7 +1276,7 @@ draw_dimensions (cairo_t *cr,
}
static void
-draw_node (cairo_t *cr, gint x, gint y, GdkRGBA *c1, GdkRGBA *c2)
+draw_node (cairo_t *cr, gint x, gint y, GdkRGBA *c1, GdkRGBA *c2, gboolean over)
{
cairo_new_sub_path (cr);
cairo_arc (cr, x, y, OUTLINE_WIDTH, 0, 2*G_PI);
@@ -1390,6 +1285,17 @@ draw_node (cairo_t *cr, gint x, gint y, GdkRGBA *c1, GdkRGBA *c2)
cairo_stroke_preserve (cr);
gdk_cairo_set_source_rgba (cr, c1);
+
+ if (over)
+ {
+ cairo_pattern_t *pattern = cairo_pattern_create_linear (x-OUTLINE_WIDTH, y-OUTLINE_WIDTH, x+OUTLINE_WIDTH, y+OUTLINE_WIDTH);
+ cairo_fill_preserve (cr);
+ cairo_pattern_add_color_stop_rgba (pattern, 0, 1, 1, 1, .1);
+ cairo_pattern_add_color_stop_rgba (pattern, 1, 1, 1, 1, .4);
+ cairo_set_source (cr, pattern);
+ cairo_fill (cr);
+ }
+
cairo_fill (cr);
}
@@ -1398,19 +1304,21 @@ draw_selection_nodes (cairo_t *cr,
GladeDesignLayoutPrivate *priv,
GtkWidget *parent)
{
+ GtkPositionType node = priv->node_over;
GtkWidget *widget = priv->selection;
gint top, bottom, left, right;
gint x1, x2, x3, y1, y2, y3;
GtkAllocation alloc, palloc;
- GdkRGBA *c1, *c2, *fg;
+ GdkRGBA *c1, *c2, *c3, *fg;
+ GtkAlign valign, halign;
gint x, y, w, h;
- Margins align;
gtk_widget_get_allocation (widget, &alloc);
if (alloc.x < 0 || alloc.y < 0) return;
c1 = &priv->frame_color_active[0];
c2 = &priv->frame_color_active[1];
+ c3 = &priv->frame_color[0];
fg = &priv->fg_color;
gtk_widget_get_allocation (parent, &palloc);
@@ -1420,13 +1328,13 @@ draw_selection_nodes (cairo_t *cr,
gtk_widget_translate_coordinates (widget, parent, 0, 0, &x, &y);
+ valign = gtk_widget_get_valign (widget);
+ halign = gtk_widget_get_halign (widget);
top = gtk_widget_get_margin_top (widget);
bottom = gtk_widget_get_margin_bottom (widget);
left = gtk_widget_get_margin_left (widget);
right = gtk_widget_get_margin_right (widget);
- align = priv->current_align_node;
-
/* Draw nodes */
x1 = x - left;
x2 = x + w/2;
@@ -1435,19 +1343,29 @@ draw_selection_nodes (cairo_t *cr,
y2 = y + h/2;
y3 = y + h + bottom;
- /* Draw align control node */
+ /* Draw nodes */
cairo_set_line_width (cr, OUTLINE_WIDTH);
- gdk_cairo_set_source_rgba (cr, c2);
- gdk_cairo_rectangle (cr, &priv->align_control);
- cairo_stroke_preserve (cr);
- gdk_cairo_set_source_rgba (cr, c1);
- cairo_fill (cr);
+ if (valign == GTK_ALIGN_FILL)
+ {
+ draw_node (cr, x2, y1, c1, c2, node == GTK_POS_TOP);
+ draw_node (cr, x2, y3, c1, c2, node == GTK_POS_BOTTOM);
+ }
+ else
+ {
+ draw_node (cr, x2, y1, (valign == GTK_ALIGN_START) ? c1 : c3, c2, node == GTK_POS_TOP);
+ draw_node (cr, x2, y3, (valign == GTK_ALIGN_END) ? c1 : c3, c2, node == GTK_POS_BOTTOM);
+ }
- /* Draw nodes */
- if (align != MARGIN_TOP) draw_node (cr, x2, y1, c1, c2);
- if (align != MARGIN_BOTTOM) draw_node (cr, x2, y3, c1, c2);
- if (align != MARGIN_LEFT) draw_node (cr, x1, y2, c1, c2);
- if (align != MARGIN_RIGHT) draw_node (cr, x3, y2, c1, c2);
+ if (halign == GTK_ALIGN_FILL)
+ {
+ draw_node (cr, x1, y2, c1, c2, node == GTK_POS_LEFT);
+ draw_node (cr, x3, y2, c1, c2, node == GTK_POS_RIGHT);
+ }
+ else
+ {
+ draw_node (cr, x1, y2, (halign == GTK_ALIGN_START) ? c1 : c3, c2, node == GTK_POS_LEFT);
+ draw_node (cr, x3, y2, (halign == GTK_ALIGN_END) ? c1 : c3, c2, node == GTK_POS_RIGHT);
+ }
/* Draw dimensions */
if (top || bottom || left || right)
@@ -1455,47 +1373,6 @@ draw_selection_nodes (cairo_t *cr,
cairo_set_line_width (cr, 1);
draw_dimensions (cr, c2, fg, x+.5, y+.5, w, h, top, bottom, left, right);
}
-
- /* Draw animated placeholders for alignment node */
- if (priv->activity == ACTIVITY_EDIT_ALIGNMENT)
- {
- gdouble dashes[] = { 3, 2 };
-
- cairo_translate (cr, -6.5, -6.5);
-
- if (!(align & MARGIN_TOP && align & MARGIN_LEFT))
- cairo_rectangle (cr, x1, y1, 12, 12);
-
- if (!(align & MARGIN_TOP && align & MARGIN_RIGHT))
- cairo_rectangle (cr, x3, y1, 12, 12);
-
- if (!(align & MARGIN_BOTTOM && align & MARGIN_LEFT))
- cairo_rectangle (cr, x1, y3, 12, 12);
-
- if (!(align & MARGIN_BOTTOM && align & MARGIN_RIGHT))
- cairo_rectangle (cr, x3, y3, 12, 12);
-
- if (align) cairo_rectangle (cr, x2, y2, 12, 12);
-
- cairo_translate (cr, 5.5, 5.5);
-
- cairo_set_line_join (cr, CAIRO_LINE_JOIN_MITER);
- cairo_set_line_cap (cr, CAIRO_LINE_CAP_BUTT);
-
- cairo_set_line_width (cr, 2);
- cairo_set_dash (cr, NULL, 0, 0);
-
- gdk_cairo_set_source_rgba (cr, c2);
- cairo_stroke_preserve (cr);
-
- /* priv->align_dash_start is incremented in on_edit_alignment_timeout() */
- cairo_set_line_width (cr, 1);
- cairo_set_dash (cr, dashes, 2, priv->align_dash_start + .5);
- gdk_cairo_set_source_rgba (cr, c1);
- cairo_stroke (cr);
-
- cairo_set_dash (cr, NULL, 0, 0);
- }
}
static gboolean
@@ -1730,8 +1607,6 @@ glade_design_layout_realize (GtkWidget * widget)
priv->cursors[ACTIVITY_RESIZE_HEIGHT] = gdk_cursor_new_for_display (display, GDK_BOTTOM_SIDE);
priv->cursors[ACTIVITY_RESIZE_WIDTH] = gdk_cursor_new_for_display (display, GDK_RIGHT_SIDE);
priv->cursors[ACTIVITY_RESIZE_WIDTH_AND_HEIGHT] = gdk_cursor_new_for_display (display, GDK_BOTTOM_RIGHT_CORNER);
-
- priv->cursors[ACTIVITY_EDIT_ALIGNMENT] = gdk_cursor_new_for_display (display, GDK_CROSS_REVERSE);
priv->cursors[ACTIVITY_MARGINS_VERTICAL] = gdk_cursor_new_for_display (display, GDK_SB_V_DOUBLE_ARROW);
priv->cursors[ACTIVITY_MARGINS_HORIZONTAL] = gdk_cursor_new_for_display (display, GDK_SB_H_DOUBLE_ARROW);
@@ -1830,6 +1705,7 @@ glade_design_layout_init (GladeDesignLayout *layout)
priv->new_width = -1;
priv->new_height = -1;
+ priv->node_over = -1;
/* setup static member of rectangles */
priv->east.width = PADDING + OUTLINE_WIDTH;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]