From 94a1e38de816779410dddee607abeff76aac63f4 Mon Sep 17 00:00:00 2001 From: Andrea Zagli Date: Sun, 24 Jun 2007 14:28:49 +0000 Subject: [PATCH] Added CanvasText. Continued selection. git-svn-id: svn+ssh://saetta.homelinux.org/svn/greptool/trunk@8 76169498-11ee-428b-941f-28d7a79d5cb2 --- data/greptool/glade/greptool.glade | 975 +++++++++++++++++++++++------ src/Makefile.am | 1 + src/canvas.c | 197 ++++-- src/canvastext.c | 368 +++++++++++ src/canvastext.h | 66 ++ src/main.c | 35 +- src/objects_tree.c | 1 + 7 files changed, 1377 insertions(+), 266 deletions(-) create mode 100644 src/canvastext.c create mode 100644 src/canvastext.h diff --git a/data/greptool/glade/greptool.glade b/data/greptool/glade/greptool.glade index 375f442..d9e1a3f 100644 --- a/data/greptool/glade/greptool.glade +++ b/data/greptool/glade/greptool.glade @@ -535,27 +535,40 @@ You should have received a copy of the GNU General Public License along with Nau 4 3 - + True - True + 0 + Provider + + + GTK_FILL + + + + + + True + 0 + Connection String - 1 - 2 1 2 + GTK_FILL - + True + 0 + SQL - 1 - 2 + 2 + 3 GTK_FILL - GTK_FILL + @@ -578,39 +591,26 @@ You should have received a copy of the GNU General Public License along with Nau - + True - 0 - SQL - 2 - 3 + 1 + 2 GTK_FILL - + GTK_FILL - + True - 0 - Connection String + True + 1 + 2 1 2 - GTK_FILL - - - - - - True - 0 - Provider - - - GTK_FILL @@ -648,19 +648,27 @@ You should have received a copy of the GNU General Public License along with Nau 3 3 - + + True + 0 + Height + + + GTK_FILL + + + + + True True - True - 0 - True + 1 1 10000 1 10 10 + 1 + 2 1 2 - 1 - 2 - GTK_FILL @@ -678,26 +686,18 @@ You should have received a copy of the GNU General Public License along with Nau - + True True - 1 1 10000 1 10 10 - 1 - 2 + True + 0 + True 1 2 - - - - - - True - 0 - Height - - + 1 + 2 GTK_FILL @@ -744,19 +744,27 @@ You should have received a copy of the GNU General Public License along with Nau 3 3 - + + True + 0 + Height + + + GTK_FILL + + + + + True True - True - 0 - True + 1 1 10000 1 10 10 + 1 + 2 1 2 - 1 - 2 - GTK_FILL @@ -774,26 +782,18 @@ You should have received a copy of the GNU General Public License along with Nau - + True True - 1 1 10000 1 10 10 - 1 - 2 + True + 0 + True 1 2 - - - - - - True - 0 - Height - - + 1 + 2 GTK_FILL @@ -898,32 +898,35 @@ You should have received a copy of the GNU General Public License along with Nau 3 3 - + True GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK - A4 -Custom - + 0 + Width - 1 - 2 + 1 + 2 + GTK_FILL + - + True GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK 0 - Type + Height + 2 + 3 GTK_FILL - + True True GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK @@ -933,12 +936,11 @@ Custom 1 2 - 2 - 3 + 1 - + True True GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK @@ -948,35 +950,33 @@ Custom 1 2 - 1 + 2 + 3 - + True GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK 0 - Height + Type - 2 - 3 GTK_FILL - + True GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK - 0 - Width + A4 +Custom + - 1 - 2 - GTK_FILL - + 1 + 2 @@ -1019,22 +1019,61 @@ Custom 3 3 - + True - True GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK - 0 0 10000 1 10 10 - 2 + 0 + Top + + + GTK_FILL + + + + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 + Right + + + 1 + 2 + GTK_FILL + + + + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 + Bottom + + + 2 + 3 + GTK_FILL + + + + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 + Left - 1 - 2 3 4 + GTK_FILL + - + True True GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK @@ -1044,8 +1083,6 @@ Custom 1 2 - 2 - 3 @@ -1064,7 +1101,7 @@ Custom - + True True GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK @@ -1074,60 +1111,23 @@ Custom 1 2 + 2 + 3 - + True + True GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK - 0 - Left + 0 0 10000 1 10 10 + 2 + 1 + 2 3 4 - GTK_FILL - - - - - - True - GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK - 0 - Bottom - - - 2 - 3 - GTK_FILL - - - - - - True - GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK - 0 - Right - - - 1 - 2 - GTK_FILL - - - - - - True - GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK - 0 - Top - - - GTK_FILL - @@ -1169,34 +1169,31 @@ Custom 2 4 - - True - GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK - 0 - Height - - - - + True True GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK - 0 0 10000 1 10 10 - 2 + 0 + True - 1 + 3 4 + 1 + 2 - + True + True GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK - 0 - On First Page + 0 + True + 1 + 2 1 2 @@ -1216,35 +1213,38 @@ Custom - + True - True GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK - 0 - True + 0 + On First Page - 1 - 2 1 2 - + True True GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK - 0 - True + 1 1 10000 1 10 10 + 2 - 3 + 1 4 - 1 - 2 + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 + Height + + @@ -1286,34 +1286,31 @@ Custom 2 4 - - True - GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK - 0 - Height - - - - + True True GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK - 0 0 10000 1 10 10 - 2 + 0 + True - 1 + 3 4 + 1 + 2 - + True + True GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK - 0 - On First Page + 0 + True + 1 + 2 1 2 @@ -1333,35 +1330,38 @@ Custom - + True - True GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK - 0 - True + 0 + On First Page - 1 - 2 1 2 - + True True GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK - 0 - True + 1 1 10000 1 10 10 + 2 - 3 + 1 4 - 1 - 2 + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 + Height + + @@ -1454,4 +1454,571 @@ Custom + + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + Preferences - GRepTool + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + + + True + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 3 + 3 + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 + GTK_SHADOW_NONE + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 12 + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 3 + 2 + + + True + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 0 100 1 10 10 + + + 1 + 2 + + + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 + Size + + + + + + + + + + + + + + + + + + + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + <b>Grid</b> + True + + + label_item + + + + + False + False + + + + + + + + + + + False + + + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + General + + + tab + False + False + + + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 3 + 3 + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 + GTK_SHADOW_NONE + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 12 + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 + GTK_SHADOW_NONE + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 12 + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 3 + 2 + 3 + 3 + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 + Width + + + 1 + 2 + GTK_FILL + + + + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 + Height + + + 2 + 3 + GTK_FILL + + + + + + True + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 0 10000 1 10 10 + 2 + + + 1 + 2 + 1 + 2 + + + + + True + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 0 10000 1 10 10 + 2 + + + 1 + 2 + 2 + 3 + + + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 + Type + + + GTK_FILL + + + + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + A4 +Custom + + + 1 + 2 + + + + + + + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + Size + True + + + label_item + + + + + False + + + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 + GTK_SHADOW_NONE + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 12 + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 4 + 2 + 3 + 3 + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 + Top + + + GTK_FILL + + + + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 + Right + + + 1 + 2 + GTK_FILL + + + + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 + Bottom + + + 2 + 3 + GTK_FILL + + + + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 + Left + + + 3 + 4 + GTK_FILL + + + + + + True + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 0 10000 1 10 10 + 2 + + + 1 + 2 + + + + + True + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 0 10000 1 10 10 + 2 + + + 1 + 2 + 1 + 2 + + + + + True + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 0 10000 1 10 10 + 2 + + + 1 + 2 + 2 + 3 + + + + + True + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 0 10000 1 10 10 + 2 + + + 1 + 2 + 3 + 4 + + + + + + + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + Margins + True + + + label_item + + + + + False + 1 + + + + + + + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + <b>Page</b> + True + + + label_item + + + + + False + False + + + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 + GTK_SHADOW_NONE + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 12 + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 3 + 2 + + + True + True + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 + + + 1 + 2 + + + + + + + + + + + + + + + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 0 + Font + + + GTK_FILL + + + + + + + + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + <b>Text Objects</b> + True + + + label_item + + + + + False + False + 1 + + + + + + + + 1 + False + + + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + Defaults + + + tab + 1 + False + False + + + + + + + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + 3 + 3 + GTK_BUTTONBOX_END + + + True + True + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + gtk-cancel + True + 0 + + + + + True + True + True + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK + gtk-ok + True + 0 + + + 1 + + + + + False + 1 + + + + + diff --git a/src/Makefile.am b/src/Makefile.am index cf21935..431dbba 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -15,5 +15,6 @@ greptool_SOURCES = \ objects_tree.c \ canvas.c \ canvasitem.c \ + canvastext.c \ canvasline.c \ canvasrect.c diff --git a/src/canvas.c b/src/canvas.c index 070e07b..b860c47 100644 --- a/src/canvas.c +++ b/src/canvas.c @@ -23,12 +23,15 @@ #include "main.h" #include "canvas.h" #include "canvasitem.h" +#include "canvastext.h" #include "canvasline.h" #include "canvasrect.h" static void grpt_canvas_class_init (GRptCanvasClass *klass); static void grpt_canvas_init (GRptCanvas *canvas); +static void grpt_canvas_fill_section (GRptCanvas *grpt_canvas, RptReportSection section, GList *objects); + #define GRPT_CANVAS_GET_PRIVATE(obj) (G_TYPE_INSTANCE_GET_PRIVATE ((obj), GRPT_TYPE_CANVAS, GRptCanvasPrivate)) @@ -123,54 +126,44 @@ grpt_canvas_init (GRptCanvas *grpt_canvas) } static void -grpt_canvas_add_object (GRptCanvas *grpt_canvas, RptReportSection section, Tool tool, +grpt_canvas_add_object (GRptCanvas *grpt_canvas, RptReportSection section, RptObject *rpt_object, gdouble x, gdouble y, gdouble width, gdouble height) { GRptCanvasPrivate *priv = GRPT_CANVAS_GET_PRIVATE (grpt_canvas); GRptCanvasClass *klass = GRPT_CANVAS_GET_CLASS (grpt_canvas); - RptObject *rpt_object; GRptCanvasItem *item; - RptPoint position; - - position.x = x; - position.y = y; - - switch (tool) + if (IS_RPT_OBJ_TEXT (rpt_object)) { - case TOOL_LINE: - { - rpt_object = rpt_obj_line_new (get_new_object_name (priv->tool), position); - rpt_report_add_object_to_section (priv->rpt_report, rpt_object, RPTREPORT_SECTION_BODY); - - item = grpt_canvas_line_new (priv->root, - x, y, - width, height, - RPT_OBJ_LINE (rpt_object), - NULL); - - } - break; - - case TOOL_RECT: - { - rpt_object = rpt_obj_rect_new (get_new_object_name (priv->tool), position); - rpt_report_add_object_to_section (priv->rpt_report, rpt_object, RPTREPORT_SECTION_BODY); - - item = grpt_canvas_rect_new (priv->root, - x, y, - width, height, - RPT_OBJ_RECT (rpt_object), - NULL); - } - break; - - default: - return; + item = grpt_canvas_text_new (priv->root, + x, y, + width, height, + RPT_OBJ_TEXT (rpt_object), + NULL); + } + else if (IS_RPT_OBJ_RECT (rpt_object)) + { + item = grpt_canvas_rect_new (priv->root, + x, y, + width, height, + RPT_OBJ_RECT (rpt_object), + NULL); + } + else if (IS_RPT_OBJ_LINE (rpt_object)) + { + item = grpt_canvas_line_new (priv->root, + x, y, + width, height, + RPT_OBJ_LINE (rpt_object), + NULL); + } + else + { + return; } - grpt_canvas_item_set_section (item, RPTREPORT_SECTION_BODY); + grpt_canvas_item_set_section (item, section); priv->body_objects = g_list_append (priv->body_objects, item); @@ -202,6 +195,10 @@ grpt_canvas_on_button_press_event (GtkWidget *widget, { grpt_canvas_item_set_selected (GRPT_CANVAS_ITEM (item), TRUE); } + + priv->in_selection = FALSE; + priv->sel_x_start = event->x; + priv->sel_y_start = event->y; } else { @@ -247,8 +244,10 @@ grpt_canvas_on_button_release_event (GtkWidget *widget, gdouble y; gdouble width; gdouble height; + RptPoint position; - GRptCanvasPrivate *priv = GRPT_CANVAS_GET_PRIVATE ((GRptCanvas *)user_data); + GRptCanvas *grpt_canvas = (GRptCanvas *)user_data; + GRptCanvasPrivate *priv = GRPT_CANVAS_GET_PRIVATE (grpt_canvas); if (event->button == 1) { @@ -279,12 +278,36 @@ grpt_canvas_on_button_release_event (GtkWidget *widget, if (priv->tool != TOOL_SELECT) { + RptObject *rpt_object = NULL; + + position.x = x; + position.y = y; + if (width != 0 || height != 0) { - grpt_canvas_add_object ((GRptCanvas *)user_data, RPTREPORT_SECTION_BODY, priv->tool, x, y, width, height); + switch (priv->tool) + { + case TOOL_TEXT: + rpt_object = rpt_obj_text_new (get_new_object_name (priv->tool), position); + break; + + case TOOL_LINE: + rpt_object = rpt_obj_line_new (get_new_object_name (priv->tool), position); + break; + + case TOOL_RECT: + rpt_object = rpt_obj_rect_new (get_new_object_name (priv->tool), position); + break; + } + if (rpt_object != NULL) + { + rpt_report_add_object_to_section (priv->rpt_report, rpt_object, RPTREPORT_SECTION_BODY); + + grpt_canvas_add_object (grpt_canvas, RPTREPORT_SECTION_BODY, rpt_object, x, y, width, height); + } } } - else + else if (priv->in_selection) { GooCanvasBounds bound; GList *objects; @@ -301,19 +324,23 @@ grpt_canvas_on_button_release_event (GtkWidget *widget, if (objects != NULL) { objects = g_list_first (objects); - } - while (objects != NULL) - { - item = (GooCanvasItem *)objects->data; - - if (item != priv->selection) + while (objects != NULL) { - grpt_canvas_item_set_selected (GRPT_CANVAS_ITEM (item), TRUE); + item = (GooCanvasItem *)objects->data; + + if (item != priv->selection) + { + grpt_canvas_item_set_selected (GRPT_CANVAS_ITEM (item), TRUE); + } + + objects = g_list_next (objects); } - - objects = g_list_next (objects); + g_list_free (objects); + } + else + { + grpt_canvas_select_section_none (grpt_canvas, RPTREPORT_SECTION_BODY); } - g_list_free (objects); } priv->in_selection = FALSE; @@ -403,13 +430,16 @@ grpt_canvas_on_motion_notify_event (GtkWidget *widget, position = grpt_canvas_item_get_position (item); - position->x += (x - position->x); - position->y += (y - position->y); + position->x += (x - priv->sel_x_start); + position->y += (y - priv->sel_y_start); grpt_canvas_item_set_position (item, *position); items = g_list_next (items); } + + priv->sel_x_start = x; + priv->sel_y_start = y; } } @@ -422,6 +452,7 @@ GRptCanvas GtkWidget *viewport; GtkWidget *fixed; RptSize *size; + GList *objects; GRptCanvas *grpt_canvas = GRPT_CANVAS (g_object_new (grpt_canvas_get_type (), NULL)); @@ -463,6 +494,34 @@ GRptCanvas "visibility", GOO_CANVAS_ITEM_HIDDEN, NULL); + /* loading objects from rpt_report */ + objects = rpt_report_section_get_objects (priv->rpt_report, RPTREPORT_SECTION_REPORT_HEADER); + if (objects != NULL) + { + grpt_canvas_fill_section (grpt_canvas, RPTREPORT_SECTION_REPORT_HEADER, objects); + } + objects = rpt_report_section_get_objects (priv->rpt_report, RPTREPORT_SECTION_PAGE_HEADER); + if (objects != NULL) + { + grpt_canvas_fill_section (grpt_canvas, RPTREPORT_SECTION_PAGE_HEADER, objects); + } + objects = rpt_report_section_get_objects (priv->rpt_report, RPTREPORT_SECTION_BODY); + if (objects != NULL) + { + grpt_canvas_fill_section (grpt_canvas, RPTREPORT_SECTION_BODY, objects); + } + objects = rpt_report_section_get_objects (priv->rpt_report, RPTREPORT_SECTION_REPORT_FOOTER); + if (objects != NULL) + { + grpt_canvas_fill_section (grpt_canvas, RPTREPORT_SECTION_REPORT_FOOTER, objects); + } + objects = rpt_report_section_get_objects (priv->rpt_report, RPTREPORT_SECTION_PAGE_FOOTER); + if (objects != NULL) + { + grpt_canvas_fill_section (grpt_canvas, RPTREPORT_SECTION_PAGE_FOOTER, objects); + } + g_list_free (objects); + return grpt_canvas; } @@ -704,3 +763,35 @@ grpt_canvas_free (GRptCanvas *grpt_canvas) gtk_widget_destroy (priv->goo_canvas); gtk_widget_destroy (priv->scrolledw); } + +static void +grpt_canvas_fill_section (GRptCanvas *grpt_canvas, RptReportSection section, GList *objects) +{ + RptObject *rpt_object; + RptPoint *position; + RptSize *size; + + if (objects != NULL) + { + objects = g_list_first (objects); + + while (objects != NULL) + { + position = NULL; + size = NULL; + + rpt_object = (RptObject *)objects->data; + + g_object_get (G_OBJECT (rpt_object), + "position", &position, + "size", &size, + NULL); + + grpt_canvas_add_object (grpt_canvas, section, rpt_object, + position->x, position->y, + size->width, size->height); + + objects = g_list_next (objects); + } + } +} diff --git a/src/canvastext.c b/src/canvastext.c new file mode 100644 index 0000000..5ce6384 --- /dev/null +++ b/src/canvastext.c @@ -0,0 +1,368 @@ +/* + * Copyright (C) 2007 Andrea Zagli + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + */ + +#include + +#include "canvastext.h" + + +static void grpt_canvas_text_class_init (GRptCanvasTextClass *klass); +static void grpt_canvas_text_init (GRptCanvasText *grpt_canvas_text); + + +static void grpt_canvas_text_paint (GooCanvasItemSimple *simple, + cairo_t *cr, + const GooCanvasBounds *bounds); + +static RptObject *grpt_canvas_text_get_rpt_object (GRptCanvasItem *grpt_canvas_item); + + +#define GRPT_CANVAS_TEXT_GET_PRIVATE(obj) (G_TYPE_INSTANCE_GET_PRIVATE ((obj), GRPT_TYPE_CANVAS_TEXT, GRptCanvasTextPrivate)) + + +typedef struct _GRptCanvasTextPrivate GRptCanvasTextPrivate; +struct _GRptCanvasTextPrivate + { + RptObjText *rpt_object_text; + }; + +GType +grpt_canvas_text_get_type (void) +{ + static GType grpt_canvas_text_type = 0; + + if (!grpt_canvas_text_type) + { + static const GTypeInfo grpt_canvas_text_info = + { + sizeof (GRptCanvasTextClass), + NULL, /* base_init */ + NULL, /* base_finalize */ + (GClassInitFunc) grpt_canvas_text_class_init, + NULL, /* class_finalize */ + NULL, /* class_data */ + sizeof (GRptCanvasText), + 0, /* n_preallocs */ + (GInstanceInitFunc) grpt_canvas_text_init, + NULL + }; + + grpt_canvas_text_type = g_type_register_static (GRPT_TYPE_CANVAS_ITEM, "GRptCanvasText", + &grpt_canvas_text_info, 0); + } + + return grpt_canvas_text_type; +} + +static void +grpt_canvas_text_class_init (GRptCanvasTextClass *klass) +{ + GObjectClass *object_class = G_OBJECT_CLASS (klass); + GRptCanvasItemClass *canvas_item_class = GRPT_CANVAS_ITEM_CLASS (klass); + GooCanvasItemSimpleClass *simple_class = (GooCanvasItemSimpleClass *)klass; + + g_type_class_add_private (object_class, sizeof (GRptCanvasTextPrivate)); + + canvas_item_class->paint = grpt_canvas_text_paint; + canvas_item_class->get_rpt_object = grpt_canvas_text_get_rpt_object; +} + +static void +grpt_canvas_text_init (GRptCanvasText *grpt_canvas_text) +{ +} + +GRptCanvasItem +*grpt_canvas_text_new (GooCanvasItem *parent, gdouble x, gdouble y, gdouble width, gdouble height, RptObjText *rpt_object_text, ...) +{ + GRptCanvasItem *item; + GRptCanvasText *grpt_canvas_text; + + RptPoint position; + RptSize size; + + const char *first_property; + va_list var_args; + GRptCanvasTextPrivate *priv; + + item = g_object_new (GRPT_TYPE_CANVAS_TEXT, NULL); + + grpt_canvas_text = (GRptCanvasText *)item; + + priv = GRPT_CANVAS_TEXT_GET_PRIVATE (grpt_canvas_text); + priv->rpt_object_text = g_object_ref (rpt_object_text); + + va_start (var_args, rpt_object_text); + first_property = va_arg (var_args, char*); + if (first_property) + { + g_object_set_valist ((GObject *)item, first_property, var_args); + } + va_end (var_args); + + if (parent) + { + goo_canvas_item_add_child (parent, GOO_CANVAS_ITEM (item), -1); + g_object_unref (item); + } + + position.x = x; + position.y = y; + grpt_canvas_item_set_position (item, position); + + size.width = width; + size.height = height; + grpt_canvas_item_set_size (item, size); + + return item; +} + +static void +grpt_canvas_text_paint (GooCanvasItemSimple *simple, cairo_t *cr, const GooCanvasBounds *bounds) +{ + RptPoint *position = NULL; + RptSize *size = NULL; + RptRotation *rotation = NULL; + RptAlign *align = NULL; + RptBorder *border = NULL; + RptFont *font = NULL; + RptColor *color = NULL; + + PangoLayout *playout; + PangoFontDescription *pfdesc; + PangoAttribute *pattr; + PangoAttrList *lpattr = NULL; + + gchar *name; + gchar *text; + gchar *str_font; + + gdouble padding_top = 0.0; + gdouble padding_right = 0.0; + gdouble padding_bottom = 0.0; + gdouble padding_left = 0.0; + + GRptCanvasText *grpt_canvas_text = (GRptCanvasText *)simple; + + GRptCanvasItem *grpt_canvas_item = (GRptCanvasItem *)simple; + + GRptCanvasTextPrivate *priv = GRPT_CANVAS_TEXT_GET_PRIVATE (grpt_canvas_text); + + g_object_get (G_OBJECT (priv->rpt_object_text), + "name", &name, + "position", &position, + "size", &size, + "rotation", &rotation, + "border", &border, + "font", &font, + "align", &align, + "background-color", &color, + "padding-top", &padding_top, + "padding-right", &padding_right, + "padding-bottom", &padding_bottom, + "padding-left", &padding_left, + "source", &text, + NULL); + + if (position == NULL) + { + return; + } + + if (text == NULL || strcmp (text, "") == 0) + { + text = name; + } + + /* creating pango layout */ + /*if (priv->output_type == RPTP_OUTPUT_GTK) + { + playout = gtk_print_context_create_pango_layout (priv->gtk_print_context); + } + else + {*/ + playout = pango_cairo_create_layout (cr); + /*}*/ + if (size != NULL) + { + pango_layout_set_width (playout, (size->width - padding_left - padding_right) * PANGO_SCALE); + } + + if (font != NULL) + { + str_font = g_strdup (font->name); + if (font->bold) + { + str_font = g_strconcat (str_font, " bold", NULL); + } + if (font->italic) + { + str_font = g_strconcat (str_font, " italic", NULL); + } + if (font->size > 0) + { + str_font = g_strconcat (str_font, g_strdup_printf (" %d", font->size), NULL); + } + else + { + str_font = g_strconcat (str_font, " 12", NULL); + } + } + else + { + str_font = g_strdup ("Sans 12"); + } + + /* creating pango font description */ + pfdesc = pango_font_description_from_string (str_font); + pango_layout_set_font_description (playout, pfdesc); + pango_font_description_free (pfdesc); + + /* setting layout attributes */ + if (font != NULL && font->underline != PANGO_UNDERLINE_NONE) + { + PangoAttribute *pattr; + + pattr = pango_attr_underline_new (font->underline); + pattr->start_index = 0; + pattr->end_index = strlen (text) + 1; + + if (lpattr == NULL) + { + lpattr = pango_attr_list_new (); + } + pango_attr_list_insert (lpattr, pattr); + } + if (font != NULL && font->strike) + { + PangoAttribute *pattr; + + pattr = pango_attr_strikethrough_new (TRUE); + pattr->start_index = 0; + pattr->end_index = strlen (text) + 1; + + if (lpattr == NULL) + { + lpattr = pango_attr_list_new (); + } + pango_attr_list_insert (lpattr, pattr); + } + + if (lpattr != NULL) + { + pango_layout_set_attributes (playout, lpattr); + } + + /*if (rotation != NULL) + { + rpt_print_rotate (rpt_print, position, size, rotation->angle); + }*/ + + /* background */ + if (position != NULL && size != NULL && color != NULL) + { + cairo_rectangle (cr, position->x, position->y, size->width, size->height); + cairo_set_source_rgba (cr, color->r, color->g, color->b, color->a); + cairo_fill_preserve (cr); + } + + /* drawing border */ + /*rpt_print_border (rpt_print, position, size, border, rotation);*/ + + /* setting horizontal alignment */ + if (align != NULL) + { + switch (align->h_align) + { + case RPT_HALIGN_LEFT: + break; + + case RPT_HALIGN_CENTER: + pango_layout_set_alignment (playout, PANGO_ALIGN_CENTER); + break; + + case RPT_HALIGN_RIGHT: + pango_layout_set_alignment (playout, PANGO_ALIGN_RIGHT); + break; + + case RPT_HALIGN_JUSTIFIED: + pango_layout_set_justify (playout, TRUE); + break; + } + + /* TO DO */ + /* setting vertical alignment */ + switch (align->v_align) + { + case RPT_VALIGN_TOP: + break; + + case RPT_VALIGN_CENTER: + break; + + case RPT_VALIGN_BOTTOM: + break; + } + } + + /* setting clipping region */ + if (size != NULL) + { + cairo_rectangle (cr, + position->x + padding_left, + position->y + padding_top, + size->width - padding_left - padding_right, + size->height - padding_top - padding_bottom); + cairo_clip (cr); + } + + /* drawing text */ + if (font != NULL) + { + if (font->color != NULL) + { + cairo_set_source_rgba (cr, font->color->r, font->color->g, font->color->b, font->color->a); + } + else + { + cairo_set_source_rgba (cr, 0.0, 0.0, 0.0, 1.0); + } + } + else + { + cairo_set_source_rgba (cr, 0.0, 0.0, 0.0, 1.0); + } + + cairo_move_to (cr, position->x + padding_left, position->y + padding_top); + + pango_layout_set_text (playout, text, -1); + pango_cairo_show_layout (cr, playout); + + if (position != NULL && size != NULL) + { + cairo_reset_clip (cr); + } +} + +static RptObject +*grpt_canvas_text_get_rpt_object (GRptCanvasItem *grpt_canvas_item) +{ + GRptCanvasTextPrivate *priv = GRPT_CANVAS_TEXT_GET_PRIVATE (GRPT_CANVAS_TEXT (grpt_canvas_item)); + + return RPT_OBJECT (priv->rpt_object_text); +} diff --git a/src/canvastext.h b/src/canvastext.h new file mode 100644 index 0000000..6d0b736 --- /dev/null +++ b/src/canvastext.h @@ -0,0 +1,66 @@ +/* + * Copyright (C) 2007 Andrea Zagli + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + */ + +#ifndef __GRPT_CANVAS_TEXT_H__ +#define __GRPT_CANVAS_TEXT_H__ + +#include +#include + +#include "canvasitem.h" + + +G_BEGIN_DECLS + + +#define GRPT_TYPE_CANVAS_TEXT (grpt_canvas_text_get_type ()) +#define GRPT_CANVAS_TEXT(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GRPT_TYPE_CANVAS_TEXT, GRptCanvasText)) +#define GRPT_CANVAS_TEXT_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GRPT_TYPE_CANVAS_TEXT, GRptCanvasTextClass)) +#define GRPT_IS_CANVAS_TEXT(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GRPT_TYPE_CANVAS_TEXT)) +#define GRPT_IS_CANVAS_TEXT_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GRPT_TYPE_CANVAS_TEXT)) +#define GRPT_CANVAS_TEXT_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GRPT_TYPE_CANVAS_TEXT, GRptCanvasTextClass)) + + +typedef struct _GRptCanvasText GRptCanvasText; +typedef struct _GRptCanvasTextClass GRptCanvasTextClass; + +struct _GRptCanvasText +{ + GRptCanvasItem parent; +}; + +struct _GRptCanvasTextClass +{ + GRptCanvasItemClass parent_class; +}; + +GType grpt_canvas_text_get_type (void) G_GNUC_CONST; + +GRptCanvasItem *grpt_canvas_text_new (GooCanvasItem *parent, + gdouble x, + gdouble y, + gdouble width, + gdouble height, + RptObjText *rpt_object_text, + ...); + + +G_END_DECLS + + +#endif /* __GRPT_CANVAS_TEXT_H__ */ diff --git a/src/main.c b/src/main.c index 68e579e..5b4aab3 100644 --- a/src/main.c +++ b/src/main.c @@ -42,11 +42,11 @@ void report_on_canvas_object_removed (GRptCanvas *grpt_canvas, static gchar *report_filename; static RptReport *rpt_report; -static gint text_counter = 0; -static gint line_counter = 0; -static gint rect_counter = 0; -static gint ellipse_counter = 0; -static gint image_counter = 0; +static gint text_counter; +static gint line_counter; +static gint rect_counter; +static gint ellipse_counter; +static gint image_counter; static GtkWidget *w; static GtkWidget *vbox; @@ -72,6 +72,16 @@ static GRptCanvas *grpt_canvas; static GRptObjectsTree *objects_tree; /* PRIVATE */ +static void +report_reset_counters () +{ + text_counter = 0; + line_counter = 0; + rect_counter = 0; + ellipse_counter = 0; + image_counter = 0; +} + static void menu_toolbar_sensitivity () { @@ -142,6 +152,7 @@ report_new () } rpt_report = rptr; + report_reset_counters (); report_set_defaults (); menu_toolbar_sensitivity (); @@ -149,10 +160,10 @@ report_new () grpt_canvas = grpt_canvas_new (rpt_report); grpt_objects_tree_set_canvas (objects_tree, grpt_canvas); + canvas_widget = grpt_canvas_get_widget (grpt_canvas); + g_signal_connect (grpt_canvas, "object-added", G_CALLBACK (report_on_canvas_object_added), NULL); g_signal_connect (grpt_canvas, "object-removed", G_CALLBACK (report_on_canvas_object_removed), NULL); - - canvas_widget = grpt_canvas_get_widget (grpt_canvas); gtk_container_add (GTK_CONTAINER (vbox), canvas_widget); gtk_box_reorder_child (GTK_BOX (vbox), canvas_widget, 3); @@ -167,16 +178,19 @@ report_open_from_file (const gchar *filename) { GtkWidget *canvas_widget; + report_close (); + RptReport *rptr = rpt_report_new_from_file (filename); if (rptr == NULL) { /* TO DO */ return; } + rpt_report = rptr; - report_close (); report_filename = g_strdup (filename); - rpt_report = rptr; + + report_reset_counters (); menu_toolbar_sensitivity (); @@ -185,6 +199,9 @@ report_open_from_file (const gchar *filename) canvas_widget = grpt_canvas_get_widget (grpt_canvas); + g_signal_connect (grpt_canvas, "object-added", G_CALLBACK (report_on_canvas_object_added), NULL); + g_signal_connect (grpt_canvas, "object-removed", G_CALLBACK (report_on_canvas_object_removed), NULL); + gtk_container_add (GTK_CONTAINER (vbox), canvas_widget); gtk_box_reorder_child (GTK_BOX (vbox), canvas_widget, 3); diff --git a/src/objects_tree.c b/src/objects_tree.c index 5e100f4..489b8f7 100644 --- a/src/objects_tree.c +++ b/src/objects_tree.c @@ -286,6 +286,7 @@ grpt_objects_tree_set_canvas (GRptObjectsTree *grpt_objects_tree, GRptCanvas *ca { grpt_objects_tree_fill_tree_section (grpt_objects_tree, RPTREPORT_SECTION_PAGE_FOOTER, objects); } + g_list_free (objects); } void -- 2.49.0