// FGAIThermal - AIBase derived class creates an AI thunderstorm // // Written by David Culp, started Feb 2004. // // Copyright (C) 2004 David P. Culp - davidculp2@comcast.net // // This program is free software; you can redistribute it and/or // modify it under the terms of the GNU General Public License as // published by the Free Software Foundation; either version 2 of the // License, or (at your option) any later version. // // This program is distributed in the hope that it will be useful, but // WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // General Public License for more details. // // You should have received a copy of the GNU General Public License // along with this program; if not, write to the Free Software // Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. #ifndef _FG_AIThermal_HXX #define _FG_AIThermal_HXX #include "AIManager.hxx" #include "AIBase.hxx" #include SG_USING_STD(string); class FGAIThermal : public FGAIBase { public: FGAIThermal(FGAIManager* mgr); ~FGAIThermal(); bool init(); virtual void bind(); virtual void unbind(); void update(double dt); inline void setStrength( double s ) { strength = s; }; inline void setDiameter( double d ) { diameter = d; }; protected: static FGAIThermal *_self; private: double dt; void Run(double dt); SGPropertyNode* wind_from_down; double strength; double diameter; double scaler; }; #endif // _FG_AIThermal_HXX