/usr/include/cegui-0.8.7/CEGUI/RendererModules/Ogre/GeometryBuffer.h is in libcegui-mk2-dev 0.8.7-1.3+b2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 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 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 | /***********************************************************************
created: Tue Feb 17 2009
author: Paul D Turner
*************************************************************************/
/***************************************************************************
* Copyright (C) 2004 - 2011 Paul D Turner & The CEGUI Development Team
*
* Permission is hereby granted, free of charge, to any person obtaining
* a copy of this software and associated documentation files (the
* "Software"), to deal in the Software without restriction, including
* without limitation the rights to use, copy, modify, merge, publish,
* distribute, sublicense, and/or sell copies of the Software, and to
* permit persons to whom the Software is furnished to do so, subject to
* the following conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
* IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
***************************************************************************/
#ifndef _CEGUIOgreGeometryBuffer_h_
#define _CEGUIOgreGeometryBuffer_h_
#include "CEGUI/GeometryBuffer.h"
#include "CEGUI/RendererModules/Ogre/Renderer.h"
#include "CEGUI/Rect.h"
#include "CEGUI/Quaternion.h"
#include <OgreMatrix4.h>
#include <OgreColourValue.h>
#include <OgreRenderOperation.h>
#include <OgreTexture.h>
#include <utility>
#include <vector>
#ifdef CEGUI_USE_OGRE_HLMS
#include <OgreRenderable.h>
#endif
// Ogre forward refs
namespace Ogre
{
class RenderSystem;
}
// Start of CEGUI namespace section
namespace CEGUI
{
//! Implementation of CEGUI::GeometryBuffer for the Ogre engine
class OGRE_GUIRENDERER_API OgreGeometryBuffer : public GeometryBuffer
{
public:
//! Constructor
OgreGeometryBuffer(OgreRenderer& owner, Ogre::RenderSystem& rs);
//! Destructor
virtual ~OgreGeometryBuffer();
//! return the transformation matrix used for this buffer.
const Ogre::Matrix4& getMatrix() const;
// implement CEGUI::GeometryBuffer interface.
virtual void draw() const;
virtual void setTranslation(const Vector3f& v);
virtual void setRotation(const Quaternion& r);
virtual void setPivot(const Vector3f& p);
virtual void setClippingRegion(const Rectf& region);
virtual void appendVertex(const Vertex& vertex);
virtual void appendGeometry(const Vertex* const vbuff, uint vertex_count);
virtual void setActiveTexture(Texture* texture);
virtual void reset();
virtual Texture* getActiveTexture() const;
virtual uint getVertexCount() const;
virtual uint getBatchCount() const;
virtual void setRenderEffect(RenderEffect* effect);
virtual RenderEffect* getRenderEffect();
void setClippingActive(const bool active);
bool isClippingActive() const;
protected:
//! convert CEGUI::colour into something Ogre can use
Ogre::RGBA colourToOgre(const Colour& col) const;
//! update cached matrix
void updateMatrix() const;
//! Synchronise data in the hardware buffer with what's been added
void syncHardwareBuffer() const;
//! set up texture related states
void initialiseTextureStates() const;
//! vertex structure used internally and also by Ogre.
struct OgreVertex
{
float x, y, z;
Ogre::RGBA diffuse;
float u, v;
};
//! type to track info for per-texture sub batches of geometry
struct BatchInfo
{
Ogre::TexturePtr texture;
uint vertexCount;
bool clip;
};
//! Renderer object that owns this GeometryBuffer
OgreRenderer& d_owner;
//! Ogre render system we're to use.
Ogre::RenderSystem& d_renderSystem;
//! Texture that is set as active
OgreTexture* d_activeTexture;
//! rectangular clip region
Rectf d_clipRect;
//! whether clipping will be active for the current batch
bool d_clippingActive;
//! translation vector
Vector3f d_translation;
//! rotation quaternion
Quaternion d_rotation;
//! pivot point for rotation
Vector3f d_pivot;
//! RenderEffect that will be used by the GeometryBuffer
RenderEffect* d_effect;
//! offset to be applied to all geometry
Vector2f d_texelOffset;
//! model matrix cache
mutable Ogre::Matrix4 d_matrix;
//! true when d_matrix is valid and up to date
mutable bool d_matrixValid;
#ifdef CEGUI_USE_OGRE_HLMS
//! Render operation for this buffer.
mutable Ogre::v1::RenderOperation d_renderOp;
//! H/W buffer where the vertices are rendered from.
mutable Ogre::v1::HardwareVertexBufferSharedPtr d_hwBuffer;
#else
//! Render operation for this buffer.
mutable Ogre::RenderOperation d_renderOp;
//! H/W buffer where the vertices are rendered from.
mutable Ogre::HardwareVertexBufferSharedPtr d_hwBuffer;
#endif
//! whether the h/w buffer is in sync with the added geometry
mutable bool d_sync;
//! type of container that tracks BatchInfos.
typedef std::vector<BatchInfo> BatchList;
//! list of texture batches added to the geometry buffer
BatchList d_batches;
//! type of container used to queue the geometry
typedef std::vector<OgreVertex> VertexList;
//! container where added geometry is stored.
VertexList d_vertices;
};
} // End of CEGUI namespace section
#endif // end of guard _CEGUIOgreGeometryBuffer_h_
|