2011-10-23 17:52:20 +00:00
|
|
|
/*
|
2012-11-18 00:30:06 +00:00
|
|
|
* ***** BEGIN GPL LICENSE BLOCK *****
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program 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 General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software Foundation,
|
|
|
|
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
*
|
|
|
|
* Contributor(s): Dalai Felinto
|
|
|
|
*
|
|
|
|
* This source uses some of the ideas and code from Paul Bourke.
|
|
|
|
* Developed as part of a Research and Development project for
|
|
|
|
* SAT - La Société des arts technologiques.
|
|
|
|
*
|
|
|
|
* ***** END GPL LICENSE BLOCK *****
|
|
|
|
*/
|
2009-04-20 15:06:46 +00:00
|
|
|
|
2011-02-22 10:33:14 +00:00
|
|
|
/** \file KX_Dome.h
|
|
|
|
* \ingroup ketsji
|
|
|
|
*/
|
|
|
|
|
2012-03-09 18:28:30 +00:00
|
|
|
#ifndef __KX_DOME_H__
|
|
|
|
#define __KX_DOME_H__
|
2009-04-20 15:06:46 +00:00
|
|
|
|
|
|
|
#include "KX_Scene.h"
|
|
|
|
#include "KX_Camera.h"
|
|
|
|
#include "DNA_screen_types.h"
|
|
|
|
#include "RAS_ICanvas.h"
|
|
|
|
#include "RAS_IRasterizer.h"
|
|
|
|
#include "KX_KetsjiEngine.h"
|
|
|
|
|
|
|
|
#include "GL/glew.h"
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
#include "MEM_guardedalloc.h"
|
|
|
|
#include "BKE_text.h"
|
|
|
|
|
|
|
|
//Dome modes: limit hardcoded in buttons_scene.c
|
2009-06-08 20:08:19 +00:00
|
|
|
#define DOME_FISHEYE 1
|
|
|
|
#define DOME_TRUNCATED_FRONT 2
|
|
|
|
#define DOME_TRUNCATED_REAR 3
|
|
|
|
#define DOME_ENVMAP 4
|
|
|
|
#define DOME_PANORAM_SPH 5
|
|
|
|
#define DOME_NUM_MODES 6
|
2009-04-20 15:06:46 +00:00
|
|
|
|
|
|
|
|
|
|
|
/// class for render 3d scene
|
|
|
|
class KX_Dome
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/// constructor
|
2011-10-06 22:04:01 +00:00
|
|
|
KX_Dome (RAS_ICanvas* m_canvas,
|
|
|
|
/// rasterizer
|
|
|
|
RAS_IRasterizer* m_rasterizer,
|
|
|
|
/// engine
|
|
|
|
KX_KetsjiEngine* m_engine,
|
|
|
|
|
|
|
|
short res,
|
|
|
|
short mode,
|
|
|
|
short angle,
|
|
|
|
float resbuf,
|
|
|
|
short tilt,
|
|
|
|
struct Text* warptext
|
|
|
|
);
|
2009-04-20 15:06:46 +00:00
|
|
|
|
|
|
|
/// destructor
|
|
|
|
virtual ~KX_Dome (void);
|
|
|
|
|
|
|
|
//openGL checks:
|
|
|
|
bool dlistSupported;
|
2009-06-08 20:08:19 +00:00
|
|
|
bool fboSupported;
|
2009-04-20 15:06:46 +00:00
|
|
|
|
|
|
|
//openGL names:
|
2012-06-03 11:16:13 +00:00
|
|
|
GLuint domefacesId[7]; /* ID of the images -- room for 7 images, using only 4 for 180deg x 360deg dome,
|
|
|
|
* 6 for panoramic and +1 for warp mesh */
|
|
|
|
GLuint dlistId; /* ID of the Display Lists of the images (used as an offset) */
|
2009-04-20 15:06:46 +00:00
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
double u[3], v[3];
|
|
|
|
MT_Vector3 verts[3]; //three verts
|
|
|
|
} DomeFace;
|
|
|
|
|
|
|
|
//mesh warp functions
|
|
|
|
typedef struct {
|
|
|
|
double x, y, u, v, i;
|
|
|
|
} WarpMeshNode;
|
|
|
|
|
|
|
|
struct {
|
|
|
|
bool usemesh;
|
|
|
|
int mode;
|
|
|
|
int n_width, n_height; //nodes width and height
|
2009-06-08 20:08:19 +00:00
|
|
|
int imagesize;
|
2009-04-20 15:06:46 +00:00
|
|
|
int bufferwidth, bufferheight;
|
2009-06-08 20:08:19 +00:00
|
|
|
GLuint fboId;
|
2009-04-20 15:06:46 +00:00
|
|
|
vector <vector <WarpMeshNode> > nodes;
|
|
|
|
} warp;
|
|
|
|
|
|
|
|
bool ParseWarpMesh(STR_String text);
|
|
|
|
|
|
|
|
vector <DomeFace> cubetop, cubebottom, cuberight, cubeleft, cubefront, cubeback; //for fisheye
|
|
|
|
vector <DomeFace> cubeleftback, cuberightback; //for panorama
|
|
|
|
|
|
|
|
int nfacestop, nfacesbottom, nfacesleft, nfacesright, nfacesfront, nfacesback;
|
|
|
|
int nfacesleftback, nfacesrightback;
|
|
|
|
|
2012-03-08 03:05:57 +00:00
|
|
|
int GetNumberRenders() { return m_numfaces; }
|
2009-04-20 15:06:46 +00:00
|
|
|
|
|
|
|
void RenderDome(void);
|
|
|
|
void RenderDomeFrame(KX_Scene* scene, KX_Camera* cam, int i);
|
|
|
|
void BindImages(int i);
|
|
|
|
|
2012-10-08 03:28:11 +00:00
|
|
|
void SetViewPort(const int viewport[4]);
|
2009-04-20 15:06:46 +00:00
|
|
|
void CalculateFrustum(KX_Camera* cam);
|
|
|
|
void RotateCamera(KX_Camera* cam, int i);
|
|
|
|
|
2009-06-08 20:08:19 +00:00
|
|
|
//Mesh creation Functions
|
2009-04-20 15:06:46 +00:00
|
|
|
void CreateMeshDome180(void);
|
|
|
|
void CreateMeshDome250(void);
|
|
|
|
void CreateMeshPanorama(void);
|
|
|
|
|
|
|
|
void SplitFace(vector <DomeFace>& face, int *nfaces);
|
|
|
|
|
|
|
|
void FlattenDome(MT_Vector3 verts[3]);
|
|
|
|
void FlattenPanorama(MT_Vector3 verts[3]);
|
|
|
|
|
|
|
|
//Draw functions
|
|
|
|
void GLDrawTriangles(vector <DomeFace>& face, int nfaces);
|
|
|
|
void GLDrawWarpQuads(void);
|
|
|
|
void Draw(void);
|
|
|
|
void DrawDomeFisheye(void);
|
2009-06-08 20:08:19 +00:00
|
|
|
void DrawEnvMap(void);
|
2009-04-20 15:06:46 +00:00
|
|
|
void DrawPanorama(void);
|
|
|
|
void DrawDomeWarped(void);
|
|
|
|
|
|
|
|
//setting up openGL
|
|
|
|
void CreateGLImages(void);
|
|
|
|
void ClearGLImages(void);//called on resize
|
|
|
|
bool CreateDL(void); //create Display Lists
|
|
|
|
void ClearDL(void); //remove Display Lists
|
2009-06-08 20:08:19 +00:00
|
|
|
bool CreateFBO(void);//create FBO (for warp mesh)
|
|
|
|
void ClearFBO(void); //remove FBO
|
2009-04-20 15:06:46 +00:00
|
|
|
|
|
|
|
void CalculateCameraOrientation();
|
|
|
|
void CalculateImageSize(); //set m_imagesize
|
|
|
|
|
|
|
|
int canvaswidth;
|
|
|
|
int canvasheight;
|
|
|
|
|
|
|
|
protected:
|
|
|
|
int m_drawingmode;
|
|
|
|
|
|
|
|
int m_imagesize;
|
|
|
|
int m_buffersize; // canvas small dimension
|
|
|
|
int m_numfaces; // 4 to 6 depending on the kind of dome image
|
|
|
|
int m_numimages; //numfaces +1 if we have warp mesh
|
2009-06-08 20:08:19 +00:00
|
|
|
|
2012-03-20 22:56:26 +00:00
|
|
|
short m_resolution; //resolution to tessellate the mesh
|
2009-04-20 15:06:46 +00:00
|
|
|
short m_mode; // the mode (truncated, warped, panoramic,...)
|
|
|
|
short m_angle; //the angle of the fisheye
|
|
|
|
float m_radangle; //the angle of the fisheye in radians
|
|
|
|
float m_resbuffer; //the resolution of the buffer
|
2009-06-08 20:08:19 +00:00
|
|
|
short m_tilt; //the dome tilt (camera rotation on horizontal axis)
|
2009-04-20 15:06:46 +00:00
|
|
|
|
|
|
|
RAS_Rect m_viewport;
|
|
|
|
|
|
|
|
MT_Matrix4x4 m_projmat;
|
|
|
|
|
2012-04-12 00:15:02 +00:00
|
|
|
MT_Matrix3x3 m_locRot[6]; // the rotation matrix
|
2009-04-20 15:06:46 +00:00
|
|
|
|
|
|
|
/// rendered scene
|
|
|
|
KX_Scene * m_scene;
|
|
|
|
|
2011-10-06 22:04:01 +00:00
|
|
|
/// canvas
|
|
|
|
RAS_ICanvas* m_canvas;
|
|
|
|
/// rasterizer
|
|
|
|
RAS_IRasterizer* m_rasterizer;
|
|
|
|
/// render tools
|
|
|
|
RAS_IRenderTools* m_rendertools;
|
|
|
|
/// engine
|
|
|
|
KX_KetsjiEngine* m_engine;
|
2009-08-18 15:37:31 +00:00
|
|
|
|
|
|
|
|
|
|
|
#ifdef WITH_CXX_GUARDEDALLOC
|
2012-06-25 09:14:37 +00:00
|
|
|
MEM_CXX_CLASS_ALLOC_FUNCS("GE:KX_Dome")
|
2009-08-18 15:37:31 +00:00
|
|
|
#endif
|
2009-04-20 15:06:46 +00:00
|
|
|
};
|
|
|
|
|
2012-03-09 18:28:30 +00:00
|
|
|
#endif /* __KX_DOME_H__ */
|