2002-10-12 11:37:38 +00:00
|
|
|
/**
|
|
|
|
* $Id$
|
|
|
|
*
|
|
|
|
* ***** BEGIN GPL/BL DUAL 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. The Blender
|
|
|
|
* Foundation also sells licenses for use in proprietary software under
|
|
|
|
* the Blender License. See http://www.blender.org/BL/ for information
|
|
|
|
* about this.
|
|
|
|
*
|
|
|
|
* 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
|
|
*
|
|
|
|
* The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* The Original Code is: all of this file.
|
|
|
|
*
|
|
|
|
* Contributor(s): none yet.
|
|
|
|
*
|
|
|
|
* ***** END GPL/BL DUAL LICENSE BLOCK *****
|
|
|
|
*/
|
|
|
|
#ifndef __RAS_IRASTERIZER
|
|
|
|
#define __RAS_IRASTERIZER
|
|
|
|
|
|
|
|
#ifdef WIN32
|
|
|
|
#pragma warning (disable:4786)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "MT_CmMatrix4x4.h"
|
|
|
|
#include "MT_Matrix4x4.h"
|
|
|
|
|
|
|
|
class RAS_ICanvas;
|
|
|
|
class RAS_IPolyMaterial;
|
|
|
|
#include "RAS_MaterialBucket.h"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 3D rendering device context interface.
|
|
|
|
*/
|
|
|
|
class RAS_IRasterizer
|
|
|
|
{
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
RAS_IRasterizer(RAS_ICanvas* canv){};
|
|
|
|
virtual ~RAS_IRasterizer(){};
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
enum {
|
|
|
|
RAS_RENDER_3DPOLYGON_TEXT = 16384
|
|
|
|
};
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
* Drawing types
|
|
|
|
*/
|
2004-08-10 11:34:12 +00:00
|
|
|
enum DrawType {
|
2002-10-12 11:37:38 +00:00
|
|
|
KX_BOUNDINGBOX = 1,
|
|
|
|
KX_WIREFRAME,
|
|
|
|
KX_SOLID,
|
|
|
|
KX_SHADED,
|
|
|
|
KX_TEXTURED
|
|
|
|
};
|
|
|
|
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
* Valid SetDepthMask parameters
|
|
|
|
*/
|
2004-08-10 11:34:12 +00:00
|
|
|
enum DepthMask {
|
2002-10-12 11:37:38 +00:00
|
|
|
KX_DEPTHMASK_ENABLED =1,
|
2004-02-23 18:46:19 +00:00
|
|
|
KX_DEPTHMASK_DISABLED
|
2002-10-12 11:37:38 +00:00
|
|
|
};
|
|
|
|
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
*/
|
2004-03-22 22:02:18 +00:00
|
|
|
enum {
|
|
|
|
KX_TWOSIDE = 512,
|
|
|
|
KX_LINES = 32768
|
|
|
|
};
|
|
|
|
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
* Stereo mode types
|
|
|
|
*/
|
2004-08-10 11:34:12 +00:00
|
|
|
enum StereoMode {
|
2002-10-12 11:37:38 +00:00
|
|
|
RAS_STEREO_NOSTEREO = 1,
|
|
|
|
RAS_STEREO_QUADBUFFERED,
|
|
|
|
RAS_STEREO_ABOVEBELOW,
|
2004-08-10 11:34:12 +00:00
|
|
|
RAS_STEREO_INTERLACED,
|
|
|
|
RAS_STEREO_ANAGLYPH,
|
2004-10-24 11:03:18 +00:00
|
|
|
RAS_STEREO_SIDEBYSIDE,
|
|
|
|
RAS_STEREO_VINTERLACE,
|
|
|
|
|
|
|
|
RAS_STEREO_MAXSTEREO
|
2002-10-12 11:37:38 +00:00
|
|
|
};
|
2006-02-13 05:45:32 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Texture gen modes.
|
|
|
|
*/
|
|
|
|
enum TexCoGen {
|
|
|
|
RAS_TEXCO_GEN, //< GPU will generate texture coordinates
|
|
|
|
RAS_TEXCO_ORCO, //< Vertex coordinates (object space)
|
|
|
|
RAS_TEXCO_GLOB, //< Vertex coordinates (world space)
|
|
|
|
RAS_TEXCO_UV1, //< UV coordinates
|
|
|
|
RAS_TEXCO_OBJECT, //< Use another object's position as coordinates
|
|
|
|
RAS_TEXCO_LAVECTOR, //< Light vector as coordinates
|
|
|
|
RAS_TEXCO_VIEW, //< View vector as coordinates
|
|
|
|
RAS_TEXCO_STICKY, //< Sticky coordinates
|
|
|
|
RAS_TEXCO_WINDOW, //< Window coordinates
|
|
|
|
RAS_TEXCO_NORM, //< Normal coordinates
|
|
|
|
RAS_TEXTANGENT, //<
|
|
|
|
RAS_TEXCO_DISABLE //< Disable this texture unit (cached)
|
|
|
|
};
|
|
|
|
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
* Render pass identifiers for stereo.
|
|
|
|
*/
|
2004-08-10 11:34:12 +00:00
|
|
|
enum StereoEye {
|
2002-10-12 11:37:38 +00:00
|
|
|
RAS_STEREO_LEFTEYE = 1,
|
2004-02-23 18:46:19 +00:00
|
|
|
RAS_STEREO_RIGHTEYE
|
2002-10-12 11:37:38 +00:00
|
|
|
};
|
|
|
|
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
* SetDepthMask enables or disables writing a fragment's depth value
|
|
|
|
* to the Z buffer.
|
|
|
|
*/
|
2004-08-10 11:34:12 +00:00
|
|
|
virtual void SetDepthMask(DepthMask depthmask)=0;
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
* SetMaterial sets the material settings for subsequent primitives
|
|
|
|
* to be rendered with.
|
|
|
|
* The material will be cached.
|
|
|
|
*/
|
2005-01-16 06:02:06 +00:00
|
|
|
virtual bool SetMaterial(const RAS_IPolyMaterial& mat)=0;
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
* Init initialises the renderer.
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual bool Init()=0;
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
* Exit cleans up the renderer.
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual void Exit()=0;
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
* BeginFrame is called at the start of each frame.
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual bool BeginFrame(int drawingmode, double time)=0;
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
* ClearDepthBuffer clears the depth buffer.
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual void ClearDepthBuffer()=0;
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
* ClearCachingInfo clears the currently cached material.
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual void ClearCachingInfo(void)=0;
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
* EndFrame is called at the end of each frame.
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual void EndFrame()=0;
|
2004-04-11 02:50:02 +00:00
|
|
|
/**
|
2004-04-24 06:40:15 +00:00
|
|
|
* SetRenderArea sets the render area from the 2d canvas
|
2004-04-11 02:50:02 +00:00
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual void SetRenderArea()=0;
|
|
|
|
|
2004-04-11 02:50:02 +00:00
|
|
|
// Stereo Functions
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
* SetStereoMode will set the stereo mode
|
|
|
|
*/
|
2004-08-10 11:34:12 +00:00
|
|
|
virtual void SetStereoMode(const StereoMode stereomode)=0;
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
* Stereo can be used to query if the rasterizer is in stereo mode.
|
|
|
|
* @return true if stereo mode is enabled.
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual bool Stereo()=0;
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
* Sets which eye buffer subsequent primitives will be rendered to.
|
|
|
|
*/
|
2004-08-10 11:34:12 +00:00
|
|
|
virtual void SetEye(const StereoEye eye)=0;
|
2004-10-24 11:03:18 +00:00
|
|
|
virtual StereoEye GetEye()=0;
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
2004-10-24 11:03:18 +00:00
|
|
|
* Sets the distance between eyes for stereo mode.
|
2004-04-24 06:40:15 +00:00
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual void SetEyeSeparation(const float eyeseparation)=0;
|
2004-10-24 11:03:18 +00:00
|
|
|
virtual float GetEyeSeparation() = 0;
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
2004-10-24 11:03:18 +00:00
|
|
|
* Sets the focal length for stereo mode.
|
2004-04-24 06:40:15 +00:00
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual void SetFocalLength(const float focallength)=0;
|
2004-10-24 11:03:18 +00:00
|
|
|
virtual float GetFocalLength() = 0;
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
* SwapBuffers swaps the back buffer with the front buffer.
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual void SwapBuffers()=0;
|
2004-04-11 02:50:02 +00:00
|
|
|
|
|
|
|
// Drawing Functions
|
|
|
|
/**
|
|
|
|
* IndexPrimitives: Renders primitives.
|
|
|
|
* @param vertexarrays is an array of vertex arrays
|
|
|
|
* @param indexarrays is an array of index arrays
|
|
|
|
* @param mode determines the type of primitive stored in the vertex/index arrays:
|
|
|
|
* 0 triangles
|
|
|
|
* 1 lines (default)
|
|
|
|
* 2 quads
|
|
|
|
* @param polymat (reserved)
|
|
|
|
* @param useObjectColor will render the object using @param rgbacolor instead of
|
|
|
|
* vertex colours.
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual void IndexPrimitives( const vecVertexArray& vertexarrays,
|
|
|
|
const vecIndexArrays & indexarrays,
|
|
|
|
int mode,
|
|
|
|
class RAS_IPolyMaterial* polymat,
|
|
|
|
class RAS_IRenderTools* rendertools,
|
|
|
|
bool useObjectColor,
|
2006-04-02 21:04:20 +00:00
|
|
|
const MT_Vector4& rgbacolor,
|
|
|
|
class KX_ListSlot** slot)=0;
|
2004-04-11 02:50:02 +00:00
|
|
|
/**
|
2004-04-24 06:40:15 +00:00
|
|
|
* @copydoc IndexPrimitives
|
2004-04-11 02:50:02 +00:00
|
|
|
* IndexPrimitivesEx will renormalize faces if @param vertexarrays[i].getFlag() & TV_CALCFACENORMAL
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual void IndexPrimitives_Ex( const vecVertexArray& vertexarrays,
|
|
|
|
const vecIndexArrays & indexarrays,
|
|
|
|
int mode,
|
|
|
|
class RAS_IPolyMaterial* polymat,
|
|
|
|
class RAS_IRenderTools* rendertools,
|
|
|
|
bool useObjectColor,
|
|
|
|
const MT_Vector4& rgbacolor)=0;
|
2004-04-11 02:50:02 +00:00
|
|
|
/**
|
|
|
|
* IndexPrimitives_3DText will render text into the polygons.
|
|
|
|
* The text to be rendered is from @param rendertools client object's text property.
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual void IndexPrimitives_3DText( const vecVertexArray& vertexarrays,
|
|
|
|
const vecIndexArrays & indexarrays,
|
|
|
|
int mode,
|
|
|
|
class RAS_IPolyMaterial* polymat,
|
|
|
|
class RAS_IRenderTools* rendertools,
|
|
|
|
bool useObjectColor,
|
|
|
|
const MT_Vector4& rgbacolor)=0;
|
|
|
|
|
2006-01-06 03:46:54 +00:00
|
|
|
virtual void IndexPrimitivesMulti(
|
|
|
|
const vecVertexArray& vertexarrays,
|
|
|
|
const vecIndexArrays & indexarrays,
|
|
|
|
int mode,
|
|
|
|
class RAS_IPolyMaterial* polymat,
|
|
|
|
class RAS_IRenderTools* rendertools,
|
|
|
|
bool useObjectColor,
|
2006-04-02 21:04:20 +00:00
|
|
|
const MT_Vector4& rgbacolor,
|
|
|
|
class KX_ListSlot** slot)=0;
|
2006-01-06 03:46:54 +00:00
|
|
|
|
|
|
|
virtual void IndexPrimitivesMulti_Ex(
|
|
|
|
const vecVertexArray& vertexarrays,
|
|
|
|
const vecIndexArrays & indexarrays,
|
|
|
|
int mode,
|
|
|
|
class RAS_IPolyMaterial* polymat,
|
|
|
|
class RAS_IRenderTools* rendertools,
|
|
|
|
bool useObjectColor,
|
|
|
|
const MT_Vector4& rgbacolor)=0;
|
|
|
|
|
|
|
|
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual void SetProjectionMatrix(MT_CmMatrix4x4 & mat)=0;
|
|
|
|
/* This one should become our final version, methinks. */
|
|
|
|
/**
|
|
|
|
* Set the projection matrix for the rasterizer. This projects
|
|
|
|
* from camera coordinates to window coordinates.
|
|
|
|
* @param mat The projection matrix.
|
|
|
|
*/
|
2004-05-16 13:10:10 +00:00
|
|
|
virtual void SetProjectionMatrix(const MT_Matrix4x4 & mat)=0;
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
* Sets the modelview matrix.
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual void SetViewMatrix(const MT_Matrix4x4 & mat,
|
|
|
|
const MT_Vector3& campos,
|
|
|
|
const MT_Point3 &camLoc,
|
|
|
|
const MT_Quaternion &camOrientQuat)=0;
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual const MT_Point3& GetCameraPosition()=0;
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual void LoadViewMatrix()=0;
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual void SetFog(float start,
|
|
|
|
float dist,
|
|
|
|
float r,
|
|
|
|
float g,
|
|
|
|
float b)=0;
|
|
|
|
|
|
|
|
virtual void SetFogColor(float r,
|
|
|
|
float g,
|
|
|
|
float b)=0;
|
|
|
|
|
|
|
|
virtual void SetFogStart(float start)=0;
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual void SetFogEnd(float end)=0;
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual void DisplayFog()=0;
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual void DisableFog()=0;
|
|
|
|
|
|
|
|
virtual void SetBackColor(float red,
|
|
|
|
float green,
|
|
|
|
float blue,
|
|
|
|
float alpha)=0;
|
|
|
|
|
2004-04-11 02:50:02 +00:00
|
|
|
/**
|
|
|
|
* @param drawingmode = KX_BOUNDINGBOX, KX_WIREFRAME, KX_SOLID, KX_SHADED or KX_TEXTURED.
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual void SetDrawingMode(int drawingmode)=0;
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
* @return the current drawing mode: KX_BOUNDINGBOX, KX_WIREFRAME, KX_SOLID, KX_SHADED or KX_TEXTURED.
|
|
|
|
*/
|
|
|
|
virtual int GetDrawingMode()=0;
|
|
|
|
/**
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual void EnableTextures(bool enable)=0;
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
* Sets face culling
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual void SetCullFace(bool enable)=0;
|
2004-04-11 02:50:02 +00:00
|
|
|
/**
|
|
|
|
* Sets wireframe mode.
|
|
|
|
*/
|
2004-03-22 22:02:18 +00:00
|
|
|
virtual void SetLines(bool enable)=0;
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual double GetTime()=0;
|
2004-04-24 06:40:15 +00:00
|
|
|
/**
|
|
|
|
* Generates a projection matrix from the specified frustum.
|
|
|
|
* @param left the left clipping plane
|
|
|
|
* @param right the right clipping plane
|
|
|
|
* @param bottom the bottom clipping plane
|
|
|
|
* @param top the top clipping plane
|
|
|
|
* @param frustnear the near clipping plane
|
|
|
|
* @param frustfar the far clipping plane
|
|
|
|
* @return a 4x4 matrix representing the projection transform.
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual MT_Matrix4x4 GetFrustumMatrix(
|
|
|
|
float left,
|
|
|
|
float right,
|
|
|
|
float bottom,
|
|
|
|
float top,
|
|
|
|
float frustnear,
|
2004-04-11 02:50:02 +00:00
|
|
|
float frustfar,
|
|
|
|
bool perspective = true
|
2002-10-12 11:37:38 +00:00
|
|
|
)=0;
|
2004-06-04 03:00:13 +00:00
|
|
|
/**
|
|
|
|
* Sets the specular colour component of the lighting equation.
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual void SetSpecularity(float specX,
|
|
|
|
float specY,
|
|
|
|
float specZ,
|
|
|
|
float specval)=0;
|
2004-06-04 03:00:13 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the specular exponent component of the lighting equation.
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual void SetShinyness(float shiny)=0;
|
2004-06-04 03:00:13 +00:00
|
|
|
/**
|
|
|
|
* Sets the diffuse colour component of the lighting equation.
|
|
|
|
*/
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual void SetDiffuse(float difX,
|
|
|
|
float difY,
|
|
|
|
float difZ,
|
|
|
|
float diffuse)=0;
|
2006-01-06 03:46:54 +00:00
|
|
|
/**
|
|
|
|
* Sets the emissive colour component of the lighting equation.
|
|
|
|
*/
|
|
|
|
virtual void SetEmissive(float eX,
|
|
|
|
float eY,
|
|
|
|
float eZ,
|
|
|
|
float e
|
|
|
|
)=0;
|
|
|
|
|
|
|
|
virtual void SetAmbientColor(float red, float green, float blue)=0;
|
|
|
|
virtual void SetAmbient(float factor)=0;
|
|
|
|
/**
|
|
|
|
* Sets alpha testing
|
|
|
|
*/
|
|
|
|
virtual void SetAlphaTest(bool enable)=0;
|
|
|
|
|
2005-01-16 06:02:06 +00:00
|
|
|
/**
|
|
|
|
* Sets a polygon offset. z depth will be: z1 = mult*z0 + add
|
|
|
|
*/
|
|
|
|
virtual void SetPolygonOffset(float mult, float add) = 0;
|
2002-10-12 11:37:38 +00:00
|
|
|
|
2005-07-27 09:30:53 +00:00
|
|
|
virtual void DrawDebugLine(const MT_Vector3& from,const MT_Vector3& to,const MT_Vector3& color)=0;
|
2006-02-13 05:45:32 +00:00
|
|
|
|
|
|
|
virtual void SetTexCoords(TexCoGen coords, int unit) = 0;
|
2006-04-11 05:57:30 +00:00
|
|
|
virtual void SetAttrib(int type) = 0;
|
2006-02-13 05:45:32 +00:00
|
|
|
virtual void GetViewMatrix(MT_Matrix4x4 &mat) const = 0;
|
|
|
|
|
2006-04-02 21:04:20 +00:00
|
|
|
virtual bool QueryLists(){return false;}
|
|
|
|
virtual bool QueryArrays(){return false;}
|
2002-10-12 11:37:38 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif //__RAS_IRASTERIZER
|
|
|
|
|