1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81
|
#include <iostream>
#include <tulip/TlpTools.h>
#include <tulip/Graph.h>
#include <tulip/ForEach.h>
#include <tulip/BooleanProperty.h>
#include <tulip/ColorProperty.h>
#include <tulip/DoubleProperty.h>
#include <tulip/GraphProperty.h>
#include <tulip/IntegerProperty.h>
#include <tulip/LayoutProperty.h>
#include <tulip/SizeProperty.h>
#include <tulip/StringProperty.h>
/**
* Tutorial 003
*
* Create a graph and a properties of each type
* And display properties present in the graph
*
*/
using namespace std;
using namespace tlp;
void buildGraph(Graph *graph) {
// add three nodes
node n1 = graph->addNode();
node n2 = graph->addNode();
node n3 = graph->addNode();
// add three edges
graph->addEdge(n2, n3);
graph->addEdge(n1, n2);
graph->addEdge(n3, n1);
}
int main() {
// initialize the Tulip libs
initTulipLib();
// create an empty graph
Graph *graph = newGraph();
// build the graph
buildGraph(graph);
// Get and create several properties
DoubleProperty *metric = graph->getLocalProperty<DoubleProperty>("firstMetric");
BooleanProperty *select = graph->getLocalProperty<BooleanProperty>("firstSelection");
LayoutProperty *layout = graph->getLocalProperty<LayoutProperty>("firstLayout");
IntegerProperty *integer = graph->getLocalProperty<IntegerProperty>("firstInteger");
ColorProperty *colors = graph->getLocalProperty<ColorProperty>("firstColors");
SizeProperty *sizes = graph->getLocalProperty<SizeProperty>("firstSizes");
GraphProperty *meta = graph->getLocalProperty<GraphProperty>("firstMeta");
StringProperty *strings = graph->getLocalProperty<StringProperty>("firstString");
// initialize all the properties
metric->setAllNodeValue(0.0);
metric->setAllEdgeValue(0.0);
select->setAllNodeValue(false);
select->setAllEdgeValue(false);
layout->setAllNodeValue(Coord(0, 0, 0)); // coordinates
layout->setAllEdgeValue(vector<Coord>()); // Vector of bends
integer->setAllNodeValue(0);
integer->setAllEdgeValue(0);
sizes->setAllNodeValue(Size(0, 0, 0)); // width, height, depth
sizes->setAllEdgeValue(Size(0, 0, 0)); // start_size, end_size, arrow_size
colors->setAllNodeValue(Color(0, 0, 0, 0)); // Red, green, blue
colors->setAllEdgeValue(Color(0, 0, 0, 0)); // Red, green, blue
strings->setAllNodeValue("first");
strings->setAllEdgeValue("first");
meta->setAllNodeValue(graph); // an existing graph
// iterating over properties
string p;
cout << "List of the properties present in the graph:" << endl;
forEach (p, graph->getLocalProperties()) { cout << p << endl; }
saveGraph(graph, "tutorial003.tlp");
delete graph;
return EXIT_SUCCESS;
}
|