00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019 #ifndef COLLISIONSPHERE_H
00020 #define COLLISIONSPHERE_H
00021
00022 #include <pandabase.h>
00023
00024 #include "collisionSolid.h"
00025
00026
00027
00028
00029
00030 class EXPCL_PANDA CollisionSphere : public CollisionSolid {
00031 PUBLISHED:
00032 INLINE CollisionSphere(const LPoint3f ¢er, float radius);
00033 INLINE CollisionSphere(float cx, float cy, float cz, float radius);
00034
00035 public:
00036 INLINE CollisionSphere(const CollisionSphere ©);
00037 virtual CollisionSolid *make_copy();
00038
00039 virtual PT(CollisionEntry)
00040 test_intersection(const CollisionEntry &entry) const;
00041
00042 virtual void xform(const LMatrix4f &mat);
00043 virtual LPoint3f get_collision_origin() const;
00044
00045 virtual void output(ostream &out) const;
00046
00047 PUBLISHED:
00048 INLINE void set_center(const LPoint3f ¢er);
00049 INLINE void set_center(float x, float y, float z);
00050 INLINE const LPoint3f &get_center() const;
00051
00052 INLINE void set_radius(float radius);
00053 INLINE float get_radius() const;
00054
00055 protected:
00056 INLINE CollisionSphere(void);
00057 virtual BoundingVolume *recompute_bound();
00058
00059 protected:
00060 virtual PT(CollisionEntry)
00061 test_intersection_from_sphere(const CollisionEntry &entry) const;
00062 virtual PT(CollisionEntry)
00063 test_intersection_from_ray(const CollisionEntry &entry) const;
00064 virtual PT(CollisionEntry)
00065 test_intersection_from_segment(const CollisionEntry &entry) const;
00066
00067 virtual void fill_viz_geom();
00068
00069 bool intersects_line(double &t1, double &t2,
00070 const LPoint3f &from, const LVector3f &delta) const;
00071
00072 private:
00073 LPoint3f _center;
00074 float _radius;
00075
00076 public:
00077 static void register_with_read_factory();
00078 virtual void write_datagram(BamWriter *manager, Datagram &me);
00079
00080 protected:
00081 static TypedWritable *make_CollisionSphere(const FactoryParams ¶ms);
00082 void fillin(DatagramIterator &scan, BamReader *manager);
00083
00084 public:
00085 static TypeHandle get_class_type() {
00086 return _type_handle;
00087 }
00088 static void init_type() {
00089 CollisionSolid::init_type();
00090 register_type(_type_handle, "CollisionSphere",
00091 CollisionSolid::get_class_type());
00092 }
00093 virtual TypeHandle get_type() const {
00094 return get_class_type();
00095 }
00096 virtual TypeHandle force_init_type() {init_type(); return get_class_type();}
00097
00098 private:
00099 static TypeHandle _type_handle;
00100 };
00101
00102 #include "collisionSphere.I"
00103
00104 #endif
00105
00106