Add support for helipads from apt.dat 850+
This commit is contained in:
parent
2319948b95
commit
11c00afaec
10 changed files with 112 additions and 18 deletions
|
@ -436,7 +436,7 @@ private:
|
|||
const string& rwy_no(token[1]);
|
||||
int surface_code = atoi( token[7].c_str() );
|
||||
|
||||
cache->insertRunway(FGPositioned::RUNWAY, rwy_no, pos,
|
||||
cache->insertRunway(FGPositioned::HELIPAD, rwy_no, pos,
|
||||
currentAirportID, heading, length,
|
||||
width, 0.0, 0.0, surface_code);
|
||||
}
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
// runwaybase.cxx -- a base class for runways and taxiways
|
||||
//
|
||||
// Written by James Turber, started December 2008.
|
||||
// Written by James Turner, started December 2008.
|
||||
//
|
||||
// Copyright (C) 2000 Curtis L. Olson - http://www.flightgear.org/~curt
|
||||
//
|
||||
|
|
|
@ -202,3 +202,14 @@ std::vector<flightgear::Approach*> FGRunway::getApproaches() const
|
|||
return result;
|
||||
}
|
||||
|
||||
FGHelipad::FGHelipad(PositionedID aGuid,
|
||||
PositionedID aAirport, const string& aIdent,
|
||||
const SGGeod& aGeod,
|
||||
const double heading, const double length,
|
||||
const double width,
|
||||
const int surface_code) :
|
||||
FGRunwayBase(aGuid, RUNWAY, aIdent, aGeod,
|
||||
heading, length, width, surface_code),
|
||||
_airport(aAirport)
|
||||
{
|
||||
}
|
||||
|
|
|
@ -134,4 +134,17 @@ public:
|
|||
|
||||
};
|
||||
|
||||
class FGHelipad : public FGRunwayBase
|
||||
{
|
||||
PositionedID _airport;
|
||||
public:
|
||||
FGHelipad(PositionedID aGuid,
|
||||
PositionedID aAirport, const std::string& rwy_no,
|
||||
const SGGeod& aGeod,
|
||||
const double heading, const double length,
|
||||
const double width,
|
||||
const int surface_code);
|
||||
};
|
||||
|
||||
|
||||
#endif // _FG_RUNWAYS_HXX
|
||||
|
|
|
@ -131,6 +131,12 @@ unsigned int FGAirport::numRunways() const
|
|||
return mRunways.size();
|
||||
}
|
||||
|
||||
unsigned int FGAirport::numHelipads() const
|
||||
{
|
||||
loadHelipads();
|
||||
return mHelipads.size();
|
||||
}
|
||||
|
||||
FGRunway* FGAirport::getRunwayByIndex(unsigned int aIndex) const
|
||||
{
|
||||
loadRunways();
|
||||
|
@ -139,6 +145,14 @@ FGRunway* FGAirport::getRunwayByIndex(unsigned int aIndex) const
|
|||
return (FGRunway*) flightgear::NavDataCache::instance()->loadById(mRunways[aIndex]);
|
||||
}
|
||||
|
||||
FGHelipad* FGAirport::getHelipadByIndex(unsigned int aIndex) const
|
||||
{
|
||||
loadHelipads();
|
||||
|
||||
assert(aIndex >= 0 && aIndex < mHelipads.size());
|
||||
return (FGHelipad*) flightgear::NavDataCache::instance()->loadById(mHelipads[aIndex]);
|
||||
}
|
||||
|
||||
bool FGAirport::hasRunwayWithIdent(const string& aIdent) const
|
||||
{
|
||||
return flightgear::NavDataCache::instance()->airportItemWithIdent(guid(), FGPositioned::RUNWAY, aIdent) != 0;
|
||||
|
@ -356,6 +370,18 @@ void FGAirport::loadRunways() const
|
|||
mRunways = flightgear::NavDataCache::instance()->airportItemsOfType(guid(), FGPositioned::RUNWAY);
|
||||
}
|
||||
|
||||
void FGAirport::loadHelipads() const
|
||||
{
|
||||
if (mHelipadsLoaded) {
|
||||
return; // already loaded, great
|
||||
}
|
||||
|
||||
loadSceneryDefinitions();
|
||||
|
||||
mHelipadsLoaded = true;
|
||||
mHelipads = flightgear::NavDataCache::instance()->airportItemsOfType(guid(), FGPositioned::HELIPAD);
|
||||
}
|
||||
|
||||
void FGAirport::loadTaxiways() const
|
||||
{
|
||||
if (mTaxiwaysLoaded) {
|
||||
|
|
|
@ -38,6 +38,7 @@
|
|||
// forward decls
|
||||
class FGAirportDynamics;
|
||||
class FGRunway;
|
||||
class FGHelipad;
|
||||
class FGTaxiway;
|
||||
class FGPavement;
|
||||
class SGPropertyNode;
|
||||
|
@ -102,7 +103,9 @@ public:
|
|||
FGAirportDynamics *getDynamics();
|
||||
|
||||
unsigned int numRunways() const;
|
||||
unsigned int numHelipads() const;
|
||||
FGRunway* getRunwayByIndex(unsigned int aIndex) const;
|
||||
FGHelipad* getHelipadByIndex(unsigned int aIndex) const;
|
||||
|
||||
bool hasRunwayWithIdent(const std::string& aIdent) const;
|
||||
FGRunway* getRunwayByIdent(const std::string& aIdent) const;
|
||||
|
@ -245,7 +248,7 @@ private:
|
|||
void validateTowerData() const;
|
||||
|
||||
/**
|
||||
* Helper to parse property data loaded from an ICAO.twr.xml filke
|
||||
* Helper to parse property data loaded from an ICAO.twr.xml file
|
||||
*/
|
||||
void readTowerData(SGPropertyNode* aRoot);
|
||||
|
||||
|
@ -254,16 +257,19 @@ private:
|
|||
FGAirportDynamics *_dynamics;
|
||||
|
||||
void loadRunways() const;
|
||||
void loadHelipads() const;
|
||||
void loadTaxiways() const;
|
||||
void loadProcedures() const;
|
||||
|
||||
mutable bool mTowerDataLoaded;
|
||||
mutable bool mRunwaysLoaded;
|
||||
mutable bool mHelipadsLoaded;
|
||||
mutable bool mTaxiwaysLoaded;
|
||||
mutable bool mProceduresLoaded;
|
||||
bool mILSDataLoaded;
|
||||
|
||||
mutable PositionedIDVec mRunways;
|
||||
mutable PositionedIDVec mHelipads;
|
||||
mutable PositionedIDVec mTaxiways;
|
||||
PositionedIDVec mPavements;
|
||||
|
||||
|
|
|
@ -1195,22 +1195,27 @@ void MapWidget::drawAirport(FGAirport* apt)
|
|||
}
|
||||
|
||||
for (unsigned int r=0; r<apt->numRunways(); ++r) {
|
||||
FGRunway* rwy = apt->getRunwayByIndex(r);
|
||||
if (!rwy->isReciprocal()) {
|
||||
drawRunwayPre(rwy);
|
||||
}
|
||||
FGRunway* rwy = apt->getRunwayByIndex(r);
|
||||
if (!rwy->isReciprocal()) {
|
||||
drawRunwayPre(rwy);
|
||||
}
|
||||
}
|
||||
|
||||
for (unsigned int r=0; r<apt->numRunways(); ++r) {
|
||||
FGRunway* rwy = apt->getRunwayByIndex(r);
|
||||
if (!rwy->isReciprocal()) {
|
||||
drawRunway(rwy);
|
||||
}
|
||||
for (unsigned int r=0; r<apt->numRunways(); ++r) {
|
||||
FGRunway* rwy = apt->getRunwayByIndex(r);
|
||||
if (!rwy->isReciprocal()) {
|
||||
drawRunway(rwy);
|
||||
}
|
||||
|
||||
if (rwy->ILS()) {
|
||||
drawILS(false, rwy);
|
||||
}
|
||||
} // of runway iteration
|
||||
if (rwy->ILS()) {
|
||||
drawILS(false, rwy);
|
||||
}
|
||||
}
|
||||
|
||||
for (unsigned int r=0; r<apt->numHelipads(); ++r) {
|
||||
FGHelipad* hp = apt->getHelipadByIndex(r);
|
||||
drawHelipad(hp);
|
||||
} // of runway iteration
|
||||
|
||||
}
|
||||
|
||||
|
@ -1392,6 +1397,32 @@ void MapWidget::drawTraffic()
|
|||
} // of ai/models iteration
|
||||
}
|
||||
|
||||
void MapWidget::drawHelipad(FGHelipad* hp)
|
||||
{
|
||||
SGVec2d pos = project(hp->geod());
|
||||
glLineWidth(1.0);
|
||||
glColor3f(1.0, 1.0, 1.0);
|
||||
circleAt(pos, 16, 5.0);
|
||||
|
||||
if (validDataForKey(hp)) {
|
||||
setAnchorForKey(hp, pos);
|
||||
return;
|
||||
}
|
||||
|
||||
char buffer[1024];
|
||||
::snprintf(buffer, 1024, "%s\n%03d\n%.0f'",
|
||||
hp->ident().c_str(),
|
||||
displayHeading(hp->headingDeg()),
|
||||
hp->lengthFt());
|
||||
|
||||
MapData* d = createDataForKey(hp);
|
||||
d->setText(buffer);
|
||||
d->setLabel(hp->ident());
|
||||
d->setPriority(40);
|
||||
d->setOffset(MapData::HALIGN_CENTER | MapData::VALIGN_BOTTOM, 8);
|
||||
d->setAnchor(pos);
|
||||
}
|
||||
|
||||
void MapWidget::drawAIAircraft(const SGPropertyNode* model, const SGGeod& pos, double hdg)
|
||||
{
|
||||
|
||||
|
|
|
@ -13,6 +13,7 @@
|
|||
// forward decls
|
||||
class FGRouteMgr;
|
||||
class FGRunway;
|
||||
class FGHelipad;
|
||||
class FGAirport;
|
||||
class FGNavRecord;
|
||||
class FGFix;
|
||||
|
@ -58,6 +59,7 @@ private:
|
|||
int scoreAirportRunways(FGAirport* apt);
|
||||
void drawRunwayPre(FGRunway* rwy);
|
||||
void drawRunway(FGRunway* rwy);
|
||||
void drawHelipad(FGHelipad* hp);
|
||||
void drawILS(bool tuned, FGRunway* rwy);
|
||||
|
||||
void drawNavaids();
|
||||
|
|
|
@ -71,7 +71,7 @@ using std::string;
|
|||
namespace {
|
||||
|
||||
const int MAX_RETRIES = 10;
|
||||
const int SCHEMA_VERSION = 6;
|
||||
const int SCHEMA_VERSION = 7;
|
||||
const int CACHE_SIZE_KBYTES= 16000;
|
||||
|
||||
// bind a std::string to a sqlite statement. The std::string must live the
|
||||
|
@ -724,6 +724,9 @@ public:
|
|||
if (ty == FGPositioned::TAXIWAY) {
|
||||
reset(loadRunwayStmt);
|
||||
return new FGTaxiway(rowId, id, pos, heading, lengthM, widthM, surface);
|
||||
} else if (ty == FGPositioned::HELIPAD) {
|
||||
reset(loadRunwayStmt);
|
||||
return new FGHelipad(rowId, apt, id, pos, heading, lengthM, widthM, surface);
|
||||
} else {
|
||||
double displacedThreshold = sqlite3_column_double(loadRunwayStmt, 4);
|
||||
double stopway = sqlite3_column_double(loadRunwayStmt, 5);
|
||||
|
@ -1020,6 +1023,7 @@ FGPositioned* NavDataCache::NavDataCachePrivate::loadById(sqlite3_int64 rowid)
|
|||
return new AirportTower(rowid, aptId, ident, pos);
|
||||
|
||||
case FGPositioned::RUNWAY:
|
||||
case FGPositioned::HELIPAD:
|
||||
case FGPositioned::TAXIWAY:
|
||||
return loadRunway(rowid, ty, ident, pos, aptId);
|
||||
|
||||
|
@ -1516,7 +1520,7 @@ NavDataCache::insertRunway(FGPositioned::Type ty, const string& ident,
|
|||
{
|
||||
// only runways are spatially indexed; don't bother indexing taxiways
|
||||
// or pavements
|
||||
bool spatialIndex = (ty == FGPositioned::RUNWAY);
|
||||
bool spatialIndex = ( ty == FGPositioned::RUNWAY || ty == FGPositioned::HELIPAD);
|
||||
|
||||
sqlite3_int64 rowId = d->insertPositioned(ty, cleanRunwayNo(ident), "", pos, apt,
|
||||
spatialIndex);
|
||||
|
|
|
@ -47,6 +47,7 @@ public:
|
|||
HELIPORT,
|
||||
SEAPORT,
|
||||
RUNWAY,
|
||||
HELIPAD,
|
||||
TAXIWAY,
|
||||
PAVEMENT,
|
||||
WAYPOINT,
|
||||
|
|
Loading…
Add table
Reference in a new issue