diff --git a/src/comm/QGCFlightGearLink.cc b/src/comm/QGCFlightGearLink.cc index 4a044c8403d57a95c59291ba812e353b2eb1b169..dd9696db51f51071423102d858f0127d6c6d5dbf 100644 --- a/src/comm/QGCFlightGearLink.cc +++ b/src/comm/QGCFlightGearLink.cc @@ -481,7 +481,7 @@ bool QGCFlightGearLink::connectSimulation() processFgfs = "/Applications/FlightGear.app/Contents/Resources/fgfs"; processTerraSync = "/Applications/FlightGear.app/Contents/Resources/terrasync"; //fgRoot = "/Applications/FlightGear.app/Contents/Resources/data"; - //fgScenery = "/Applications/FlightGear.app/Contents/Resources/data/Scenery"; + fgScenery = "/Applications/FlightGear.app/Contents/Resources/data/Scenery"; terraSyncScenery = "/Applications/FlightGear.app/Contents/Resources/data/Scenery-TerraSync"; // /Applications/FlightGear.app/Contents/Resources/data/Scenery: #endif @@ -489,13 +489,22 @@ bool QGCFlightGearLink::connectSimulation() #ifdef Q_OS_WIN32 processFgfs = "C:\\Program Files (x86)\\FlightGear\\bin\\Win32\\fgfs"; //fgRoot = "C:\\Program Files (x86)\\FlightGear\\data"; + fgScenery = "C:\\Program Files (x86)\\FlightGear\\data\\Scenery" terraSyncScenery = "C:\\Program Files (x86)\\FlightGear\\data\\Scenery-Terrasync"; #endif #ifdef Q_OS_LINUX processFgfs = "fgfs"; - //fgRoot = "/usr/share/games/flightgear"; - //fgScenery = "/usr/share/games/flightgear/Scenery/"; + //fgRoot = "/usr/share/flightgear"; + QString fgScenery1 = "/usr/share/flightgear/data/Scenery"; + QString fgScenery2 = "/usr/share/games/flightgear/Scenery"; // Ubuntu default location + fgScenery = ""; //Flightgear can also start with fgScenery = "" + if (QDir(fgScenery1).exists()) + fgScenery = fgScenery1; + else if (QDir(fgScenery2).exists()) + fgScenery = fgScenery2; + + processTerraSync = "nice"; //according to http://wiki.flightgear.org/TerraSync, run with lower priority terraSyncScenery = QDir::homePath() + "/.terrasync/Scenery"; //according to http://wiki.flightgear.org/TerraSync a separate directory is used #endif @@ -540,7 +549,7 @@ bool QGCFlightGearLink::connectSimulation() /*Prepare FlightGear Arguments */ //flightGearArguments << QString("--fg-root=%1").arg(fgRoot); - flightGearArguments << QString("--fg-scenery=%1:%2").arg(terraSyncScenery); //according to http://wiki.flightgear.org/TerraSync a separate directory is used + flightGearArguments << QString("--fg-scenery=%1:%2").arg(fgScenery).arg(terraSyncScenery); //according to http://wiki.flightgear.org/TerraSync a separate directory is used flightGearArguments << QString("--fg-aircraft=%1").arg(fgAircraft); if (mav->getSystemType() == MAV_TYPE_QUADROTOR) {