00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019 #ifndef __SEGMENT_VIEWER_H__
00020 #define __SEGMENT_VIEWER_H__
00021
00022 #include <QtGui/QtGui>
00023
00024 #include <fstream>
00025 #include <string>
00026 #include <exception>
00027
00028 #include <QtGui/QtGui>
00029 #include <QGLWidget>
00030
00031 #include "base_viewer.h"
00032 #include "../lib/segmentation/efficient/efficient.h"
00033 #include "../lib/segmentation/segment.h"
00034 #include "../lib/mesh/mesh_sequence.h"
00035 #include "../lib/segmentation/timesegmentation.h"
00036 #include "../lib/segmentation/TimeSegmentation/dummytimesegmentation.h"
00037 #include "../lib/utils/utils.h"
00038
00039 namespace ViewerNS {
00040
00046 class SegmentViewer: public BaseViewer {
00047 Q_OBJECT
00048 public:
00053 SegmentViewer(MeshNS::MeshSequencePtr *mesh, QWidget* parent = 0);
00054
00055 public slots:
00059 void load(const QString& basename M_UNUSED) {
00060 _first = 0;
00061 _last = (*_dmesh)->size() - 1;
00062 _current = 0;
00063 _has_changed = true;
00064 }
00065
00071 void changeSegmentation(SegmentationNS::SegmentationPtr seg, bool update= true) {
00072 _segment = seg;
00073
00074 changeCluster(_nbCluster, update);
00075 }
00076
00082 void changeCluster(int nb, bool update = true) {
00083 _nbCluster = nb;
00084 if (_segment) {
00085 _segment->setNbCluster(nb);
00086 if (update)
00087 _segment->segment();
00088 }
00089 _has_changed = true;
00090 updateGL();
00091 }
00092
00093 void shouldUpdate() {
00094 _has_changed = true;
00095 updateGL();
00096 }
00097
00102 SegmentationNS::SegmentationPtr getSegmentation() {
00103 return _segment;
00104 }
00105
00106 protected:
00107 void draw();
00108 void animate();
00109
00110 private:
00111 bool _has_changed;
00112 int _nbCluster;
00113 MeshNS::MeshSequencePtr *_dmesh;
00114 SegmentationNS::SegmentationPtr _segment;
00115 int _first, _last, _current;
00116 };
00117 }
00118 #endif