X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;ds=sidebyside;f=src%2Factiveobject.h;h=b6a0e67af37e51603c0a53ef584f6ff04f163346;hb=c0fb5dd3179a0cf70457f5948c0aaca69cbf4c0c;hp=fe6c085141df192cccca5b3f37f8c193a505a1e4;hpb=66479394037baa941cb06d75d3afc79ff4c717a2;p=oweals%2Fminetest.git diff --git a/src/activeobject.h b/src/activeobject.h index fe6c08514..b6a0e67af 100644 --- a/src/activeobject.h +++ b/src/activeobject.h @@ -17,8 +17,7 @@ with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */ -#ifndef ACTIVEOBJECT_HEADER -#define ACTIVEOBJECT_HEADER +#pragma once #include "irr_aabb3d.h" #include @@ -28,9 +27,9 @@ enum ActiveObjectType { ACTIVEOBJECT_TYPE_TEST = 1, // Deprecated stuff ACTIVEOBJECT_TYPE_ITEM = 2, - ACTIVEOBJECT_TYPE_RAT = 3, - ACTIVEOBJECT_TYPE_OERKKI1 = 4, - ACTIVEOBJECT_TYPE_FIREFLY = 5, +// ACTIVEOBJECT_TYPE_RAT = 3, +// ACTIVEOBJECT_TYPE_OERKKI1 = 4, +// ACTIVEOBJECT_TYPE_FIREFLY = 5, ACTIVEOBJECT_TYPE_MOBV2 = 6, // End deprecated stuff ACTIVEOBJECT_TYPE_LUAENTITY = 7, @@ -43,7 +42,7 @@ enum ActiveObjectType { struct ActiveObjectMessage { - ActiveObjectMessage(u16 id_, bool reliable_=true, std::string data_=""): + ActiveObjectMessage(u16 id_, bool reliable_=true, const std::string &data_ = "") : id(id_), reliable(reliable_), datastring(data_) @@ -65,7 +64,7 @@ public: { } - u16 getId() + u16 getId() const { return m_id; } @@ -76,11 +75,29 @@ public: } virtual ActiveObjectType getType() const = 0; + + + /*! + * Returns the collision box of the object. + * This box is translated by the object's + * location. + * The box's coordinates are world coordinates. + * @returns true if the object has a collision box. + */ virtual bool getCollisionBox(aabb3f *toset) const = 0; + + + /*! + * Returns the selection box of the object. + * This box is not translated when the + * object moves. + * The box's coordinates are world coordinates. + * @returns true if the object has a selection box. + */ + virtual bool getSelectionBox(aabb3f *toset) const = 0; + + virtual bool collideWithObjects() const = 0; protected: u16 m_id; // 0 is invalid, "no id" }; - -#endif -