ladanyi@1
|
1 |
#include <all_include.h>
|
ladanyi@1
|
2 |
#include <mapstorage.h>
|
ladanyi@1
|
3 |
#include <main_win.h>
|
ladanyi@1
|
4 |
#include <libgnomecanvasmm.h>
|
ladanyi@1
|
5 |
#include <libgnomecanvasmm/polygon.h>
|
ladanyi@1
|
6 |
|
ladanyi@1
|
7 |
#define MAIN_PART
|
ladanyi@1
|
8 |
|
hegyi@28
|
9 |
std::vector <std::string> edge_property_strings;
|
hegyi@28
|
10 |
std::vector <double> edge_property_defaults;
|
hegyi@28
|
11 |
std::vector <std::string> node_property_strings;
|
hegyi@28
|
12 |
std::vector <double> node_property_defaults;
|
ladanyi@1
|
13 |
|
ladanyi@1
|
14 |
|
ladanyi@1
|
15 |
int main(int argc, char *argv[])
|
ladanyi@1
|
16 |
{
|
hegyi@4
|
17 |
|
hegyi@4
|
18 |
//initializing
|
hegyi@4
|
19 |
|
hegyi@28
|
20 |
edge_property_strings.resize(EDGE_PROPERTY_NUM);
|
hegyi@28
|
21 |
edge_property_strings[E_WIDTH]="Edge Width";
|
hegyi@28
|
22 |
edge_property_strings[E_COLOR]="Edge Color";
|
hegyi@28
|
23 |
edge_property_strings[E_TEXT]="Edge Text";
|
ladanyi@1
|
24 |
|
hegyi@28
|
25 |
edge_property_defaults.resize(EDGE_PROPERTY_NUM);
|
hegyi@28
|
26 |
edge_property_defaults[E_WIDTH]=10.0;
|
hegyi@28
|
27 |
edge_property_defaults[E_COLOR]=100;
|
hegyi@28
|
28 |
edge_property_defaults[E_TEXT]=0;
|
hegyi@28
|
29 |
|
hegyi@28
|
30 |
node_property_strings.resize(NODE_PROPERTY_NUM);
|
hegyi@28
|
31 |
node_property_strings[N_RADIUS]="Node Radius";
|
hegyi@28
|
32 |
node_property_strings[N_COLOR]="Node Color";
|
hegyi@28
|
33 |
node_property_strings[N_TEXT]="Node Text";
|
hegyi@28
|
34 |
|
hegyi@28
|
35 |
node_property_defaults.resize(NODE_PROPERTY_NUM);
|
hegyi@28
|
36 |
node_property_defaults[N_RADIUS]=20.0;
|
hegyi@28
|
37 |
node_property_defaults[N_COLOR]=100;
|
hegyi@28
|
38 |
node_property_defaults[N_TEXT]=0;
|
ladanyi@1
|
39 |
|
ladanyi@1
|
40 |
if(argc<2)
|
ladanyi@1
|
41 |
{
|
ladanyi@1
|
42 |
std::cerr << "USAGE: gd <input filename.lgf>" << std::endl;
|
ladanyi@1
|
43 |
return 0;
|
ladanyi@1
|
44 |
}
|
ladanyi@1
|
45 |
|
ladanyi@1
|
46 |
Coordinates coosvector;
|
ladanyi@1
|
47 |
|
ladanyi@1
|
48 |
Graph g;
|
ladanyi@1
|
49 |
|
ladanyi@1
|
50 |
CoordinatesMap cm(g);
|
ladanyi@1
|
51 |
Graph::EdgeMap<double> cap(g), map1(g), map2(g), map3(g), map4(g);
|
hegyi@4
|
52 |
Graph::NodeMap<double> nodedata (g);
|
ladanyi@1
|
53 |
|
ladanyi@1
|
54 |
//we create one object to read x coordinates
|
ladanyi@1
|
55 |
//and one to read y coordinate of nodes and write them to cm NodeMap.
|
ladanyi@1
|
56 |
XMap <CoordinatesMap> xreader (cm);
|
ladanyi@1
|
57 |
YMap <CoordinatesMap> yreader (cm);
|
hegyi@4
|
58 |
|
hegyi@4
|
59 |
//reading in graph and its maps
|
ladanyi@1
|
60 |
|
ladanyi@1
|
61 |
std::ifstream is(argv[1]);
|
ladanyi@1
|
62 |
|
ladanyi@1
|
63 |
GraphReader<Graph> reader(is, g);
|
ladanyi@1
|
64 |
reader.readNodeMap("coordinates_x", xreader);
|
ladanyi@1
|
65 |
reader.readNodeMap("coordinates_y", yreader);
|
ladanyi@1
|
66 |
reader.readNodeMap("data", nodedata);
|
ladanyi@1
|
67 |
reader.readEdgeMap("cap", cap);
|
ladanyi@1
|
68 |
reader.readEdgeMap("map1", map1);
|
ladanyi@1
|
69 |
reader.readEdgeMap("map2", map2);
|
ladanyi@1
|
70 |
reader.readEdgeMap("map3", map3);
|
ladanyi@1
|
71 |
reader.readEdgeMap("map4", map4);
|
ladanyi@1
|
72 |
reader.run();
|
ladanyi@1
|
73 |
|
hegyi@4
|
74 |
//initializing MapStorage with the read data
|
hegyi@4
|
75 |
|
ladanyi@1
|
76 |
MapStorage ms(g);
|
ladanyi@1
|
77 |
ms.addNodeMap("data",&nodedata);
|
ladanyi@1
|
78 |
ms.addEdgeMap("cap",&cap);
|
ladanyi@1
|
79 |
ms.addEdgeMap("map1",&map1);
|
ladanyi@1
|
80 |
ms.addEdgeMap("map2",&map2);
|
ladanyi@1
|
81 |
ms.addEdgeMap("map3",&map3);
|
ladanyi@1
|
82 |
ms.addEdgeMap("map4",&map4);
|
ladanyi@1
|
83 |
|
hegyi@4
|
84 |
//initializing GUI
|
hegyi@4
|
85 |
|
ladanyi@1
|
86 |
Gnome::Canvas::init();
|
ladanyi@1
|
87 |
Gtk::Main app(argc, argv);
|
ladanyi@1
|
88 |
|
ladanyi@1
|
89 |
MainWin mainwin("Displayed Graph", g, cm, ms);
|
ladanyi@1
|
90 |
app.run(mainwin);
|
ladanyi@1
|
91 |
|
ladanyi@1
|
92 |
return 0;
|
ladanyi@1
|
93 |
}
|