pointSprite.h 3.8 KB
Newer Older
1 2 3
/*******************************************************************************
 * CGoGN: Combinatorial and Geometric modeling with Generic N-dimensional Maps  *
 * version 0.1                                                                  *
4
 * Copyright (C) 2009-2012, IGG Team, LSIIT, University of Strasbourg           *
5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
 *                                                                              *
 * 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.           *
 *                                                                              *
20
 * Web site: http://cgogn.unistra.fr/                                           *
21 22 23 24 25 26 27 28 29 30 31 32 33 34
 * Contact information: cgogn@unistra.fr                                        *
 *                                                                              *
 *******************************************************************************/

#ifndef __POINT_SPRITE_3D__
#define __POINT_SPRITE_3D__

#include "Utils/GLSLShader.h"
#include "Geometry/vector_gen.h"

namespace CGoGN { namespace Utils { class VBO; } }

namespace CGoGN
{
35

36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51
namespace Utils
{

class PointSprite: public Utils::GLSLShader
{
protected:
	static const unsigned int WIDTHSPRITE = 64;

	static std::string vertexShaderText;

	static std::string geometryShaderText;

	static std::string fragmentShaderText;

	static unsigned char* m_ptrSphere;

52 53
	static PointSprite* m_instance0;

54 55 56
	// compute the sphere instead of storing it in image file.
	static void computeSphere();

57 58 59 60 61
	CGoGNGLuint m_uniform_size;

	CGoGNGLuint m_uniform_color;

	CGoGNGLuint m_idTexture;
62

63
	CGoGNGLuint m_uniform_texture;
Sylvain's avatar
Sylvain committed
64
	
65
	CGoGNGLuint m_uniform_EyePos;
Sylvain's avatar
Sylvain committed
66
	
Sylvain Thery's avatar
Sylvain Thery committed
67
//	CGoGNGLuint m_uniform_EyeY;
68 69 70 71

	CGoGNGLuint m_uniform_ambiant;

	CGoGNGLuint m_uniform_lightPos;
Pierre Kraemer's avatar
Pierre Kraemer committed
72

73 74 75
public:
	/**
	 * init shaders, texture and variables
Thery Sylvain's avatar
Thery Sylvain committed
76 77
	 * @param withColorPerVertex if true use setAttributeColor for per vertex color, else use predraw(color) for global color
	 * @param radius of sphere
78
	 */
79

Sylvain's avatar
Sylvain committed
80
	PointSprite(bool withColorPerVertex=false, float radius=1.0f, bool with_plane=false);
81 82 83 84 85 86 87 88

	/**
	 * clean shaders, texture and variables
	 */
	~PointSprite();

	/**
	 * call once before sending points to gpu
Thery Sylvain's avatar
Thery Sylvain committed
89
	 * @param color set global color of sprites
90
	 */
91
	void predraw(const Geom::Vec4f& color);
92

93 94 95 96 97
	/**
	 * call once before sending points to gpu
	 */
	void predraw();

98 99 100 101 102 103 104 105 106 107
	/**
	 * call once after sending points to gpu
	 */
	void postdraw();

	/**
	 * set the radius of sphere
	 * @param radius
	 */
	void setSize(float radius);
Sylvain's avatar
Sylvain committed
108 109 110 111
	
	/**
	* set the plane of rendering for VR rendering
	*/
Sylvain Thery's avatar
Sylvain Thery committed
112
	void setEyePosition(const Geom::Vec3f& ep);
Sylvain's avatar
Sylvain committed
113

114 115 116 117 118 119

	/**
	 * set position attribute
	 */
	unsigned int setAttributePosition(VBO* vbo);

120
	/**
Thery Sylvain's avatar
Thery Sylvain committed
121
	 * set color attribute
122 123
	 */
	unsigned int setAttributeColor(VBO* vbo);
124 125 126 127 128 129


	void setLightPosition(const Geom::Vec3f& pos);

	void setAmbiantColor(const Geom::Vec3f& amb);

130
};
131

132 133 134
} // namespace Utils

} // namespace CGoGN
135
#endif