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