source: GTP/trunk/App/Demos/Vis/FriendlyCulling/src/SceneEntity.cpp @ 3070

Revision 3070, 3.1 KB checked in by mattausch, 16 years ago (diff)
Line 
1#include "SceneEntity.h"
2#include "Geometry.h"
3#include "Material.h"
4#include "RenderState.h"
5#include "Shape.h"
6#include "Transform3.h"
7#include "Camera.h"
8
9#include "glInterface.h"
10#include <Cg/cg.h>
11#include <Cg/cgGL.h>
12
13
14using namespace std;
15
16
17namespace CHCDemoEngine
18{
19
20bool SceneEntity::sUseLODs = true;
21
22
23SceneEntity::SceneEntity(Transform3 *trafo):
24mTransform(trafo), mCurrentLODLevel(0), mLODLastUpdated(-1)
25{
26        mBox.Initialize();
27}
28
29
30SceneEntity::~SceneEntity()
31{
32}
33
34
35void SceneEntity::UpdateLODs(const Vector3 &viewPoint)
36{
37        mCurrentLODLevel = 0;
38
39        if (!sUseLODs) return;
40
41        const Vector3 pos = GetWorldCenter();
42
43        const float dist = SqrDistance(pos, viewPoint);
44
45        // note: we assume that lods are ordered from smallest distance to largest
46        const int l = (int)mLODLevels.size();
47
48        for (int i = 0; i < l; ++ i)
49        {
50                if (mLODLevels[i].GetSquaredDistance() > dist)
51                        break;
52
53                mCurrentLODLevel = i;
54        }
55}
56
57
58int SceneEntity::GetCurrentLODLevel()
59{
60        if (mLODLastUpdated != LODLevel::sFrameId)
61        {
62                mLODLastUpdated = LODLevel::sFrameId;
63                UpdateLODs(LODLevel::sViewPoint);
64        }
65
66        return mCurrentLODLevel;
67}
68
69
70void SceneEntity::GetCurrentLODLevel(ShapeContainer::iterator &start,
71                                                                         ShapeContainer::iterator &end)
72{
73        if (mLODLastUpdated != LODLevel::sFrameId)
74        {
75                mLODLastUpdated = LODLevel::sFrameId;
76                UpdateLODs(LODLevel::sViewPoint);
77        }
78
79        start = mLODLevels[mCurrentLODLevel].GetShapes().begin();
80        end   = mLODLevels[mCurrentLODLevel].GetShapes().end();
81}
82
83
84void SceneEntity::GetLODLevel(int level,
85                                                          ShapeContainer::iterator &start,
86                                                          ShapeContainer::iterator &end)
87{
88        start = mLODLevels[level].GetShapes().begin();
89        end = mLODLevels[level].GetShapes().end();
90}
91
92
93void SceneEntity::Render(RenderState *state)
94{
95        ShapeContainer::iterator sit, sit_end;
96
97        if (!mLODLevels.empty())
98                GetCurrentLODLevel(sit, sit_end);
99        else
100        {
101                sit = mShapes.begin(); sit_end = mShapes.end();
102        }
103
104        for (; sit != sit_end; ++ sit)
105        {
106                (*sit)->Render(state);
107        }
108}
109
110
111void SceneEntity::AddShape(Shape *shape)
112{
113        mShapes.push_back(shape);
114        mBox.Include(shape->GetBoundingBox());
115
116        mCenter = mBox.Center();
117}
118
119
120void SceneEntity::SetTransform(Transform3 *trafo)
121{
122        mTransform = trafo;
123}
124
125
126void SceneEntity::SetLastRendered(int lastRendered)
127{
128        mLastRendered = lastRendered;
129}
130
131
132int SceneEntity::GetLastRendered() const
133{
134        return mLastRendered;
135}
136
137
138int SceneEntity::CountNumTriangles(int lodLevel)
139{
140        int numTriangles = 0;
141       
142        ShapeContainer::iterator sit, sit_end;
143
144        if (lodLevel == -1)
145        {
146                lodLevel = GetCurrentLODLevel();
147        }
148
149        return mLODLevels[lodLevel].GetNumTriangles();
150}
151
152
153AxisAlignedBox3 SceneEntity::GetWorldBoundingBox() const
154{
155        if (mTransform->IsIdentity()) return mBox;
156
157        Matrix4x4 mat = mTransform->GetMatrix();
158
159        return Transform(mBox, mat);
160}
161
162
163AxisAlignedBox3 SceneEntity::GetBoundingBox() const
164{
165        return mBox;
166}
167
168
169Vector3 SceneEntity::GetWorldCenter() const
170{
171        if (mTransform->IsIdentity())
172                return mCenter;
173
174        return mTransform->GetMatrix() *  mCenter;
175}
176
177
178}
Note: See TracBrowser for help on using the repository browser.