source: GTP/trunk/Lib/Geom/shared/GeoTool/include/GeoMeshViewUI.h @ 2090

Revision 2090, 13.4 KB checked in by gumbau, 17 years ago (diff)
Line 
1// generated by Fast Light User Interface Designer (fluid) version 2.0100
2#ifndef GeoMeshViewUI_h
3#define GeoMeshViewUI_h
4#include "GL/glew.h"
5#ifdef _WIN32
6#include "GL/wglew.h"
7#endif
8#include        <stdio.h>
9#include        <stdlib.h>
10#include        <string.h>
11#include        <fltk/run.h>
12#include        <fltk/Group.h>
13#include        <fltk/Window.h>
14#include        <fltk/ask.h>
15#include        <fltk/file_chooser.h>
16#include        <fltk/FileChooser.h>
17#include        <fltk/MenuBar.h>
18#include        <fltk/Input.h>
19#include        <fltk/Button.h>
20#include        <fltk/ReturnButton.h>
21#include        <fltk/TextBuffer.h>
22#include        <fltk/TextEditor.h>
23#include        <fltk/Input.h>
24#include        <fltk/events.h>
25#include        <fltk/InvisibleBox.h>
26#include        <fltk/ItemGroup.h>
27#include        <fltk/Item.h>
28#include        <fltk/Divider.h>
29#include        <fltk/Output.h>
30#include        <fltk/Button.h>
31#include        <fltk/ProgressBar.h>
32#include        <fltk/CheckButton.h>
33#include        <fltk/RadioButton.h>
34#include        <fltk/FloatInput.h>
35#include        <fltk/Browser.h>
36#include        <fltk/Image.h>
37#include        <fltk/SharedImage.h>
38#include        <fltk/Slider.h>
39#include        <GeoMesh.h>
40#include        <GeoLodStripsLibrary.h>
41#include        <GeoMeshView.h>
42#include        <GeoMeshSaver.h>
43#include        <GeoMeshSimplifier.h>
44#include        <GeoMeshStripifier.h>
45#include        <GeoTreeSimplifier.h>
46#include        "GeoTreeSimpSequence.h"
47#include        "GeoLodStripsConstructor.h"
48#include        "GeoLodTreeLibrary.h"
49
50//      About Dialog.
51#include "GTAboutDialog.h"
52#include        "../resource.h"
53
54#include        <GeoMaterialLoader.h>
55
56//      State of the button process.
57enum    ProcessState
58{
59        NONE,
60        STRIPIFY,
61        EDGE_COLLAPSE,
62        LEAVES_COLLAPSE,
63        LODSTRIPS,
64        LODSTRIPS_AUTO,
65        LODTREES,
66        LODTREES_AUTO,
67        SELECT_LEAVES,
68        VISUALIZE_LODSTRIPS,
69        VISUALIZE_LODTREES
70};
71
72// Simplification types
73enum    SimplificationType
74{
75        NO_SIMPLIFICATION,
76        MESHSIMP,
77        HOJAS,
78        VIEWPOINTDRIVEN
79};
80
81enum    ProgressBarType
82{
83        PROCESS,
84        BUILD
85};
86
87using   namespace       Geometry;
88using   namespace       std;
89
90//-----------------------------------------------------------------------------
91//-----------------------------------------------------------------------------
92class GeoToolIndexData : public Geometry::IndexData
93{
94        public:
95                GeoToolIndexData(unsigned int submeshes):Geometry::IndexData(){
96                        submeshcount = submeshes;
97                        indices=new unsigned int*[submeshcount];
98                        indexCount=new unsigned int[submeshcount];
99                        for (int i=0; i<submeshcount; i++)
100                        {
101                                indices[i]=NULL;
102                                indexCount[i]=0;
103                        }
104                }
105                virtual ~GeoToolIndexData(void){
106                        for (int i=0; i<submeshcount; i++)
107                                if (indices[i])
108                                        delete[] indices[i];
109                        delete[] indices;
110                        delete[] indexCount;
111                }
112
113                virtual void Begin(unsigned int submesh, unsigned int numinds){
114                        if (indices[submesh])           
115                                delete[] indices[submesh];
116                        indices[submesh] = new unsigned int[numinds];     
117                        indexCount[submesh] = numinds;
118                        modifySubmesh=submesh;
119                }
120
121        virtual void SetIndex(unsigned int i, unsigned int index){
122                assert(i<indexCount[modifySubmesh]);
123                indices[modifySubmesh][i] = index;
124        }
125
126                virtual void End(void){}
127                virtual void BorrowIndexData(const IndexData *){}
128
129                unsigned int submeshcount;
130                unsigned int **indices;
131                unsigned int *indexCount;
132                unsigned int modifySubmesh;
133};
134
135//-----------------------------------------------------------------------------
136//      Class User Interface of GeoTool.
137//-----------------------------------------------------------------------------
138class GeoMeshViewUI
139{
140        friend  class   GeoMeshView;
141
142        private:
143
144        //      File name Selected.
145        char    *mFileName;
146
147        //      The state of the application menus.
148        ProcessState    mApplicationState;
149
150        //      Mesh object(Model).
151        Mesh    *mGeoMesh;
152
153        //      Mesh for undo operation.
154        Mesh    *mUndoMesh;
155
156        //      Lod strips object.
157        LodStripsLibrary        *lodStripsLib;
158        //      Lod tree object.
159        LodTreeLibrary  *lodTreeLib;
160
161        MeshSimplifier                  *mMeshSimplifier;
162        TreeSimplifier                  *mTreeSimplifier;
163        char                                                            *nombremesh;
164        SimplificationType      simplificationState;
165        ProgressBarType                 progressBarType;
166
167        MeshSimplificationSequence      *oMeshSimpSequence;
168        LodStripsConstructor                            *oLodStrip;
169        GeoMeshLoader                                                           *geoMeshLoader;
170
171        inline void cb_menuFileOpen_i(fltk::Item*, void*);
172        static void cb_menuFileOpen(fltk::Item*, void*);
173        inline void cb_menuFileSave_i(fltk::Item*, void*);
174        static void cb_menuFileSave(fltk::Item*, void*);
175        inline void cb_menuFileSaveAs_i(fltk::Item*, void*);
176        static void cb_menuFileSaveAs(fltk::Item*, void*);
177        inline void cb_menuFileLoadTexture_i(fltk::Item*, void*);
178        static void cb_menuFileLoadTexture(fltk::Item*, void*);
179        inline void cb_menuFileLoadTextureSubMesh_i(fltk::Item*, void*);
180        static void cb_menuFileLoadTextureSubMesh(fltk::Item*, void*);
181
182        inline void cb_menuMeshInfo_i(fltk::Item*, void*);
183        static void cb_menuMeshInfo(fltk::Item*, void*);
184        inline void cb_menuMeshExportOBJ_i(fltk::Item*, void*);
185        static void cb_menuMeshExportOBJ(fltk::Item*, void*);
186        inline void cb_menuTransformSharedVertex_i(fltk::Item*, void*);
187        static void     cb_menuFileTransformSharedVertex(fltk::Item* o, void* v);
188
189        inline void cb_menuFileQuit_i(fltk::Item*, void*);
190        static void cb_menuFileQuit(fltk::Item*, void*);
191        inline void cb_menuEditUndo_i(fltk::Item*, void*);
192        static void cb_menuEditUndo(fltk::Item*, void*);
193        inline void cb_menuEditFit_i(fltk::Item*, void*);
194        static void cb_menuEditFit(fltk::Item*, void*);
195        inline void cb_menuEditRotate_i(fltk::Item*, void*);
196        static void cb_menuEditRotate(fltk::Item*, void*);
197        inline void cb_menuEditPan_i(fltk::Item*, void*);
198        static void cb_menuEditPan(fltk::Item*, void*);
199        inline void cb_menuEditZoom_i(fltk::Item*, void*);
200        static void cb_menuEditZoom(fltk::Item*, void*);
201        inline void cb_menuRenderWire_i(fltk::Item*, void*);
202        static void cb_menuRenderWire(fltk::Item*, void*);
203        inline void cb_menuRenderSolid_i(fltk::Item*, void*);
204        static void cb_menuRenderSolid(fltk::Item*, void*);
205        inline void cb_menuRenderLighting_i(fltk::Item*, void*);
206        static void cb_menuRenderLighting(fltk::Item*, void*);
207        inline void cb_menuRenderCW_i(fltk::Item*, void*);
208        static void cb_menuRenderCW(fltk::Item*, void*);
209        inline void cb_menuRenderCCW_i(fltk::Item*, void*);
210        static void cb_menuRenderCCW(fltk::Item*, void*);
211        inline void cb_menuRenderFlat_i(fltk::Item*, void*);
212        static void cb_menuRenderFlat(fltk::Item*, void*);
213        inline void cb_menuRenderSmooth_i(fltk::Item*, void*);
214        static void cb_menuRenderSmooth(fltk::Item*, void*);
215        inline void cb_menuRenderTextures_i(fltk::Item*, void*);
216        static void cb_menuRenderTextures(fltk::Item*, void*);
217        inline void cb_menuStripify_i(fltk::Item*, void*);
218        static void cb_menuStripify(fltk::Item*, void*);
219        inline void cb_menuSimplify_i(fltk::ItemGroup*, void*);
220        static void cb_menuSimplify(fltk::ItemGroup*, void*);
221        inline void cb_menuSimplifyEdgeCollapse_i(fltk::Item*, void*);
222        static void cb_menuSimplifyEdgeCollapse(fltk::Item*, void*);
223        inline void cb_menuSimplifyLeavesCollapse_i(fltk::Item*, void*);
224        static void cb_menuSimplifyLeavesCollapse(fltk::Item*, void*);
225
226        inline void cb_menuLodStripsGenerate_i(fltk::Item*, void*);
227        static void cb_menuLodStripsGenerate(fltk::Item*, void*);
228        inline void cb_menuLodStripsVisualize_i(fltk::Item*, void*);
229        static void cb_menuLodStripsVisualize(fltk::Item*, void*);
230
231        inline void cb_menuSelectLeaves_i(fltk::Item*, void*);
232        static void cb_menuSelectLeaves(fltk::Item*, void*);
233        inline void cb_menuLodTreesOpenLodStripTrunk_i(fltk::Item*, void*);
234        static void cb_menuLodTreesOpenLodStripTrunk(fltk::Item*, void*);
235        inline void cb_menuLodTreesOpenLeavesSimplification_i(fltk::Item*, void*);
236        static void cb_menuLodTreesOpenLeavesSimplification(fltk::Item*, void*);
237        inline void cb_menuLodTreesGenerate_i(fltk::Item*, void*);
238        static void cb_menuLodTreesGenerate(fltk::Item*, void*);
239        inline void cb_menuLodTreesVisualize_i(fltk::Item*, void*);
240        static void cb_menuLodTreesVisualize(fltk::Item*, void*);
241        inline void cb_menuHelpAbout_i(fltk::Item*, void*);
242        static void cb_menuHelpAbout(fltk::Item*, void*);
243
244        inline void cb_mButtonProcess_i(fltk::Button*, void*);
245        static void cb_mButtonProcess(fltk::Button*, void*);
246        inline void cb_mButtonSort_i(fltk::Button*, void*);
247        static void cb_mButtonSort(fltk::Button*, void*);
248        inline void cb_mButtonBuild_i(fltk::Button*, void*);
249        static void cb_mButtonBuild(fltk::Button*, void*);
250        inline void cb_mMeshInfo_i(fltk::Browser*, void*);
251        static void cb_mMeshInfo(fltk::Browser*, void*);
252        inline void cb_mLodStripSlider_i(fltk::Slider*, void*);
253        static void cb_mLodStripSlider(fltk::Slider*, void*);
254        inline void cb_mLodTreeSlider_i(fltk::Slider*, void*);
255        static void cb_mLodTreeSlider(fltk::Slider*, void*);
256
257        //      Logo's callback.
258        inline void cb_mLogo_i(fltk::InvisibleBox*, void*);
259        static void cb_mLogo(fltk::InvisibleBox*, void*);
260
261        //      Shows build process.
262        void    activeBuildProcess();
263
264        //      Shows the stripify panel.
265        void    showStripify();
266
267        //      Shows the simplify panels.
268        void    showEdgeCollapse();
269        void    showLeavesCollapse();
270
271        //      Shows the LodStrips panels.
272        void    showOpenMeshSimplification();
273        void    showAutoGenerateLodStrips();
274        void    showAutoGenerateLodTrees();
275
276        //      Shows the LodTrees panel.
277        void    showOpenLeavesSimplification();
278
279        //      Show the mesh info browser.
280        void    showMeshInfo();
281       
282        //      Show the LodStrips visulization panel.
283        void    showLodStripSlider();
284        void    showLodTreeSlider();
285
286        void    hideStripify();
287        void    hideEdgeCollapse();
288        void    hideLeavesCollapse();
289        void    hideOpenMeshSimplification();
290        void    hideOpenLeavesSimplification();
291        void    hideRightPanel();
292        //      Hide the mesh info browser.
293        void    hideMeshInfo();
294
295        //      Hide the LodStrips visualization panel.
296        void    hideLodStripSlider();
297        void    hideLodTreeSlider();
298       
299        //      Get the number of vertices.
300        size_t  getVertexCount(Mesh     *geoMesh);
301
302        //      Get the number of triangles.
303        size_t  getTriangleCount(Mesh   *geoMesh);
304
305        //      Get the number of strips.
306        size_t  getStripCount(Mesh      *geoMesh);
307
308        int             paintMesh();
309
310        //      Simplify the mesh object.
311        bool    simplifyEdgeCollapse();
312
313        //      Simplify the mesh object.
314        void    simplifyLeavesCollapse();
315
316        //      Create a siplification sequence of the simplification method.
317        void    createSimplificationSequence();
318
319        //      Create a siplification sequence of the leaves.
320        void    createLeavesSequence(const std::string &);
321
322        //      Stripify the mesh object.
323        void    stripify();
324
325        //      Method that undo then mesh changes.
326        void    undo();
327
328        //      Refresh number of vertices, triangles, strips, ...
329        void    refreshApplicationBar();
330
331        //      Open a mesh file.
332        void    openMeshFile(void);
333
334        //      Check if file exists.
335        bool    fileExists(const char   *fileNameMesh);
336
337        //      Set textures to mesh model.
338        void setTextures();
339
340        public:
341
342        // the indexdata for the LOD models
343        GeoToolIndexData *lod_index_data;
344
345        GeoMeshView                                     *geoMeshView;
346        fltk::Window                            *mMainWindow;
347        fltk::Group                                     *MainView;
348        fltk::InvisibleBox      *cframe;
349        fltk::MenuBar                           *menuBar;
350        fltk::ItemGroup                 *menuFile;
351        fltk::Item                                      *menuFileOpen;
352        fltk::Item                                      *menuFileSave;
353        fltk::Item                                      *menuFileSaveAs;
354        fltk::Item                                      *menuMeshInfo;
355        fltk::Item                                      *menuMeshExportOBJ;
356        fltk::Item                                      *menuFileTransformSharedVertex;
357        fltk::ItemGroup                 *menuLoadTextures;
358        fltk::Item                                      *menuFileLoadTexture;
359
360        fltk::Item                                      *menuFileQuit;
361        fltk::ItemGroup                 *menuEdit;
362        fltk::Item                                      *menuEditUndo;
363        fltk::Item                                      *menuEditFit;
364        fltk::Item                                      *menuEditRotate;
365        fltk::Item                                      *menuEditPan;
366        fltk::Item                                      *menuEditZoom;
367        fltk::ItemGroup                 *menuRender;
368        fltk::Item                                      *menuRenderWire;
369        fltk::Item                                      *menuRenderSolid;
370        fltk::Item                                      *menuRenderLighting;
371        fltk::Item                                      *menuRenderCW;
372        fltk::Item                                      *menuRenderCCW;
373        fltk::Item                                      *menuRenderFlat;
374        fltk::Item                                      *menuRenderSmooth;
375        fltk::Item                                      *menuRenderTextures;
376        fltk::Item                                      *menuStripify;
377        fltk::ItemGroup                 *menuSimplify;
378        fltk::Item                                      *menuSimplifyEdgeCollapse;
379        fltk::Item                                      *menuSimplifyLeavesCollapse;
380        fltk::Item                                      *menuSimplifySaveSequence;
381
382        fltk::ItemGroup                 *menuLodStrips;
383        fltk::Item                                      *menuLodStripsGenerate;
384        fltk::Item                                      *menuLodStripsVisualize;
385        fltk::ItemGroup                 *menuLodTrees;
386        fltk::Item                                      *menuLodTreesGenerate;
387        fltk::Item                                      *menuLodTreesVisualize;
388
389        fltk::Item                                      *menuSelectLeaves;
390        fltk::Item                                      *menuLodTreesOpenLodStripTrunk;
391        fltk::Item                                      *menuLodTreesOpenLeavesSimplification;
392        fltk::Item                                      *menuHelpAbout;
393        fltk::InvisibleBox      *mLogo;
394        fltk::Group                                     *ApplicationBar;
395        fltk::Widget                            *mFPS;
396        fltk::Widget                            *mVertices;
397        fltk::Widget                            *mTriangles;
398        fltk::Widget                            *mStrips;
399        fltk::Widget                            *mQuads;
400        fltk::Widget                            *mMB;
401        fltk::Button                            *mButtonProcess;
402        fltk::ProgressBar               *mProcessBar;
403        fltk::Button                            *mButtonSort;
404        fltk::ProgressBar               *mSortBar;
405        fltk::Button                            *mButtonBuild;
406        fltk::ProgressBar               *mBuildBar;
407        fltk::Slider                            *mLodStripSlider;
408        fltk::Slider                            *mLodTreeSlider;
409        fltk::CheckButton               *mGeometryBased;
410        fltk::CheckButton               *mViewPointDriven;
411        fltk::CheckButton               *mChangeVertices;
412        fltk::CheckButton               *mChangeTexture;
413        fltk::CheckButton               *mPercent;
414        fltk::CheckButton               *mVerticesNumber;
415        fltk::CheckButton               *mOneCacheStrip;
416        fltk::CheckButton               *mQualityStrips;
417        fltk::FloatInput                *mMeshReduction;
418        fltk::Widget                            *mProcessTitle;
419        fltk::Output                            *mMetricLabel;
420        fltk::Output                            *mTypeLabel;
421        fltk::Output                            *mMeshReductionLabel;
422        fltk::Browser                           *mMeshInfo;
423        fltk::ItemGroup                 *ogeometry;
424
425        //      Repaint the FPS label.
426        void    refreshFPS(int fps);
427
428        //      Initialize the lodstripslibrary for visualization.
429        void    setLodStripsLibrary(const Geometry::LodStripsLibraryData *, Mesh        *geomesh);
430        //      Initialize the lodtreelibrary for visualization.
431        void    setLodTreesLibrary(const Geometry::LodStripsLibraryData *, const Geometry::TreeSimplificationSequence *, Mesh   *geomesh/*, uint32 ileafSubMesh*/);
432
433        // Indentify the mesh of leaves.
434        unsigned        short                   idMeshLeaves;
435
436        GeoMeshViewUI(TIPOFUNC fun=NULL);
437        ~GeoMeshViewUI();
438        void show();
439
440        TIPOFUNC progress_function;
441        float updateProgressBar(float);
442
443        void BuildLoadTextureSubMeshMenu(void);
444        int numSubMeshNames;
445        char **SubMeshNames;
446};
447
448#endif
449
Note: See TracBrowser for help on using the repository browser.