COIN-OR::LEMON - Graph Library

source: glemon-0.x/graph_displayer_canvas.cc @ 147:10ef59f6633c

Last change on this file since 147:10ef59f6633c was 147:10ef59f6633c, checked in by Akos Ladanyi, 13 years ago

Loop edges.

  • Property exe set to *
File size: 5.7 KB
Line 
1#include "graph_displayer_canvas.h"
2#include <cmath>
3
4GraphDisplayerCanvas::GraphDisplayerCanvas(NoteBookTab & mainw) :
5  nodesmap(mainw.mapstorage.graph), edgesmap(mainw.mapstorage.graph), edgetextmap(mainw.mapstorage.graph),
6  nodetextmap(mainw.mapstorage.graph), displayed_graph(*(root()), 0, 0),
7  isbutton(0), active_item(NULL), target_item(NULL), nodemap_to_edit(""),
8  edgemap_to_edit(""), mytab(mainw)
9{
10  //base event handler is move tool
11  actual_handler=signal_event().connect(sigc::mem_fun(*this, &GraphDisplayerCanvas::moveEventHandler), false);
12  actual_tool=MOVE;
13
14  active_node=INVALID;
15  active_edge=INVALID;
16  forming_edge=INVALID;
17}
18
19GraphDisplayerCanvas::~GraphDisplayerCanvas()
20{
21  for (NodeIt n((mytab.mapstorage).graph); n != INVALID; ++n)
22    {
23      delete nodesmap[n];
24      delete nodetextmap[n];
25    }
26 
27  for (EdgeIt e((mytab.mapstorage).graph); e != INVALID; ++e)
28    {
29      delete edgesmap[e];
30      delete edgetextmap[e];
31    }
32}
33
34void GraphDisplayerCanvas::propertyChange(bool itisedge, int prop)
35{
36  if(itisedge)
37    {
38      propertyUpdate(Edge(INVALID), prop);
39    }
40  else
41    {
42      propertyUpdate(Node(INVALID), prop);
43    }
44}
45
46void GraphDisplayerCanvas::propertyUpdate(Edge edge)
47{
48  for(int i=0;i<EDGE_PROPERTY_NUM;i++)
49    {
50      propertyUpdate(edge, i);
51    }
52}
53
54void GraphDisplayerCanvas::propertyUpdate(Node node)
55{
56  for(int i=0;i<NODE_PROPERTY_NUM;i++)
57    {
58      propertyUpdate(node, i);
59    }
60}
61
62void GraphDisplayerCanvas::propertyUpdate(Node node, int prop)
63{
64  //dummy=dummy;
65
66  std::string mapname=mytab.getActiveNodeMap(prop);
67
68  if(mapname!="")
69    {
70      if( ( ((mytab.mapstorage).nodemap_storage).find(mapname) != ((mytab.mapstorage).nodemap_storage).end() ) )
71        {
72          switch(prop)
73            {
74            case N_RADIUS:
75              changeNodeRadius(mapname, node);
76              break;
77            case N_COLOR:
78              changeNodeColor(mapname, node);
79              break;
80            case N_TEXT:
81              changeNodeText(mapname, node);
82              break;
83            default:
84              std::cerr<<"Error\n";
85            }
86        }
87    }
88  else //mapname==""
89    {
90      Node node=INVALID;       
91      switch(prop)
92        {
93        case N_RADIUS:
94          resetNodeRadius(node);
95          break;
96        case N_COLOR:
97          resetNodeColor(node);
98          break;
99        case N_TEXT:
100          resetNodeText(node);
101          break;
102        default:
103          std::cerr<<"Error\n";
104        }
105    }
106
107}
108
109void GraphDisplayerCanvas::propertyUpdate(Edge edge, int prop)
110{
111  //dummy=dummy;
112
113  std::string mapname=mytab.getActiveEdgeMap(prop);
114
115  if(mapname!="")
116    {
117      if( ( ((mytab.mapstorage).edgemap_storage).find(mapname) != ((mytab.mapstorage).edgemap_storage).end() ) )
118        {
119          switch(prop)
120            {
121            case E_WIDTH:
122              changeEdgeWidth(mapname, edge);
123              break;
124            case E_COLOR:
125              changeEdgeColor(mapname, edge);
126              break;
127            case E_TEXT:
128              changeEdgeText(mapname, edge);
129              break;
130            default:
131              std::cerr<<"Error\n";
132            }
133        }
134    }
135  else //mapname==""
136    {
137      switch(prop)
138        {
139        case E_WIDTH:
140          resetEdgeWidth(edge);
141          break;
142        case E_COLOR:
143          resetEdgeColor(edge);
144          break;
145        case E_TEXT:
146          resetEdgeText(edge);
147          break;
148        default:
149          std::cerr<<"Error\n";
150        }
151    }
152}
153
154void GraphDisplayerCanvas::drawGraph()
155{
156  //first edges are drawn, to hide joining with nodes later
157
158  for (EdgeIt i((mytab.mapstorage).graph); i!=INVALID; ++i)
159  {
160
161    //drawing green lines, coordinates are from mapstorage.coords
162
163    Gnome::Canvas::Points coos;
164    coos.push_back(Gnome::Art::Point(
165          (mytab.mapstorage).coords[(mytab.mapstorage).graph.source(i)].x,
166          (mytab.mapstorage).coords[(mytab.mapstorage).graph.source(i)].y));
167    coos.push_back(Gnome::Art::Point(
168          (mytab.mapstorage).coords[(mytab.mapstorage).graph.target(i)].x,
169          (mytab.mapstorage).coords[(mytab.mapstorage).graph.target(i)].y));
170   
171    edgesmap[i]=new BrokenEdge(displayed_graph, i, *this);
172   
173    //initializing edge-text as well, to empty string
174
175    XY text_pos=mytab.mapstorage.arrow_pos[i];
176    text_pos+=(XY(10,10));
177
178    edgetextmap[i]=new Gnome::Canvas::Text(displayed_graph, text_pos.x, text_pos.y, "");
179    edgetextmap[i]->property_fill_color().set_value("darkgreen");
180    edgetextmap[i]->signal_event().connect(sigc::mem_fun(*this, &GraphDisplayerCanvas::edgeMapEditEventHandler), false);
181    edgetextmap[i]->raise_to_top();
182  }
183
184  //afterwards nodes come to be drawn
185
186  for (NodeIt i((mytab.mapstorage).graph); i!=INVALID; ++i)
187  {
188    //drawing bule nodes, with black line around them
189
190    nodesmap[i]=new Gnome::Canvas::Ellipse(
191        displayed_graph,
192        (mytab.mapstorage).coords[i].x-20,
193        (mytab.mapstorage).coords[i].y-20,
194        (mytab.mapstorage).coords[i].x+20,
195        (mytab.mapstorage).coords[i].y+20);
196    *(nodesmap[i]) << Gnome::Canvas::Properties::fill_color("blue");
197    *(nodesmap[i]) << Gnome::Canvas::Properties::outline_color("black");
198    nodesmap[i]->raise_to_top();
199
200    //initializing edge-text as well, to empty string
201
202    xy<double> text_pos(
203        ((mytab.mapstorage).coords[i].x+node_property_defaults[N_RADIUS]+5),
204        ((mytab.mapstorage).coords[i].y+node_property_defaults[N_RADIUS]+5));
205
206    nodetextmap[i]=new Gnome::Canvas::Text(displayed_graph,
207        text_pos.x, text_pos.y, "");
208    nodetextmap[i]->property_fill_color().set_value("darkblue");
209    nodetextmap[i]->signal_event().connect(sigc::mem_fun(*this, &GraphDisplayerCanvas::nodeMapEditEventHandler), false);
210    nodetextmap[i]->raise_to_top();
211  }
212
213  updateScrollRegion();
214}
215
216void GraphDisplayerCanvas::clear()
217{
218  active_node=INVALID;
219  active_edge=INVALID;
220  forming_edge=INVALID;
221
222  for (NodeIt n((mytab.mapstorage).graph); n != INVALID; ++n)
223  {
224    delete nodesmap[n];
225    delete nodetextmap[n];
226  }
227
228  for (EdgeIt e((mytab.mapstorage).graph); e != INVALID; ++e)
229  {
230    delete edgesmap[e];
231    delete edgetextmap[e];
232  }
233}
Note: See TracBrowser for help on using the repository browser.