Vegastrike 0.5.1 rc1  1.0
Original sources for Vegastrike Evolved
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
Orders::FacePerpendicular Class Reference
Inheritance diagram for Orders::FacePerpendicular:
Orders::FaceTargetITTS Orders::ChangeHeading Order

Public Member Functions

void SetParent (Unit *parent1)
 Sets the parent of this Unit. Any virtual functions must call this one. More...
 
 FacePerpendicular (bool aggressive, bool afterburn, bool force_afterburn, int seed)
 
void Execute ()
 The function that gets called and executes all queued suborders. More...
 
- Public Member Functions inherited from Orders::FaceTargetITTS
 FaceTargetITTS (bool fini=false, int accuracy=3)
 
virtual string getOrderDescription ()
 
virtual ~FaceTargetITTS ()
 
- Public Member Functions inherited from Orders::ChangeHeading
 ChangeHeading (const QVector &final_heading, int switchback, float turning_speed=1, bool term=false)
 takes in the destination target, and the ammount of accuracy (how many times it should miss destination and come back) should be used More...
 
void SetDest (const QVector &)
 
virtual ~ChangeHeading ()
 
- Public Member Functions inherited from Order
virtual void ChooseTarget ()
 this function calls the destructor (needs to be overridden for python; More...
 
virtual bool PursueTarget (Unit *, bool isleader)
 
void ClearMessages ()
 clears the messasges of this order More...
 
 Order ()
 The default constructor setting everything to NULL and no dependency on order. More...
 
 Order (int type, int subtype)
 The constructor that specifies what order dependencies this order has. More...
 
virtual void Destroy ()
 The virutal function that unrefs all memory then calls Destruct () which takes care of unreffing this or calling delete on this. More...
 
OrderqueryType (unsigned int type)
 returns a pointer to the first order that may be bitwised ored with that type More...
 
OrderqueryAny (unsigned int type)
 returns a pointer to the first order that may be bitwise ored with any type More...
 
void eraseType (unsigned int type)
 Erases all orders that bitwise OR with that type. More...
 
bool AttachOrder (Unit *targets)
 Attaches a group of targets to this order (used for strategery-type games) More...
 
bool AttachOrder (QVector target)
 Attaches a navigation point to this order. More...
 
bool AttachSelfOrder (Unit *targets)
 Attaches a group (form up) to this order. More...
 
OrderEnqueueOrder (Order *ord)
 Enqueues another order that will be executed (in parallel perhaps) when next void Execute() is called. More...
 
OrderReplaceOrder (Order *ord)
 Replaces the first order of that type in the order queue. More...
 
bool Done ()
 
int getType ()
 
int getSubType ()
 
UnitGetParent () const
 
virtual void Communicate (const class CommunicationMessage &c)
 Sends a communication message from the Unit (encapulated in c) to this unit. More...
 
virtual void ProcessCommMessage (class CommunicationMessage &c)
 processes a single message...generally called by the Messages() func More...
 
virtual void ProcessCommunicationMessages (float CommRepsonseTime, bool RemoveMessageProcessed)
 responds (or does not) to certain messages in the message queue More...
 
OrderfindOrder (Order *ord)
 return pointer to order or NULL if not found More...
 
void eraseOrder (Order *ord)
 erase that order from the list More...
 
OrderEnqueueOrderFirst (Order *ord)
 enqueue order as first order More...
 
virtual olist_tgetOrderList ()
 returns the orderlist (NULL for orders that haven't got any) More...
 
virtual void AdjustRelationTo (Unit *un, float factor)
 
OrderfindOrderList ()
 searches the suborders recursively for the first order that has an orderlist More...
 
std::string createFullOrderDescription (int level=0)
 
void setActionString (std::string astring)
 
std::string getActionString ()
 
virtual float getMood ()
 

Additional Inherited Members

- Public Types inherited from Order
enum  ORDERTYPES {
  MOVEMENT =1, FACING =2, WEAPON =4, CLOAKING =8,
  ALLTYPES =(1|2|4|8)
}
 The varieties of order types MOVEMENT,FACING, and WEAPON orders may not be mutually executed (lest one engine goes left, the other right) More...
 
enum  SUBORDERTYPES { SLOCATION =1, STARGET =2, SSELF =4 }
 
- Protected Member Functions inherited from Orders::ChangeHeading
void ResetDone ()
 
- Protected Attributes inherited from Order
Unitparent
 The unit this order is attached to. More...
 
unsigned int type
 The bit code (from ORDERTYPES) that this order is (for parallel execution) More...
 
unsigned int subtype
 
bool done
 Whether or not this order is done. More...
 
UnitContainer group
 If this order applies to a group of units (as in form up with this group) More...
 
QVector targetlocation
 If this order applies to a physical location in world space. More...
 
std::vector< Order * > suborders
 The queue of suborders that will be executed in parallel according to bit code. More...
 
std::list< class
CommunicationMessage * > 
messagequeue
 a bunch of communications that have not been answered CommunicationMessages are actually containing reference to a nice Finite State Machine that can allow a player to have a reasonable conversation with an AI More...
 
std::string actionstring
 

Detailed Description

Definition at line 409 of file hard_coded_scripts.cpp.

Constructor & Destructor Documentation

Orders::FacePerpendicular::FacePerpendicular ( bool  aggressive,
bool  afterburn,
bool  force_afterburn,
int  seed 
)
inline

Definition at line 424 of file hard_coded_scripts.cpp.

References VegaConfig::getVariable(), XMLSupport::parse_float(), VSRandom::rand(), VSRandom::uniformInc(), vs_config, and VS_RAND_MAX.

424  : FaceTargetITTS( false, 3 )
425  , m( Vector( 0, 0, 1000 ), true, afterburn, false )
426  {
427  this->aggressive = aggressive;
428  VSRandom vsr( seed );
429  this->afterburn = afterburn;
430  this->force_afterburn = force_afterburn;
431 
432  static float loopdis = XMLSupport::parse_float( vs_config->getVariable( "AI", "loop_around_distance", "1" ) );
433  qq = pp = 0;
434  static float loopdisd =
435  XMLSupport::parse_float( vs_config->getVariable( "AI", "loop_around_destination_distance", "20.0" ) );
436  static float loopdisv =
437  XMLSupport::parse_float( vs_config->getVariable( "AI", "loop_around_destination_vertical", "4.0" ) );
438  static float loopdisl = XMLSupport::parse_float( vs_config->getVariable( "AI", "loop_around_destination_lateral", "4.0" ) );
439  rr.Set( loopdisl*vsr.uniformInc( -1, 1 ), loopdisv*vsr.uniformInc( -1, 1 ), 1.0+loopdisd*vsr.uniformInc( 0, 1 ) );
440  if (vsr.rand() < VS_RAND_MAX/2) {
441  qq = vsr.uniformInc( -1, 1 );
442  rr.j = qq;
443  if (qq > 0)
444  qq += loopdis;
445  if (qq < 0)
446  qq -= loopdis;
447  } else {
448  pp = vsr.uniformInc( -1, 1 );
449  rr.i = pp;
450  if (pp > 0)
451  pp += loopdis;
452  if (pp < 0)
453  pp -= loopdis;
454  }
455  }

Member Function Documentation

void Orders::FacePerpendicular::Execute ( )
inlinevirtual

The function that gets called and executes all queued suborders.

Reimplemented from Orders::FaceTargetITTS.

Definition at line 456 of file hard_coded_scripts.cpp.

References Unit::cumulative_transformation_matrix, done, Orders::ChangeHeading::Execute(), Orders::FaceTargetITTS::Execute(), UnitUtil::getDistance(), Matrix::getR(), VegaConfig::getVariable(), XMLSupport::parse_float(), Unit::Position(), QVector, speed, Unit::Target(), useAfterburner(), Vector, and vs_config.

457  {
458  static float gun_range_pct = XMLSupport::parse_float( vs_config->getVariable( "AI", "gun_range_percent_ok", ".66" ) );
459  Unit *targ = parent->Target();
460  if (targ) {
461  Vector relloc = parent->Position()-targ->Position();
463  bool afterburn = useAfterburner() && this->afterburn;
464  bool ab_needed = force_afterburn || targ->GetVelocity().MagnitudeSquared() > parent->GetComputerData().max_speed();
465  m.SetDesiredVelocity( Vector( 0, 0, afterburn
466  && ab_needed ? parent->GetComputerData().max_ab_speed() : parent->GetComputerData().
467  max_speed() ), true );
468  float speed, grange = 0, mrange = 0;
469  parent->getAverageGunSpeed( speed, grange, mrange );
470  if (r.Dot( relloc ) < 0) {
472  float dist = UnitUtil::getDistance( parent, targ );
473  if ( dist < grange*gun_range_pct || (grange == 0 && dist < mrange) ) {
474  static float velocity_adjustment_pct =
475  XMLSupport::parse_float( vs_config->getVariable( "AI", "loop_around_pursuit_velocity_percent", ".9" ) );
476  m.SetDesiredVelocity( Vector( 0, 0, targ->cumulative_velocity.Magnitude()*velocity_adjustment_pct ), true );
477  }
478  m.SetAfterburn( afterburn && ab_needed );
479  m.Execute();
480  } else {
481  done = false;
482  if (afterburn)
483  m.SetAfterburn( ab_needed );
484  else
485  m.SetAfterburn( 0 );
486  Vector scala = targ->cumulative_transformation_matrix.getR().Cross(
487  aggressive ? parent->cumulative_transformation_matrix.getQ() : Vector( .01, .99,
488  -.001 ) )*parent->rSize()*100.;
489  QVector dest = parent->Position()+scala;
490  SetDest( dest );
492  m.Execute();
493  }
494  }
495  }
void Orders::FacePerpendicular::SetParent ( Unit parent1)
inlinevirtual

Sets the parent of this Unit. Any virtual functions must call this one.

Reimplemented from Order.

Definition at line 419 of file hard_coded_scripts.cpp.

References Order::SetParent().

420  {
421  FaceTargetITTS::SetParent( parent1 );
422  m.SetParent( parent1 );
423  }

The documentation for this class was generated from the following file: