]> Dogcows Code - chaz/yoink/blobdiff - src/Moof/Entity.hh
cade lab fixes
[chaz/yoink] / src / Moof / Entity.hh
index 33efcc9e77ca20afbc362184007306e0ca586c7f..ee0f8602c6fd8585090251b9d89cab8f753aefd6 100644 (file)
@@ -43,37 +43,44 @@ namespace Mf {
 class Entity;
 typedef boost::shared_ptr<Entity> EntityP;
 
-class Camera;
+class Frustum;
 
 
 /**
  * Interface for game objects that can be drawn to the screen and have a
- * specified size.
+ * specified volume (take up space).
  */
 
-class Entity : public Drawable, public Cullable
+class Entity : public Cullable, public Drawable
 {
+protected:
+
+       Aabb<3>         mAabb;
+       Sphere<3>       mSphere;
+
 public:
-       inline virtual ~Entity() {}
 
-       const Aabb& getAabb() const
+       virtual ~Entity() {}
+
+       virtual void drawIfVisible(Scalar alpha, const Frustum& frustum) const
        {
-               return aabb_;
+               if (isVisible(frustum)) draw(alpha);
        }
 
-       const Sphere& getSphere() const
+       virtual bool isVisible(const Frustum& frustum) const
        {
-               return sphere_;
+               return mSphere.isVisible(frustum) && mAabb.isVisible(frustum);
        }
 
-       virtual void drawIfVisible(Scalar alpha, const Camera& cam) const
+       const Aabb<3>& getAabb() const
        {
-               if (isVisible(cam)) draw(alpha);
+               return mAabb;
        }
 
-protected:
-       Aabb    aabb_;
-       Sphere  sphere_;
+       const Sphere<3>& getSphere() const
+       {
+               return mSphere;
+       }
 };
 
 
This page took 0.01812 seconds and 4 git commands to generate.