graph_displayer_canvas.cc
author hegyi
Mon, 25 Jul 2005 11:17:23 +0000
branchgui
changeset 38 9cab23d9b124
parent 35 79bffdf6aea2
child 41 06f1f9a8d51f
permissions -rwxr-xr-x
Continuing adding new maps.
ladanyi@6
     1
#include <graph_displayer_canvas.h>
hegyi@17
     2
#include <broken_edge.h>
ladanyi@6
     3
#include <math.h>
ladanyi@6
     4
hegyi@36
     5
GraphDisplayerCanvas::GraphDisplayerCanvas(Graph & gr, CoordinatesMap & cm, MapStorage & ms, MapWin * mw):g(gr),nodesmap(g),edgesmap(g),edgetextmap(g),nodetextmap(g),displayed_graph(*(root()), 0, 0),canvasentrywidget(NULL),mapstorage(ms),isbutton(0),active_item(NULL),target_item(NULL),nodemap_to_edit(""),edgemap_to_edit(""),mapwin(mw)
ladanyi@6
     6
{
hegyi@9
     7
  
hegyi@35
     8
  
hegyi@34
     9
  active_node=INVALID;
hegyi@34
    10
  active_edge=INVALID;
hegyi@35
    11
  forming_edge=INVALID;
hegyi@34
    12
hegyi@34
    13
  //setting event handler for the editor widget
hegyi@34
    14
  entrywidget.signal_event().connect(sigc::mem_fun(*this, &GraphDisplayerCanvas::entryWidgetChangeHandler), false);
hegyi@34
    15
hegyi@34
    16
  //base event handler is move tool
hegyi@31
    17
  actual_handler=signal_event().connect(sigc::mem_fun(*this, &GraphDisplayerCanvas::moveEventHandler), false);
hegyi@35
    18
  actual_tool=MOVE;
hegyi@9
    19
ladanyi@6
    20
  //set_center_scroll_region(true);
ladanyi@6
    21
ladanyi@6
    22
  //first edges are drawn, to hide joining with nodes later
ladanyi@6
    23
ladanyi@6
    24
  for (EdgeIt i(g); i!=INVALID; ++i)
ladanyi@6
    25
  {
ladanyi@6
    26
ladanyi@6
    27
    //drawing green lines, coordinates are from cm
ladanyi@6
    28
ladanyi@6
    29
    Gnome::Canvas::Points coos;
ladanyi@6
    30
    coos.push_back(Gnome::Art::Point(cm[g.source(i)].x,cm[g.source(i)].y));
ladanyi@6
    31
    coos.push_back(Gnome::Art::Point(cm[g.target(i)].x,cm[g.target(i)].y));
ladanyi@6
    32
    
hegyi@21
    33
    edgesmap[i]=new BrokenEdge(displayed_graph, coos, *this);
ladanyi@6
    34
    *(edgesmap[i]) << Gnome::Canvas::Properties::fill_color("green");
ladanyi@6
    35
    edgesmap[i]->property_width_pixels().set_value(10);    
ladanyi@6
    36
    
ladanyi@6
    37
    //initializing edge-text as well, to empty string
ladanyi@6
    38
hegyi@30
    39
    xy<double> text_pos=edgesmap[i]->getArrowPos();
hegyi@25
    40
    text_pos+=(xy<double>(10,10));
hegyi@25
    41
hegyi@25
    42
    edgetextmap[i]=new Gnome::Canvas::Text(displayed_graph, text_pos.x, text_pos.y, "");
hegyi@28
    43
    edgetextmap[i]->property_fill_color().set_value("darkgreen");
ladanyi@6
    44
  }
ladanyi@6
    45
ladanyi@6
    46
  //afterwards nodes come to be drawn
ladanyi@6
    47
ladanyi@6
    48
  NodeIt i(g);
ladanyi@6
    49
  int maxx=0, maxy=0, minx=(int)cm[i].x, miny=(int)cm[i].y;
ladanyi@6
    50
ladanyi@6
    51
  for (; i!=INVALID; ++i)
ladanyi@6
    52
  {
ladanyi@6
    53
    //minimum and maximum is gathered to be able to zoom to the graph correctly (whole figure should be seen)
ladanyi@6
    54
ladanyi@6
    55
    if(cm[i].x>maxx)maxx=(int)cm[i].x;
ladanyi@6
    56
    if(cm[i].y>maxy)maxy=(int)cm[i].y;
ladanyi@6
    57
    if(cm[i].x<minx)minx=(int)cm[i].x;
ladanyi@6
    58
    if(cm[i].y<miny)miny=(int)cm[i].y;
ladanyi@6
    59
ladanyi@6
    60
    //drawing bule nodes, with black line around them
ladanyi@6
    61
ladanyi@6
    62
    nodesmap[i]=new Gnome::Canvas::Ellipse(displayed_graph, cm[i].x-20, cm[i].y-20, cm[i].x+20, cm[i].y+20);
ladanyi@6
    63
    *(nodesmap[i]) << Gnome::Canvas::Properties::fill_color("blue");
ladanyi@6
    64
    *(nodesmap[i]) << Gnome::Canvas::Properties::outline_color("black");
hegyi@28
    65
hegyi@28
    66
    //initializing edge-text as well, to empty string
hegyi@28
    67
hegyi@28
    68
    xy<double> text_pos((cm[i].x+node_property_defaults[N_RADIUS]+5),(cm[i].y+node_property_defaults[N_RADIUS]+5));
hegyi@28
    69
hegyi@28
    70
    nodetextmap[i]=new Gnome::Canvas::Text(displayed_graph, text_pos.x, text_pos.y, "");
hegyi@28
    71
    nodetextmap[i]->property_fill_color().set_value("darkblue");
ladanyi@6
    72
  }
ladanyi@6
    73
ladanyi@6
    74
  updateScrollRegion();
ladanyi@6
    75
}
ladanyi@6
    76
