/** * PANDA 3D SOFTWARE * Copyright (c) Carnegie Mellon University. All rights reserved. * * All use of this software is subject to the terms of the revised BSD * license. You should have received a copy of this license along * with this source code in a file named "LICENSE." * * @file odeMass.h * @author joswilso * @date 2006-12-27 */ #ifndef ODEMASS_H #define ODEMASS_H #include "pandabase.h" #include "typedReferenceCount.h" #include "luse.h" #include "ode_includes.h" /** * */ class EXPCL_PANDAODE OdeMass : public TypedReferenceCount { PUBLISHED: OdeMass(); OdeMass(const OdeMass ©); virtual ~OdeMass(); INLINE int check(); INLINE void set_zero(); INLINE void set_parameters(dReal themass, dReal cgx, dReal cgy, dReal cgz, dReal I11, dReal I22, dReal I33, dReal I12, dReal I13, dReal I23); INLINE void set_parameters(dReal themass, const LVecBase3f ¢er, const LMatrix3f &r); INLINE void set_sphere(dReal density, dReal radius); INLINE void set_sphere_total(dReal total_mass, dReal radius); INLINE void set_capsule(dReal density, int direction, dReal radius, dReal length); INLINE void set_capsule_total(dReal total_mass, int direction, dReal radius, dReal length); INLINE void set_cylinder(dReal density, int direction, dReal radius, dReal length); INLINE void set_cylinder_total(dReal total_mass, int direction, dReal radius, dReal length); INLINE void set_box(dReal density, dReal lx, dReal ly, dReal lz); INLINE void set_box(dReal density, const LVecBase3f &size); INLINE void set_box_total(dReal total_mass, dReal lx, dReal ly, dReal lz); INLINE void set_box_total(dReal total_mass, const LVecBase3f &size); INLINE void adjust(dReal newmass); INLINE void translate(dReal x, dReal y, dReal z); INLINE void translate(const LVecBase3f &pos); INLINE void rotate(const LMatrix3f &r); INLINE void add(OdeMass &other); INLINE dReal get_magnitude() const; INLINE LPoint3f get_center() const; INLINE LMatrix3f get_inertial_tensor() const; virtual void write(std::ostream &out = std::cout, unsigned int indent=0) const; public: dMass* get_mass_ptr(); private: void operator = (const OdeMass ©); dMass _mass; public: static TypeHandle get_class_type() { return _type_handle; } static void init_type() { TypedReferenceCount::init_type(); register_type(_type_handle, "OdeMass", TypedReferenceCount::get_class_type()); } virtual TypeHandle get_type() const { return get_class_type(); } virtual TypeHandle force_init_type() {init_type(); return get_class_type();} private: static TypeHandle _type_handle; }; #include "odeMass.I" #endif