gui/graph_displayer_canvas.cc
author alpar
Mon, 24 Oct 2005 15:59:38 +0000
changeset 1739 b1385f5da81b
parent 1645 4a04bb856ac7
child 1819 fd82adfbe905
permissions -rwxr-xr-x
Computing the number of the connected components and the components themselves.
ladanyi@1606
     1
#include "graph_displayer_canvas.h"
ladanyi@1606
     2
#include "broken_edge.h"
alpar@1632
     3
#include <cmath>
ladanyi@1442
     4
hegyi@1614
     5
GraphDisplayerCanvas::GraphDisplayerCanvas(MapStorage & ms, MapWin & mw, Gtk::Window * mainwin) :
ladanyi@1606
     6
  nodesmap(ms.graph), edgesmap(ms.graph), edgetextmap(ms.graph),
ladanyi@1648
     7
  nodetextmap(ms.graph), displayed_graph(*(root()), 0, 0), mapstorage(ms),
ladanyi@1648
     8
  isbutton(0), active_item(NULL), target_item(NULL), nodemap_to_edit(""),
ladanyi@1648
     9
  edgemap_to_edit(""), mapwin(mw)
ladanyi@1442
    10
{
hegyi@1614
    11
  parentwin=mainwin;
hegyi@1614
    12
ladanyi@1606
    13
  //base event handler is move tool
ladanyi@1606
    14
  actual_handler=signal_event().connect(sigc::mem_fun(*this, &GraphDisplayerCanvas::moveEventHandler), false);
ladanyi@1606
    15
  actual_tool=MOVE;
hegyi@1562
    16
ladanyi@1606
    17
  active_node=INVALID;
ladanyi@1606
    18
  active_edge=INVALID;
ladanyi@1606
    19
  forming_edge=INVALID;
ladanyi@1606
    20
}
hegyi@1468
    21
ladanyi@1606
    22
GraphDisplayerCanvas::~GraphDisplayerCanvas()
ladanyi@1606
    23
{
ladanyi@1606
    24
  for (NodeIt n(mapstorage.graph); n != INVALID; ++n)
ladanyi@1606
    25
  {
ladanyi@1606
    26
    delete nodesmap[n];
ladanyi@1606
    27
    delete nodetextmap[n];
ladanyi@1606
    28
  }
ladanyi@1442
    29
ladanyi@1606
    30
  for (EdgeIt e(mapstorage.graph); e != INVALID; ++e)
ladanyi@1606
    31
  {
ladanyi@1606
    32
    delete edgesmap[e];
ladanyi@1606
    33
    delete edgetextmap[e];
ladanyi@1606
    34
  }
ladanyi@1606
    35
}
ladanyi@1606
    36
ladanyi@1606
    37