ladanyi@6
    77
GraphDisplayerCanvas::~GraphDisplayerCanvas()
ladanyi@6
    78
{
hegyi@32
    79
  if(canvasentrywidget)
hegyi@32
    80
    {
hegyi@32
    81
      delete(canvasentrywidget);
hegyi@32
    82
    }
ladanyi@6
    83
ladanyi@6
    84
  //writing out the end state of the graph
ladanyi@6
    85
  //\todo all the maps has to be write out!
ladanyi@6
    86
ladanyi@6
    87
  Graph::NodeMap <int> id(g);
ladanyi@6
    88
  Graph::NodeMap <double> xc(g);
ladanyi@6
    89
  Graph::NodeMap <double> yc(g);
ladanyi@6
    90
  
ladanyi@6
    91
  int j=1;
ladanyi@6
    92
  
ladanyi@6
    93
  for (NodeIt i(g); i!=INVALID; ++i)
ladanyi@6
    94
  {
ladanyi@6
    95
    double x1,y1,x2,y2;
ladanyi@6
    96
    nodesmap[i]->get_bounds(x1, y1, x2, y2);
ladanyi@6
    97
    
ladanyi@6
    98
    id[i]=j++;
ladanyi@6
    99
    xc[i]=(x1+x2)/2;
ladanyi@6
   100
    yc[i]=(y1+y2)/2;
ladanyi@6
   101
  }
ladanyi@6
   102
ladanyi@6
   103
  GraphWriter<Graph> writer(std::cout,g);
ladanyi@6
   104
  
ladanyi@6
   105
  writer.writeNodeMap("id", id);
ladanyi@6
   106
  writer.writeNodeMap("coordinates_x", xc);
ladanyi@6
   107
  writer.writeNodeMap("coordinates_y", yc);
ladanyi@6
   108
  writer.run();
ladanyi@6
   109
}