2019-02-13 07:30:16 +00:00
|
|
|
#ifndef OPENMW_MWPHYSICS_PROJECTILE_H
|
|
|
|
#define OPENMW_MWPHYSICS_PROJECTILE_H
|
|
|
|
|
2020-10-23 18:27:07 +00:00
|
|
|
#include <atomic>
|
2019-02-13 07:30:16 +00:00
|
|
|
#include <memory>
|
2020-10-23 18:27:07 +00:00
|
|
|
#include <mutex>
|
2019-02-13 07:30:16 +00:00
|
|
|
|
2021-07-17 06:56:43 +00:00
|
|
|
#include <LinearMath/btVector3.h>
|
|
|
|
|
2020-10-23 18:27:07 +00:00
|
|
|
#include "ptrholder.hpp"
|
2019-02-13 07:30:16 +00:00
|
|
|
|
|
|
|
class btCollisionObject;
|
2020-10-23 18:27:07 +00:00
|
|
|
class btCollisionShape;
|
2019-02-13 07:30:16 +00:00
|
|
|
class btConvexShape;
|
2020-10-23 18:27:07 +00:00
|
|
|
|
|
|
|
namespace osg
|
|
|
|
{
|
|
|
|
class Vec3f;
|
|
|
|
}
|
2019-02-13 07:30:16 +00:00
|
|
|
|
|
|
|
namespace MWPhysics
|
|
|
|
{
|
2020-10-23 18:27:07 +00:00
|
|
|
class PhysicsTaskScheduler;
|
|
|
|
class PhysicsSystem;
|
|
|
|
|
|
|
|
class Projectile final : public PtrHolder
|
2019-02-13 07:30:16 +00:00
|
|
|
{
|
|
|
|
public:
|
2021-08-31 14:25:45 +00:00
|
|
|
Projectile(const MWWorld::Ptr& caster, const osg::Vec3f& position, float radius,
|
|
|
|
PhysicsTaskScheduler* scheduler, PhysicsSystem* physicssystem);
|
2020-10-23 18:27:07 +00:00
|
|
|
~Projectile() override;
|
2019-02-13 07:30:16 +00:00
|
|
|
|
|
|
|
btConvexShape* getConvexShape() const { return mConvexShape; }
|
|
|
|
|
2021-10-09 16:13:54 +00:00
|
|
|
void updateCollisionObjectPosition();
|
2019-02-13 07:30:16 +00:00
|
|
|
|
2020-10-23 18:27:07 +00:00
|
|
|
bool isActive() const { return mActive.load(std::memory_order_acquire); }
|
|
|
|
|
2021-08-05 08:55:19 +00:00
|
|
|
MWWorld::Ptr getTarget() const;
|
2020-10-23 18:27:07 +00:00
|
|
|
|
2020-12-14 21:23:01 +00:00
|
|
|
MWWorld::Ptr getCaster() const;
|
2021-06-23 21:13:59 +00:00
|
|
|
void setCaster(const MWWorld::Ptr& caster);
|
2021-08-05 08:55:19 +00:00
|
|
|
const btCollisionObject* getCasterCollisionObject() const { return mCasterColObj; }
|
2020-11-21 15:26:45 +00:00
|
|
|
|
2021-08-31 14:25:45 +00:00
|
|
|
void setHitWater() { mHitWater = true; }
|
|
|
|
|
|
|
|
bool getHitWater() const { return mHitWater; }
|
2020-10-23 18:27:07 +00:00
|
|
|
|
2021-08-05 08:55:19 +00:00
|
|
|
void hit(const btCollisionObject* target, btVector3 pos, btVector3 normal);
|
2020-10-23 18:27:07 +00:00
|
|
|
|
2020-12-14 21:23:01 +00:00
|
|
|
void setValidTargets(const std::vector<MWWorld::Ptr>& targets);
|
2021-08-05 08:55:19 +00:00
|
|
|
bool isValidTarget(const btCollisionObject* target) const;
|
2020-12-14 21:23:01 +00:00
|
|
|
|
2021-08-31 14:25:45 +00:00
|
|
|
btVector3 getHitPosition() const { return mHitPosition; }
|
2021-01-07 10:02:53 +00:00
|
|
|
|
2019-02-13 07:30:16 +00:00
|
|
|
private:
|
|
|
|
std::unique_ptr<btCollisionShape> mShape;
|
|
|
|
btConvexShape* mConvexShape;
|
|
|
|
|
2021-08-31 14:25:45 +00:00
|
|
|
bool mHitWater;
|
2020-10-23 18:27:07 +00:00
|
|
|
std::atomic<bool> mActive;
|
2020-11-21 15:26:45 +00:00
|
|
|
MWWorld::Ptr mCaster;
|
2021-08-05 08:55:19 +00:00
|
|
|
const btCollisionObject* mCasterColObj;
|
|
|
|
const btCollisionObject* mHitTarget;
|
2020-10-31 13:01:14 +00:00
|
|
|
btVector3 mHitPosition;
|
|
|
|
btVector3 mHitNormal;
|
2020-10-23 18:27:07 +00:00
|
|
|
|
2021-08-05 08:55:19 +00:00
|
|
|
std::vector<const btCollisionObject*> mValidTargets;
|
2020-12-14 21:23:01 +00:00
|
|
|
|
|
|
|
mutable std::mutex mMutex;
|
2019-02-13 07:30:16 +00:00
|
|
|
|
2020-10-31 13:01:14 +00:00
|
|
|
PhysicsSystem* mPhysics;
|
2020-10-23 18:27:07 +00:00
|
|
|
PhysicsTaskScheduler* mTaskScheduler;
|
2019-02-13 07:30:16 +00:00
|
|
|
|
|
|
|
Projectile(const Projectile&);
|
|
|
|
Projectile& operator=(const Projectile&);
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|