From e33e19d0587146859d48a134ec9fd94e7b7ba5cd Mon Sep 17 00:00:00 2001 From: "FWoltermann@gmail.com" Date: Thu, 8 Dec 2011 14:53:40 +0000 Subject: Initial upload --- Stars45/Sensor.h | 86 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 86 insertions(+) create mode 100644 Stars45/Sensor.h (limited to 'Stars45/Sensor.h') diff --git a/Stars45/Sensor.h b/Stars45/Sensor.h new file mode 100644 index 0000000..5bb4dc0 --- /dev/null +++ b/Stars45/Sensor.h @@ -0,0 +1,86 @@ +/* Project Starshatter 4.5 + Destroyer Studios LLC + Copyright © 1997-2004. All Rights Reserved. + + SUBSYSTEM: Stars.exe + FILE: Sensor.h + AUTHOR: John DiCamillo + + + OVERVIEW + ======== + Integrated (Passive and Active) Sensor Package class +*/ + +#ifndef Sensor_h +#define Sensor_h + +#include "Types.h" +#include "SimObject.h" +#include "System.h" +#include "Geometry.h" +#include "List.h" + +// +--------------------------------------------------------------------+ + +class Shot; +class Contact; + +// +--------------------------------------------------------------------+ + +class Sensor : public System, public SimObserver +{ +public: + enum Mode { + PAS, STD, ACM, GM, // fighter modes + PST, CST // starship modes + }; + + Sensor(); + Sensor(const Sensor& rhs); + virtual ~Sensor(); + + virtual void ExecFrame(double seconds); + virtual SimObject* LockTarget(int type=SimObject::SIM_SHIP, + bool closest=false, + bool hostile=false); + virtual SimObject* LockTarget(SimObject* candidate); + virtual bool IsTracking(SimObject* tgt); + virtual void DoEMCON(int emcon); + + virtual void ClearAllContacts(); + + virtual Mode GetMode() const { return mode; } + virtual void SetMode(Mode m); + virtual double GetBeamLimit() const; + virtual double GetBeamRange() const; + virtual void IncreaseRange(); + virtual void DecreaseRange(); + virtual void AddRange(double r); + + Contact* FindContact(Ship* s); + Contact* FindContact(Shot* s); + + // borrow this sensor for missile seeker + SimObject* AcquirePassiveTargetForMissile(); + SimObject* AcquireActiveTargetForMissile(); + + // SimObserver: + virtual bool Update(SimObject* obj); + virtual const char* GetObserverName() const; + +protected: + void ProcessContact(Ship* contact, double az1, double az2); + void ProcessContact(Shot* contact, double az1, double az2); + + Mode mode; + int nsettings; + int range_index; + float range_settings[8]; + SimObject* target; + + List contacts; +}; + +#endif Sensor_h + -- cgit v1.1