void GraphDisplayerCanvas::drawGraph()
ladanyi@1606
    38
{
ladanyi@1442
    39
  //first edges are drawn, to hide joining with nodes later
ladanyi@1442
    40
ladanyi@1606
    41
  for (EdgeIt i(mapstorage.graph); i!=INVALID; ++i)
ladanyi@1442
    42
  {
ladanyi@1442
    43
ladanyi@1606
    44
    //drawing green lines, coordinates are from mapstorage.coords
ladanyi@1442
    45
ladanyi@1442
    46
    Gnome::Canvas::Points coos;
ladanyi@1606
    47
    coos.push_back(Gnome::Art::Point(
ladanyi@1606
    48
          mapstorage.coords[mapstorage.graph.source(i)].x,
ladanyi@1606
    49
          mapstorage.coords[mapstorage.graph.source(i)].y));
ladanyi@1606
    50
    coos.push_back(Gnome::Art::Point(
ladanyi@1606
    51
          mapstorage.coords[mapstorage.graph.target(i)].x,
ladanyi@1606
    52
          mapstorage.coords[mapstorage.graph.target(i)].y));
ladanyi@1442
    53
    
hegyi@1501
    54
    edgesmap[i]=new BrokenEdge(displayed_graph, coos, *this);
ladanyi@1442
    55
    *(edgesmap[i]) << Gnome::Canvas::Properties::fill_color("green");
hegyi@1598
    56
    edgesmap[i]->property_width_units().set_value(10);    
ladanyi@1645
    57
    edgesmap[i]->lower_to_bottom();
ladanyi@1442
    58
    
ladanyi@1442
    59
    //initializing edge-text as well, to empty string
ladanyi@1442
    60
hegyi@1524
    61
    xy<double> text_pos=edgesmap[i]->getArrowPos();
hegyi@1505
    62
    text_pos+=(xy<double>(10,10));
hegyi@1505
    63
hegyi@1505
    64
    edgetextmap[i]=new Gnome::Canvas::Text(displayed_graph, text_pos.x, text_pos.y, "");
hegyi@1512
    65
    edgetextmap[i]->property_fill_color().set_value("darkgreen");
hegyi@1599
    66
    edgetextmap[i]->signal_event().connect(sigc::mem_fun(*this, &GraphDisplayerCanvas::edgeMapEditEventHandler), false);
ladanyi@1645
    67
    edgetextmap[i]->raise_to_top();
ladanyi@1442
    68
  }
ladanyi@1442
    69
ladanyi@1442
    70
  //afterwards nodes come to be drawn
ladanyi@1442
    71
ladanyi@1606
    72
  for (NodeIt i(mapstorage.graph); i!=INVALID; ++i)
ladanyi@1442
    73
  {
ladanyi@1442
    74
    //drawing bule nodes, with black line around them
ladanyi@1442
    75
ladanyi@1606
    76
    nodesmap[i]=new Gnome::Canvas::Ellipse(
ladanyi@1606
    77
        displayed_graph,
ladanyi@1606
    78
        mapstorage.coords[i].x-20,
ladanyi@1606
    79
        mapstorage.coords[i].y-20,
ladanyi@1606
    80
        mapstorage.coords[i].x+20,
ladanyi@1606
    81
        mapstorage.coords[i].y+20);
ladanyi@1442
    82
    *(nodesmap[i]) << Gnome::Canvas::Properties::fill_color("blue");
ladanyi@1442
    83
    *(nodesmap[i]) << Gnome::Canvas::Properties::outline_color("black");
ladanyi@1645
    84
    nodesmap[i]->raise_to_top();
hegyi@1512
    85
hegyi@1512
    86
    //initializing edge-text as well, to empty string
hegyi@1512
    87
ladanyi@1606
    88
    xy<double> text_pos(
ladanyi@1606
    89
        (mapstorage.coords[i].x+node_property_defaults[N_RADIUS]+5),
ladanyi@1606
    90
        (mapstorage.coords[i].y+node_property_defaults[N_RADIUS]+5));
hegyi@1512
    91
ladanyi@1606
    92
    nodetextmap[i]=new Gnome::Canvas::Text(displayed_graph,
ladanyi@1606
    93
        text_pos.x, text_pos.y, "");
hegyi@1512
    94
    nodetextmap[i]->property_fill_color().set_value("darkblue");
hegyi@1599
    95
    nodetextmap[i]->signal_event().connect(sigc::mem_fun(*this, &GraphDisplayerCanvas::nodeMapEditEventHandler), false);
ladanyi@1645
    96
    nodetextmap[i]->raise_to_top();
ladanyi@1442
    97
  }
ladanyi@1442
    98
ladanyi@1442
    99
  updateScrollRegion();
ladanyi@1442
   100
}
ladanyi@1442
   101
ladanyi@1606
   102
void GraphDisplayerCanvas::clear()
ladanyi@1442
   103
{
ladanyi@1606
   104
  active_node=INVALID;
ladanyi@1606
   105
  active_edge=INVALID;
ladanyi@1606
   106
  forming_edge=INVALID;
ladanyi@1442
   107
ladanyi@1606
   108
  for (NodeIt n(mapstorage.graph); n != INVALID; ++n)
ladanyi@1442
   109
  {
ladanyi@1606
   110
    delete nodesmap[n];
ladanyi@1606
   111
    delete nodetextmap[n];
ladanyi@1442
   112
  }
ladanyi@1442
   113
ladanyi@1606
   114
  for (EdgeIt e(mapstorage.graph); e != INVALID; ++e)
ladanyi@1606
   115
  {
ladanyi@1606
   116
    delete edgesmap[e];
ladanyi@1606
   117
    delete edgetextmap[e];
ladanyi@1606
   118
  }
ladanyi@1442
   119
}