viewer.h 3.96 KB
Newer Older
Pierre Kraemer's avatar
Pierre Kraemer committed
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
/*******************************************************************************
* CGoGN: Combinatorial and Geometric modeling with Generic N-dimensional Maps  *
* version 0.1                                                                  *
* Copyright (C) 2009, IGG Team, LSIIT, University of Strasbourg                *
*                                                                              *
* This library is free software; you can redistribute it and/or modify it      *
* under the terms of the GNU Lesser General Public License as published by the *
* Free Software Foundation; either version 2.1 of the License, or (at your     *
* option) any later version.                                                   *
*                                                                              *
* This library is distributed in the hope that it will be useful, but WITHOUT  *
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or        *
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License  *
* for more details.                                                            *
*                                                                              *
* You should have received a copy of the GNU Lesser General Public License     *
* along with this library; if not, write to the Free Software Foundation,      *
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301 USA.           *
*                                                                              *
* Web site: https://iggservis.u-strasbg.fr/CGoGN/                              *
* Contact information: cgogn@unistra.fr                                        *
*                                                                              *
*******************************************************************************/

#include <iostream>

27
#include "Utils/Qt/qtSimple.h"
Pierre Kraemer's avatar
Pierre Kraemer committed
28
#include "ui_viewer.h"
29
#include "Utils/Qt/qtui.h"
Pierre Kraemer's avatar
Pierre Kraemer committed
30
31

#include "Topology/generic/parameters.h"
32
#include "Topology/map/embeddedMap2.h"
Pierre Kraemer's avatar
Pierre Kraemer committed
33
34
35
36
37

#include "Geometry/vector_gen.h"
#include "Geometry/matrix.h"

#include "Algo/Import/import.h"
38
#include "Algo/Export/export.h"
Pierre Kraemer's avatar
Pierre Kraemer committed
39
40
41

#include "Algo/Render/GL2/mapRender.h"

Kenneth Vanhoey's avatar
merge    
Kenneth Vanhoey committed
42
43
44
45
#include "Utils/Shaders/shaderPhong.h"
#include "Utils/Shaders/shaderFlat.h"
#include "Utils/Shaders/shaderSimpleColor.h"
#include "Utils/Shaders/shaderVectorPerVertex.h"
Pierre Kraemer's avatar
Pierre Kraemer committed
46
#include "Utils/pointSprite.h"
47
#include "Utils/text3d.h"
Pierre Kraemer's avatar
Pierre Kraemer committed
48
49
50
51
52
53
54
55
56

#include "Algo/Geometry/boundingbox.h"
#include "Algo/Geometry/normal.h"

using namespace CGoGN ;

struct PFP: public PFP_STANDARD
{
	// definition of the map
57
	typedef EmbeddedMap2 MAP ;
Pierre Kraemer's avatar
Pierre Kraemer committed
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
};

typedef PFP::MAP MAP ;

class Viewer : public Utils::QT::SimpleQT
{
	Q_OBJECT

public:
	MAP myMap ;

    Utils::QT::uiDockInterface dock ;

	enum renderMode { FLAT, PHONG } ;

	Geom::Vec4f colDif ;
	Geom::Vec4f colSpec ;
	Geom::Vec4f colClear ;
	Geom::Vec4f colNormal ;

	float shininess ;

80
	Geom::BoundingBox<PFP::VEC3> bb ;
Pierre Kraemer's avatar
Pierre Kraemer committed
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
	float normalBaseSize ;
	float normalScaleFactor ;
	float vertexBaseSize ;
	float vertexScaleFactor ;
	float faceShrinkage ;

	int m_renderStyle ;
	bool m_drawVertices ;
	bool m_drawEdges ;
	bool m_drawFaces ;
	bool m_drawNormals ;

	PFP::TVEC3 position ;
	PFP::TVEC3 normal ;

	Algo::Render::GL2::MapRender* m_render ;

	Utils::VBO* m_positionVBO ;
	Utils::VBO* m_normalVBO ;

	Utils::ShaderPhong* m_phongShader ;
	Utils::ShaderFlat* m_flatShader ;
	Utils::ShaderVectorPerVertex* m_vectorShader ;
	Utils::ShaderSimpleColor* m_simpleColorShader ;
	Utils::PointSprite* m_pointSprite ;
106
	Utils::Strings3D* m_strings;
Pierre Kraemer's avatar
Pierre Kraemer committed
107
108
109
110
111
112
113
114

	Viewer() ;

	void initGUI() ;

	void cb_initGL() ;
	void cb_redraw() ;
	void cb_Open() ;
115
	void cb_Save() ;
Pierre Kraemer's avatar
Pierre Kraemer committed
116
117

	void importMesh(std::string& filename) ;
118
119
120
121
122
	void exportMesh(std::string& filename);

protected:
	void storeVerticesInfo();

Pierre Kraemer's avatar
Pierre Kraemer committed
123
124
125
126
127
128
129
130
131
132
133

public slots:
	void slot_drawVertices(bool b) ;
	void slot_verticesSize(int i) ;
	void slot_drawEdges(bool b) ;
	void slot_drawFaces(bool b) ;
	void slot_faceLighting(int i) ;
	void slot_drawNormals(bool b) ;
	void slot_normalsSize(int i) ;
};