00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046
00047
00048
00049
00050
00051
00052
00053 #ifndef SDAGLAYOUTER_H
00054 #define SDAGLAYOUTER_H
00055
00056
00057 #include <LEDA/graph.h>
00058 #include <LEDA/node_array.h>
00059 #include <LEDA/edge_array.h>
00060 #include <LEDA/list.h>
00061 #include <LEDA/string.h>
00062 #include <LEDA/point.h>
00063
00064 #ifndef leda_list_item
00065 #define leda_list_item list_item
00066 #endif
00067
00068
00071 class SDAGLayouter {
00072 public:
00073 SDAGLayouter();
00074
00076 const leda_list<leda_string> &getLayoutAlgs() { return _layoutAlgs; };
00077
00092 bool layout(const leda_string &alg, const leda_graph &g,
00093 const leda_node_array<leda_point> &sizes,
00094 leda_point windowSize,
00095 leda_node_array<leda_point> &posArray,
00096 leda_edge_array< leda_list<leda_point> > &bends );
00097
00098 private:
00103 bool bfsLayout(const leda_graph &g,
00104 const leda_node_array<leda_point> &sizes,
00105 leda_point windowSize,
00106 leda_node_array<leda_point> &posArray,
00107 leda_edge_array< leda_list<leda_point> > &bends);
00108 bool gridLayout(const leda_graph &g,
00109 const leda_node_array<leda_point> &sizes,
00110 leda_point windowSize,
00111 leda_node_array<leda_point> &posArray,
00112 leda_edge_array< leda_list<leda_point> > &bends);
00116 bool recTreeLayout(const leda_graph &g,
00117 const leda_node_array<leda_point> &sizes,
00118 leda_point windowSize,
00119 leda_node_array<leda_point> &posArray,
00120 leda_edge_array< leda_list<leda_point> > &bends);
00123 bool sugiyamaLayout(const leda_graph &g,
00124 const leda_node_array<leda_point> &sizes,
00125 leda_point windowSize,
00126 leda_node_array<leda_point> &posArray,
00127 leda_edge_array< leda_list<leda_point> > &bends);
00128
00129 leda_list <leda_string> _layoutAlgs;
00130 };
00131
00132
00133 #endif