-// FGAIAircraft - FGAIBase-derived class creates an AI airplane
+// // FGAIAircraft - FGAIBase-derived class creates an AI airplane
//
// Written by David Culp, started October 2003.
//
FGAIAircraft::FGAIAircraft(FGAISchedule *ref) : FGAIBase(otAircraft) {
trafficRef = ref;
- if (trafficRef)
+ if (trafficRef) {
groundOffset = trafficRef->getGroundOffset();
+ setCallSign(trafficRef->getCallSign());
+ }
else
groundOffset = 0;
holdPos = false;
_performance = 0; //TODO initialize to JET_TRANSPORT from PerformanceDB
+
}
props->tie("controls/gear/gear-down",
SGRawValueMethods<FGAIAircraft,bool>(*this,
&FGAIAircraft::_getGearDown));
- props->setStringValue("callsign", callsign.c_str());
}
int leg;
if ((leg = fp->getLeg()) == 10) {
trafficRef->next();
+ setCallSign(trafficRef->getCallSign());
+ //props->setStringValue("callsign", callsign.c_str());
leg = 1;
fp->setLeg(leg);
}
}
-void FGAIAircraft::setCallSign(const string& s) {
- callsign = s;
-}
-
-
void FGAIAircraft::doGroundAltitude() {
if (fabs(altitude_ft - (tgt_altitude_ft+groundOffset)) > 1000.0)
altitude_ft = (tgt_altitude_ft + groundOffset);
// This waypoint marks the fact that the aircraft has passed the initial taxi
// departure waypoint, so it can release the parking.
- if (prev->name == "park2") {
+ if (prev->name == "PushBackPoint") {
dep->getDynamics()->releaseParking(fp->getGate());
+ time_t holdUntil = now + 120;
+ fp->setTime(holdUntil);
+ //cerr << _getCallsign() << "Holding at pushback point" << endl;
}
// This is the last taxi waypoint, and marks the the end of the flight plan
if (finite(calc_bearing)) {
double hdg_error = calc_bearing - tgt_heading;
- if (fabs(hdg_error) > 1.0) {
+ if (fabs(hdg_error) > 0.01) {
TurnTo( calc_bearing );
}
if (fabs(speed_diff) > 10) {
prevSpeed = speed;
- fp->setLeadDistance(speed, tgt_heading, curr, next);
+ if (next) {
+ fp->setLeadDistance(speed, tgt_heading, curr, next);
+ }
}
}
time_t now = time(NULL) + fgGetLong("/sim/time/warp");
//cerr << "UpateTArgetValues() " << endl;
ProcessFlightPlan(dt, now);
- if (! fp->isActive(now)) {
- // Do execute Ground elev for inactive aircraft, so they
- // Are repositioned to the correct ground altitude when the user flies within visibility range.
- // In addition, check whether we are out of user range, so this aircraft
- // can be deleted.
- if (onGround()) {
+
+ // Do execute Ground elev for inactive aircraft, so they
+ // Are repositioned to the correct ground altitude when the user flies within visibility range.
+ // In addition, check whether we are out of user range, so this aircraft
+ // can be deleted.
+ if (onGround()) {
Transform(); // make sure aip is initialized.
- if (trafficRef) {
- //cerr << trafficRef->getRegistration() << " Setting altitude to " << altitude_ft;
- if (! aiTrafficVisible()) {
- setDie(true);
- throw AI_OutOfSight();
- }
- getGroundElev(dt);
- doGroundAltitude();
- // Transform();
- pos.setElevationFt(altitude_ft);
- }
+ getGroundElev(dt);
+ doGroundAltitude();
+ // Transform();
+ pos.setElevationFt(altitude_ft);
+ }
+ if (trafficRef) {
+ //cerr << trafficRef->getRegistration() << " Setting altitude to " << altitude_ft;
+ if (! aiTrafficVisible()) {
+ setDie(true);
+ //cerr << trafficRef->getRegistration() << " is set to die " << endl;
+ throw AI_OutOfSight();
}
+ }
+ if (! fp->isActive(now)) {
throw FP_Inactive();
}
- }
- else {
+ } else {
// no flight plan, update target heading, speed, and altitude
// from control properties. These default to the initial
// settings in the config file, but can be changed "on the