mirror of
https://github.com/swift-project/pilotclient.git
synced 2026-05-03 16:21:41 +08:00
refs #452 updated drivers
* FSX/FS9 directories directly resolved in parser * all: using BlackMisc::Simulation::CSimulatedAircraft instead of CAircraft
This commit is contained in:
committed by
Mathew Sutcliffe
parent
dbcc540313
commit
a8e8e5527a
@@ -35,7 +35,6 @@ using namespace BlackMisc::Simulation::FsCommon;
|
|||||||
using namespace BlackSimPlugin::Fs9;
|
using namespace BlackSimPlugin::Fs9;
|
||||||
using namespace BlackSimPlugin::FsCommon;
|
using namespace BlackSimPlugin::FsCommon;
|
||||||
|
|
||||||
|
|
||||||
namespace
|
namespace
|
||||||
{
|
{
|
||||||
/* These instances should be global, as they are shared between all classes
|
/* These instances should be global, as they are shared between all classes
|
||||||
@@ -54,8 +53,7 @@ namespace BlackSimPlugin
|
|||||||
IRemoteAircraftProvider *remoteAircraftProvider,
|
IRemoteAircraftProvider *remoteAircraftProvider,
|
||||||
IPluginStorageProvider *pluginStorageProvider,
|
IPluginStorageProvider *pluginStorageProvider,
|
||||||
QObject *parent) :
|
QObject *parent) :
|
||||||
CSimulatorFsCommon(info, ownAircraftProvider, remoteAircraftProvider, pluginStorageProvider,
|
CSimulatorFsCommon(info, ownAircraftProvider, remoteAircraftProvider, pluginStorageProvider, parent)
|
||||||
aircraftObjectsDir(), excludeDirectories(), parent)
|
|
||||||
{
|
{
|
||||||
connect(lobbyClient.data(), &CLobbyClient::disconnected, this, std::bind(&CSimulatorFs9::simulatorStatusChanged, this, 0));
|
connect(lobbyClient.data(), &CLobbyClient::disconnected, this, std::bind(&CSimulatorFs9::simulatorStatusChanged, this, 0));
|
||||||
this->m_interpolator = new BlackCore::CInterpolatorLinear(remoteAircraftProvider, this);
|
this->m_interpolator = new BlackCore::CInterpolatorLinear(remoteAircraftProvider, this);
|
||||||
@@ -63,7 +61,7 @@ namespace BlackSimPlugin
|
|||||||
"Boeing 737-400",
|
"Boeing 737-400",
|
||||||
CAircraftModel::TypeModelMatchingDefaultModel,
|
CAircraftModel::TypeModelMatchingDefaultModel,
|
||||||
"B737-400 default model",
|
"B737-400 default model",
|
||||||
CAircraftIcaoData(CAircraftIcaoCode("B734", "L2J"), CAirlineIcaoCode())
|
CAircraftIcaoCode("B734", "L2J")
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -165,7 +163,7 @@ namespace BlackSimPlugin
|
|||||||
return CCollection<CCallsign>(this->m_hashFs9Clients.keys());
|
return CCollection<CCallsign>(this->m_hashFs9Clients.keys());
|
||||||
}
|
}
|
||||||
|
|
||||||
bool CSimulatorFs9::updateOwnSimulatorCockpit(const CAircraft &ownAircraft, const CIdentifier &originator)
|
bool CSimulatorFs9::updateOwnSimulatorCockpit(const CSimulatedAircraft &ownAircraft, const CIdentifier &originator)
|
||||||
{
|
{
|
||||||
if (originator == this->identifier()) { return false; }
|
if (originator == this->identifier()) { return false; }
|
||||||
if (!this->isSimulating()) { return false; }
|
if (!this->isSimulating()) { return false; }
|
||||||
@@ -295,7 +293,7 @@ namespace BlackSimPlugin
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSimulatorFs9::updateOwnAircraftFromSimulator(const CAircraft &simDataOwnAircraft)
|
void CSimulatorFs9::updateOwnAircraftFromSimulator(const CSimulatedAircraft &simDataOwnAircraft)
|
||||||
{
|
{
|
||||||
this->updateCockpit(
|
this->updateCockpit(
|
||||||
simDataOwnAircraft.getCom1System(),
|
simDataOwnAircraft.getCom1System(),
|
||||||
@@ -313,21 +311,6 @@ namespace BlackSimPlugin
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
QString CSimulatorFs9::aircraftObjectsDir()
|
|
||||||
{
|
|
||||||
QString dir = CFsCommonUtil::fs9AircraftDirFromRegistry();
|
|
||||||
if (!dir.isEmpty()) { return dir; }
|
|
||||||
return "C:/Flight Simulator 9/Aircraft";
|
|
||||||
}
|
|
||||||
|
|
||||||
const QStringList &CSimulatorFs9::excludeDirectories()
|
|
||||||
{
|
|
||||||
static const QStringList exclude
|
|
||||||
{
|
|
||||||
};
|
|
||||||
return exclude;
|
|
||||||
}
|
|
||||||
|
|
||||||
CSimulatorFs9Listener::CSimulatorFs9Listener(const CSimulatorPluginInfo &info) :
|
CSimulatorFs9Listener::CSimulatorFs9Listener(const CSimulatorPluginInfo &info) :
|
||||||
BlackCore::ISimulatorListener(info),
|
BlackCore::ISimulatorListener(info),
|
||||||
m_timer(new QTimer(this))
|
m_timer(new QTimer(this))
|
||||||
|
|||||||
@@ -18,8 +18,7 @@
|
|||||||
#include "../fscommon/simulator_fscommon.h"
|
#include "../fscommon/simulator_fscommon.h"
|
||||||
#include "blackcore/simulator.h"
|
#include "blackcore/simulator.h"
|
||||||
#include "blackcore/interpolator.h"
|
#include "blackcore/interpolator.h"
|
||||||
#include "blackmisc/simulation/aircraftmodel.h"
|
#include "blackmisc/simulation/simulatedaircraft.h"
|
||||||
#include "blackmisc/aviation/aircraft.h"
|
|
||||||
#include "blackmisc/simulation/simulatorplugininfo.h"
|
#include "blackmisc/simulation/simulatorplugininfo.h"
|
||||||
#include "blackmisc/pixmap.h"
|
#include "blackmisc/pixmap.h"
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
@@ -71,7 +70,7 @@ namespace BlackSimPlugin
|
|||||||
virtual bool isPhysicallyRenderedAircraft(const BlackMisc::Aviation::CCallsign &callsign) const override;
|
virtual bool isPhysicallyRenderedAircraft(const BlackMisc::Aviation::CCallsign &callsign) const override;
|
||||||
|
|
||||||
//! \copydoc ISimulator::updateOwnSimulatorCockpit()
|
//! \copydoc ISimulator::updateOwnSimulatorCockpit()
|
||||||
virtual bool updateOwnSimulatorCockpit(const BlackMisc::Aviation::CAircraft &ownAircraft, const BlackMisc::CIdentifier &originator) override;
|
virtual bool updateOwnSimulatorCockpit(const BlackMisc::Simulation::CSimulatedAircraft &ownAircraft, const BlackMisc::CIdentifier &originator) override;
|
||||||
|
|
||||||
//! \copydoc ISimulator::displayStatusMessage()
|
//! \copydoc ISimulator::displayStatusMessage()
|
||||||
virtual void displayStatusMessage(const BlackMisc::CStatusMessage &message) const override;
|
virtual void displayStatusMessage(const BlackMisc::CStatusMessage &message) const override;
|
||||||
@@ -100,17 +99,10 @@ namespace BlackSimPlugin
|
|||||||
private:
|
private:
|
||||||
|
|
||||||
//! Called when data about our own aircraft are received
|
//! Called when data about our own aircraft are received
|
||||||
void updateOwnAircraftFromSimulator(const BlackMisc::Aviation::CAircraft &ownAircraft);
|
void updateOwnAircraftFromSimulator(const BlackMisc::Simulation::CSimulatedAircraft &ownAircraft);
|
||||||
|
|
||||||
void disconnectAllClients();
|
void disconnectAllClients();
|
||||||
|
|
||||||
//! Aircraft object directory
|
|
||||||
//! \todo Read from settings if registry fails
|
|
||||||
static QString aircraftObjectsDir();
|
|
||||||
|
|
||||||
//! Do not include the following directories for FS
|
|
||||||
static const QStringList &excludeDirectories();
|
|
||||||
|
|
||||||
QHash<BlackMisc::Aviation::CCallsign, QPointer<CFs9Client>> m_hashFs9Clients;
|
QHash<BlackMisc::Aviation::CCallsign, QPointer<CFs9Client>> m_hashFs9Clients;
|
||||||
QMetaObject::Connection m_connectionHostMessages;
|
QMetaObject::Connection m_connectionHostMessages;
|
||||||
int m_dispatchTimerId = -1;
|
int m_dispatchTimerId = -1;
|
||||||
|
|||||||
@@ -30,12 +30,10 @@ namespace BlackSimPlugin
|
|||||||
IOwnAircraftProvider *ownAircraftProvider,
|
IOwnAircraftProvider *ownAircraftProvider,
|
||||||
IRemoteAircraftProvider *renderedAircraftProvider,
|
IRemoteAircraftProvider *renderedAircraftProvider,
|
||||||
IPluginStorageProvider *pluginStorageProvider,
|
IPluginStorageProvider *pluginStorageProvider,
|
||||||
QString simRootDirectory,
|
|
||||||
QStringList excludedDirectories,
|
|
||||||
QObject *parent) :
|
QObject *parent) :
|
||||||
CSimulatorCommon(info, ownAircraftProvider, renderedAircraftProvider, pluginStorageProvider, parent),
|
CSimulatorCommon(info, ownAircraftProvider, renderedAircraftProvider, pluginStorageProvider, parent),
|
||||||
m_fsuipc(new CFsuipc()),
|
m_fsuipc(new CFsuipc()),
|
||||||
m_aircraftCfgParser(simRootDirectory, excludedDirectories),
|
m_aircraftCfgParser(CAircraftCfgParser::createModelLoader(CSimulatorInfo(info.getIdentifier()))),
|
||||||
m_modelMatcher(CAircraftMatcher::AllModes, this)
|
m_modelMatcher(CAircraftMatcher::AllModes, this)
|
||||||
{
|
{
|
||||||
// hack to init mapper
|
// hack to init mapper
|
||||||
@@ -43,16 +41,19 @@ namespace BlackSimPlugin
|
|||||||
auto modelMappingsProvider = std::unique_ptr<IModelMappingsProvider> { BlackMisc::make_unique<CModelMappingsProviderVPilot>(true) };
|
auto modelMappingsProvider = std::unique_ptr<IModelMappingsProvider> { BlackMisc::make_unique<CModelMappingsProviderVPilot>(true) };
|
||||||
m_modelMatcher.setModelMappingProvider(std::move(modelMappingsProvider));
|
m_modelMatcher.setModelMappingProvider(std::move(modelMappingsProvider));
|
||||||
|
|
||||||
connect(&m_aircraftCfgParser, &CAircraftCfgParser::parsingFinished, this, &CSimulatorFsCommon::ps_aircraftCfgParsingFinished);
|
bool c = connect(m_aircraftCfgParser.data(), &CAircraftCfgParser::loadingFinished, this, &CSimulatorFsCommon::ps_aircraftCfgParsingFinished);
|
||||||
|
Q_ASSERT_X(c, Q_FUNC_INFO, "Cannot connect signal");
|
||||||
|
Q_UNUSED(c);
|
||||||
|
|
||||||
CVariant aircraftCfg = getPluginData(this, "aircraft_cfg");
|
CVariant aircraftCfg = getPluginData(this, "aircraft_cfg");
|
||||||
if (aircraftCfg.isValid())
|
if (aircraftCfg.isValid())
|
||||||
{
|
{
|
||||||
// will behave like parsing was finished
|
// will behave like parsing was finished
|
||||||
m_aircraftCfgParser.updateCfgEntriesList(aircraftCfg.value<CAircraftCfgEntriesList>());
|
m_aircraftCfgParser->updateCfgEntriesList(aircraftCfg.value<CAircraftCfgEntriesList>());
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
m_aircraftCfgParser.parse(CAircraftCfgParser::ModeAsync);
|
m_aircraftCfgParser->startLoading(CAircraftCfgParser::ModeBackground);
|
||||||
}
|
}
|
||||||
//
|
//
|
||||||
// reading from cache / settings would go here
|
// reading from cache / settings would go here
|
||||||
@@ -111,23 +112,11 @@ namespace BlackSimPlugin
|
|||||||
{
|
{
|
||||||
CAircraftModel newModel(model);
|
CAircraftModel newModel(model);
|
||||||
newModel.setModelType(CAircraftModel::TypeOwnSimulatorModel);
|
newModel.setModelType(CAircraftModel::TypeOwnSimulatorModel);
|
||||||
CSimulatorFsCommon::reverseLookupIcaoData(newModel);
|
|
||||||
updateOwnModel(newModel);
|
updateOwnModel(newModel);
|
||||||
emit ownAircraftModelChanged(getOwnAircraft());
|
emit ownAircraftModelChanged(getOwnAircraft());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSimulatorFsCommon::reverseLookupIcaoData(CAircraftModel &model)
|
|
||||||
{
|
|
||||||
if (m_modelMatcher.isInitialized())
|
|
||||||
{
|
|
||||||
// reverse lookup of ICAO
|
|
||||||
CAircraftIcaoData icao = m_modelMatcher.getIcaoForModelString(model.getModelString());
|
|
||||||
icao.updateMissingParts(model.getIcao());
|
|
||||||
model.setIcao(icao); // now best ICAO info in model
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
CAircraftModel CSimulatorFsCommon::getClosestMatch(const CSimulatedAircraft &remoteAircraft)
|
CAircraftModel CSimulatorFsCommon::getClosestMatch(const CSimulatedAircraft &remoteAircraft)
|
||||||
{
|
{
|
||||||
return m_modelMatcher.getClosestMatch(remoteAircraft);
|
return m_modelMatcher.getClosestMatch(remoteAircraft);
|
||||||
@@ -138,46 +127,17 @@ namespace BlackSimPlugin
|
|||||||
return m_modelMatcher.getInstalledModelsList();
|
return m_modelMatcher.getInstalledModelsList();
|
||||||
}
|
}
|
||||||
|
|
||||||
CAircraftIcaoData CSimulatorFsCommon::getIcaoForModelString(const QString &modelString) const
|
|
||||||
{
|
|
||||||
if (!m_modelMatcher.isInitialized()) { return CAircraftIcaoData(); }
|
|
||||||
return m_modelMatcher.getIcaoForModelString(modelString);
|
|
||||||
}
|
|
||||||
|
|
||||||
void CSimulatorFsCommon::reloadInstalledModels()
|
void CSimulatorFsCommon::reloadInstalledModels()
|
||||||
{
|
{
|
||||||
m_aircraftCfgParser.parse();
|
m_aircraftCfgParser->startLoading();
|
||||||
}
|
}
|
||||||
|
|
||||||
CPixmap CSimulatorFsCommon::iconForModel(const QString &modelString) const
|
CPixmap CSimulatorFsCommon::iconForModel(const QString &modelString) const
|
||||||
{
|
{
|
||||||
static const CPixmap empty;
|
CStatusMessage msg;
|
||||||
if (modelString.isEmpty()) { return empty; }
|
CPixmap pm(m_aircraftCfgParser->iconForModel(modelString, msg));
|
||||||
CAircraftCfgEntriesList cfgEntries = m_aircraftCfgParser.getAircraftCfgEntriesList().findByTitle(modelString);
|
if (!msg.isEmpty()) { CLogMessage(this).preformatted(msg);}
|
||||||
if (cfgEntries.isEmpty())
|
return pm;
|
||||||
{
|
|
||||||
CLogMessage(this).warning("No .cfg entry for '%1'") << modelString;
|
|
||||||
return empty;
|
|
||||||
}
|
|
||||||
|
|
||||||
// normally we should have only one entry
|
|
||||||
if (cfgEntries.size() > 1)
|
|
||||||
{
|
|
||||||
CLogMessage(this).warning("Multiple FSX .cfg entries for '%1'") << modelString;
|
|
||||||
}
|
|
||||||
|
|
||||||
// use first with icon
|
|
||||||
for (const CAircraftCfgEntries &entry : cfgEntries)
|
|
||||||
{
|
|
||||||
const QString thumbnail = entry.getThumbnailFileName();
|
|
||||||
if (thumbnail.isEmpty()) { continue; }
|
|
||||||
QPixmap pm;
|
|
||||||
if (pm.load(thumbnail))
|
|
||||||
{
|
|
||||||
return CPixmap(pm);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return empty;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool CSimulatorFsCommon::changeRemoteAircraftModel(const CSimulatedAircraft &aircraft, const CIdentifier &originator)
|
bool CSimulatorFsCommon::changeRemoteAircraftModel(const CSimulatedAircraft &aircraft, const CIdentifier &originator)
|
||||||
@@ -214,7 +174,7 @@ namespace BlackSimPlugin
|
|||||||
|
|
||||||
void CSimulatorFsCommon::unload()
|
void CSimulatorFsCommon::unload()
|
||||||
{
|
{
|
||||||
this->m_aircraftCfgParser.cancelParsing();
|
this->m_aircraftCfgParser->cancelLoading();
|
||||||
this->m_modelMatcher.cancelInit();
|
this->m_modelMatcher.cancelInit();
|
||||||
CSimulatorCommon::unload();
|
CSimulatorCommon::unload();
|
||||||
}
|
}
|
||||||
@@ -222,8 +182,8 @@ namespace BlackSimPlugin
|
|||||||
void CSimulatorFsCommon::ps_aircraftCfgParsingFinished(bool success)
|
void CSimulatorFsCommon::ps_aircraftCfgParsingFinished(bool success)
|
||||||
{
|
{
|
||||||
if (!success) { return; }
|
if (!success) { return; }
|
||||||
setPluginData(this, "aircraft_cfg", CVariant::from(m_aircraftCfgParser.getAircraftCfgEntriesList()));
|
setPluginData(this, "aircraft_cfg", CVariant::from(m_aircraftCfgParser->getAircraftCfgEntriesList()));
|
||||||
m_modelMatcher.setInstalledModels(m_aircraftCfgParser.getAircraftCfgEntriesList().toAircraftModelList());
|
m_modelMatcher.setInstalledModels(m_aircraftCfgParser->getAircraftCfgEntriesList().toAircraftModelList());
|
||||||
|
|
||||||
// Now the matcher has all required information to be initialized
|
// Now the matcher has all required information to be initialized
|
||||||
m_modelMatcher.init();
|
m_modelMatcher.init();
|
||||||
|
|||||||
@@ -58,9 +58,6 @@ namespace BlackSimPlugin
|
|||||||
//! \copydoc ISimulator::getInstalledModels
|
//! \copydoc ISimulator::getInstalledModels
|
||||||
virtual BlackMisc::Simulation::CAircraftModelList getInstalledModels() const override;
|
virtual BlackMisc::Simulation::CAircraftModelList getInstalledModels() const override;
|
||||||
|
|
||||||
//! \copydoc ISimulator::getIcaoForModelString
|
|
||||||
virtual BlackMisc::Aviation::CAircraftIcaoData getIcaoForModelString(const QString &modelString) const override;
|
|
||||||
|
|
||||||
//! \copydoc ISimulator::reloadInstalledModels
|
//! \copydoc ISimulator::reloadInstalledModels
|
||||||
virtual void reloadInstalledModels() override;
|
virtual void reloadInstalledModels() override;
|
||||||
|
|
||||||
@@ -85,8 +82,6 @@ namespace BlackSimPlugin
|
|||||||
BlackMisc::Simulation::IOwnAircraftProvider *ownAircraftProvider,
|
BlackMisc::Simulation::IOwnAircraftProvider *ownAircraftProvider,
|
||||||
BlackMisc::Simulation::IRemoteAircraftProvider *renderedAircraftProvider,
|
BlackMisc::Simulation::IRemoteAircraftProvider *renderedAircraftProvider,
|
||||||
BlackMisc::IPluginStorageProvider *pluginStorageProvider,
|
BlackMisc::IPluginStorageProvider *pluginStorageProvider,
|
||||||
QString simRootDirectory,
|
|
||||||
QStringList excludedDirectories,
|
|
||||||
QObject *parent = nullptr);
|
QObject *parent = nullptr);
|
||||||
|
|
||||||
QString simulatorDetails; //!< describes version etc.
|
QString simulatorDetails; //!< describes version etc.
|
||||||
@@ -103,7 +98,7 @@ namespace BlackSimPlugin
|
|||||||
BlackMisc::Aviation::CTransponder m_simTransponder; //!< cockpit xpdr state in simulator
|
BlackMisc::Aviation::CTransponder m_simTransponder; //!< cockpit xpdr state in simulator
|
||||||
|
|
||||||
// parser / matcher
|
// parser / matcher
|
||||||
BlackMisc::Simulation::FsCommon::CAircraftCfgParser m_aircraftCfgParser; //!< aircraft.cfg parser
|
QScopedPointer<BlackMisc::Simulation::FsCommon::CAircraftCfgParser> m_aircraftCfgParser; //!< aircraft.cfg parser
|
||||||
BlackMisc::Simulation::CAircraftMatcher m_modelMatcher; //!< Model matcher
|
BlackMisc::Simulation::CAircraftMatcher m_modelMatcher; //!< Model matcher
|
||||||
|
|
||||||
//! Set own model
|
//! Set own model
|
||||||
@@ -112,9 +107,6 @@ namespace BlackSimPlugin
|
|||||||
//! Set own model
|
//! Set own model
|
||||||
void setOwnAircraftModel(const QString &modelName);
|
void setOwnAircraftModel(const QString &modelName);
|
||||||
|
|
||||||
//! Reverse lookup
|
|
||||||
void reverseLookupIcaoData(BlackMisc::Simulation::CAircraftModel &model);
|
|
||||||
|
|
||||||
protected slots:
|
protected slots:
|
||||||
//! Mapper has been initialized
|
//! Mapper has been initialized
|
||||||
void ps_mapperInitialized();
|
void ps_mapperInitialized();
|
||||||
|
|||||||
@@ -18,7 +18,6 @@
|
|||||||
#include "blackmisc/project.h"
|
#include "blackmisc/project.h"
|
||||||
#include "blackmisc/aviation/airportlist.h"
|
#include "blackmisc/aviation/airportlist.h"
|
||||||
#include "blackmisc/logmessage.h"
|
#include "blackmisc/logmessage.h"
|
||||||
#include "blackmisc/network/aircraftmappinglist.h"
|
|
||||||
#include "blackmisc/simulation/fscommon/fscommonutil.h"
|
#include "blackmisc/simulation/fscommon/fscommonutil.h"
|
||||||
|
|
||||||
#include <QTimer>
|
#include <QTimer>
|
||||||
@@ -44,8 +43,7 @@ namespace BlackSimPlugin
|
|||||||
IRemoteAircraftProvider *remoteAircraftProvider,
|
IRemoteAircraftProvider *remoteAircraftProvider,
|
||||||
IPluginStorageProvider *pluginStorageProvider,
|
IPluginStorageProvider *pluginStorageProvider,
|
||||||
QObject *parent) :
|
QObject *parent) :
|
||||||
CSimulatorFsCommon(info, ownAircraftProvider, remoteAircraftProvider, pluginStorageProvider,
|
CSimulatorFsCommon(info, ownAircraftProvider, remoteAircraftProvider, pluginStorageProvider, parent)
|
||||||
simObjectsDir(), excludeDirectories(), parent)
|
|
||||||
{
|
{
|
||||||
Q_ASSERT(ownAircraftProvider);
|
Q_ASSERT(ownAircraftProvider);
|
||||||
Q_ASSERT(remoteAircraftProvider);
|
Q_ASSERT(remoteAircraftProvider);
|
||||||
@@ -57,7 +55,7 @@ namespace BlackSimPlugin
|
|||||||
"Boeing 737-800 Paint1",
|
"Boeing 737-800 Paint1",
|
||||||
CAircraftModel::TypeModelMatchingDefaultModel,
|
CAircraftModel::TypeModelMatchingDefaultModel,
|
||||||
"B737-800 default model",
|
"B737-800 default model",
|
||||||
CAircraftIcaoData(CAircraftIcaoCode("B738", "L2J"), CAirlineIcaoCode())
|
CAircraftIcaoCode("B738", "L2J")
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -179,7 +177,7 @@ namespace BlackSimPlugin
|
|||||||
return rendered;
|
return rendered;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool CSimulatorFsx::updateOwnSimulatorCockpit(const CAircraft &ownAircraft, const CIdentifier &originator)
|
bool CSimulatorFsx::updateOwnSimulatorCockpit(const CSimulatedAircraft &ownAircraft, const CIdentifier &originator)
|
||||||
{
|
{
|
||||||
if (originator == this->identifier()) { return false; }
|
if (originator == this->identifier()) { return false; }
|
||||||
if (!this->isSimulating()) { return false; }
|
if (!this->isSimulating()) { return false; }
|
||||||
@@ -825,26 +823,6 @@ namespace BlackSimPlugin
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
QString CSimulatorFsx::simObjectsDir()
|
|
||||||
{
|
|
||||||
QString dir = CFsCommonUtil::fsxSimObjectsDirFromRegistry();
|
|
||||||
if (!dir.isEmpty()) { return dir; }
|
|
||||||
return "P:/FlightSimulatorX (MSI)/SimObjects";
|
|
||||||
// "p:/temp/SimObjects"
|
|
||||||
}
|
|
||||||
|
|
||||||
const QStringList &CSimulatorFsx::excludeDirectories()
|
|
||||||
{
|
|
||||||
static const QStringList exclude
|
|
||||||
{
|
|
||||||
"SimObjects/Animals",
|
|
||||||
"SimObjects/Misc",
|
|
||||||
"SimObjects/GroundVehicles",
|
|
||||||
"SimObjects/Boats"
|
|
||||||
};
|
|
||||||
return exclude;
|
|
||||||
}
|
|
||||||
|
|
||||||
CSimulatorFsxListener::CSimulatorFsxListener(const CSimulatorPluginInfo &info) :
|
CSimulatorFsxListener::CSimulatorFsxListener(const CSimulatorPluginInfo &info) :
|
||||||
ISimulatorListener(info),
|
ISimulatorListener(info),
|
||||||
m_timer(new QTimer(this))
|
m_timer(new QTimer(this))
|
||||||
|
|||||||
@@ -103,7 +103,7 @@ namespace BlackSimPlugin
|
|||||||
virtual int physicallyRemoveAllRemoteAircraft() override;
|
virtual int physicallyRemoveAllRemoteAircraft() override;
|
||||||
|
|
||||||
//! \copydoc ISimulator::updateOwnCockpit
|
//! \copydoc ISimulator::updateOwnCockpit
|
||||||
virtual bool updateOwnSimulatorCockpit(const BlackMisc::Aviation::CAircraft &ownAircraft, const BlackMisc::CIdentifier &originator) override;
|
virtual bool updateOwnSimulatorCockpit(const BlackMisc::Simulation::CSimulatedAircraft &ownAircraft, const BlackMisc::CIdentifier &originator) override;
|
||||||
|
|
||||||
//! \copydoc ISimulator::displayStatusMessage
|
//! \copydoc ISimulator::displayStatusMessage
|
||||||
virtual void displayStatusMessage(const BlackMisc::CStatusMessage &message) const override;
|
virtual void displayStatusMessage(const BlackMisc::CStatusMessage &message) const override;
|
||||||
@@ -179,13 +179,6 @@ namespace BlackSimPlugin
|
|||||||
//! Sync time with user's computer
|
//! Sync time with user's computer
|
||||||
void synchronizeTime(const BlackMisc::PhysicalQuantities::CTime &zuluTimeSim, const BlackMisc::PhysicalQuantities::CTime &localTimeSim);
|
void synchronizeTime(const BlackMisc::PhysicalQuantities::CTime &zuluTimeSim, const BlackMisc::PhysicalQuantities::CTime &localTimeSim);
|
||||||
|
|
||||||
//! SimObjects directory
|
|
||||||
//! \todo Read from settings if registry fails
|
|
||||||
static QString simObjectsDir();
|
|
||||||
|
|
||||||
//! Do not include the following directories for FS
|
|
||||||
static const QStringList &excludeDirectories();
|
|
||||||
|
|
||||||
static const int SkipUpdateCyclesForCockpit = 10; //!< skip x cycles before updating cockpit again
|
static const int SkipUpdateCyclesForCockpit = 10; //!< skip x cycles before updating cockpit again
|
||||||
bool m_simConnected = false; //!< Is simulator connected?
|
bool m_simConnected = false; //!< Is simulator connected?
|
||||||
bool m_simSimulating = false; //!< Simulator running?
|
bool m_simSimulating = false; //!< Simulator running?
|
||||||
|
|||||||
@@ -66,7 +66,7 @@ namespace BlackSimPlugin
|
|||||||
"__A319/A319_CFM.obj __A319/DAL.png",
|
"__A319/A319_CFM.obj __A319/DAL.png",
|
||||||
CAircraftModel::TypeModelMatchingDefaultModel,
|
CAircraftModel::TypeModelMatchingDefaultModel,
|
||||||
"A319 CFM DAL",
|
"A319 CFM DAL",
|
||||||
CAircraftIcaoData(CAircraftIcaoCode("A319", "L2J"), CAirlineIcaoCode())
|
CAircraftIcaoCode("A319", "L2J")
|
||||||
));
|
));
|
||||||
|
|
||||||
resetData();
|
resetData();
|
||||||
@@ -115,7 +115,7 @@ namespace BlackSimPlugin
|
|||||||
situation.setGroundspeed({ m_xplaneData.groundspeed, CSpeedUnit::m_s() });
|
situation.setGroundspeed({ m_xplaneData.groundspeed, CSpeedUnit::m_s() });
|
||||||
|
|
||||||
// updates
|
// updates
|
||||||
updateOwnIcaoData(Aviation::CAircraftIcaoData { m_xplaneData.aircraftIcaoCode });
|
updateOwnIcaoCodes(m_xplaneData.aircraftIcaoCode, CAirlineIcaoCode());
|
||||||
updateOwnSituation(situation);
|
updateOwnSituation(situation);
|
||||||
updateCockpit(
|
updateCockpit(
|
||||||
Aviation::CComSystem::getCom1System({ m_xplaneData.com1Active, CFrequencyUnit::kHz() }, { m_xplaneData.com1Standby, CFrequencyUnit::kHz() }),
|
Aviation::CComSystem::getCom1System({ m_xplaneData.com1Active, CFrequencyUnit::kHz() }, { m_xplaneData.com1Standby, CFrequencyUnit::kHz() }),
|
||||||
@@ -171,12 +171,12 @@ namespace BlackSimPlugin
|
|||||||
auto liveriesIt = liveries.begin();
|
auto liveriesIt = liveries.begin();
|
||||||
for (; modelStringsIt != modelStrings.end() && icaosIt != icaos.end() && airlinesIt != airlines.end() && liveriesIt != liveries.end(); ++modelStringsIt, ++icaosIt, ++airlinesIt, ++liveriesIt)
|
for (; modelStringsIt != modelStrings.end() && icaosIt != icaos.end() && airlinesIt != airlines.end() && liveriesIt != liveries.end(); ++modelStringsIt, ++icaosIt, ++airlinesIt, ++liveriesIt)
|
||||||
{
|
{
|
||||||
using namespace BlackMisc::Simulation;
|
|
||||||
CAircraftIcaoData icaoData {*icaosIt, *airlinesIt};
|
|
||||||
CLivery livery; //! \todo resolve livery
|
|
||||||
Q_UNUSED(liveriesIt);
|
Q_UNUSED(liveriesIt);
|
||||||
CAircraftModel aircraftModel { *modelStringsIt, CAircraftModel::TypeModelMapping, QString(), icaoData };
|
using namespace BlackMisc::Simulation;
|
||||||
aircraftModel.setLivery(livery);
|
CAircraftIcaoCode aircraftIcao(*icaosIt);
|
||||||
|
CLivery livery; //! \todo resolve livery
|
||||||
|
livery.setAirlineIcaoCode(CAirlineIcaoCode(*airlinesIt));
|
||||||
|
CAircraftModel aircraftModel(*modelStringsIt, CAircraftModel::TypeDatabaseEntry, QString(), aircraftIcao, livery);
|
||||||
m_installedModels.push_back(aircraftModel);
|
m_installedModels.push_back(aircraftModel);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -246,18 +246,19 @@ namespace BlackSimPlugin
|
|||||||
|
|
||||||
void CSimulatorXPlane::ps_emitOwnAircraftModelChanged(const QString &path, const QString &filename, const QString &livery, const QString &icao)
|
void CSimulatorXPlane::ps_emitOwnAircraftModelChanged(const QString &path, const QString &filename, const QString &livery, const QString &icao)
|
||||||
{
|
{
|
||||||
|
Q_UNUSED(icao);
|
||||||
|
|
||||||
//! \todo XP, change as appropriate, add resolution of own livery
|
//! \todo XP, change as appropriate, add resolution of own livery
|
||||||
// try to set correct model and ICAO values here
|
// try to set correct model and ICAO values here
|
||||||
// thy show up in GUI
|
// thy show up in GUI
|
||||||
CAircraftModel model(getOwnAircraftModel());
|
CAircraftModel model(getOwnAircraftModel());
|
||||||
CAirlineIcaoCode airlineIcao(model.getAirlineIcaoCode());
|
CAirlineIcaoCode airlineIcaoCode(model.getAirlineIcaoCode());
|
||||||
model.setModelType(CAircraftModel::TypeOwnSimulatorModel);
|
model.setModelType(CAircraftModel::TypeOwnSimulatorModel);
|
||||||
model.setFileName(path + "/" + filename);
|
model.setFileName(path + "/" + filename);
|
||||||
model.setLivery(CLivery("XPLANE." + livery, airlineIcao, "XP livery", "", "", false));
|
model.setLivery(CLivery("XPLANE." + livery, airlineIcaoCode, "XP livery", "", "", false));
|
||||||
CAircraftIcaoData aircraftIcao(icao);
|
|
||||||
|
|
||||||
// updates
|
// updates
|
||||||
updateOwnIcaoData(aircraftIcao);
|
updateOwnIcaoCodes(model.getAircraftIcaoCode(), airlineIcaoCode);
|
||||||
updateOwnModel(model);
|
updateOwnModel(model);
|
||||||
emit ownAircraftModelChanged(getOwnAircraft());
|
emit ownAircraftModelChanged(getOwnAircraft());
|
||||||
}
|
}
|
||||||
@@ -341,7 +342,7 @@ namespace BlackSimPlugin
|
|||||||
return getAircraftInRangeForCallsign(callsign).isRendered();
|
return getAircraftInRangeForCallsign(callsign).isRendered();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool CSimulatorXPlane::updateOwnSimulatorCockpit(const BlackMisc::Aviation::CAircraft &aircraft, const CIdentifier &originator)
|
bool CSimulatorXPlane::updateOwnSimulatorCockpit(const BlackMisc::Simulation::CSimulatedAircraft &aircraft, const CIdentifier &originator)
|
||||||
{
|
{
|
||||||
Q_ASSERT(isConnected());
|
Q_ASSERT(isConnected());
|
||||||
if (originator == this->identifier()) { return false; }
|
if (originator == this->identifier()) { return false; }
|
||||||
@@ -383,9 +384,11 @@ namespace BlackSimPlugin
|
|||||||
this->updateAircraftModel(callsign, aircraftModel, identifier());
|
this->updateAircraftModel(callsign, aircraftModel, identifier());
|
||||||
CSimulatedAircraft aircraftAfterModelApplied(getAircraftInRangeForCallsign(newRemoteAircraft.getCallsign()));
|
CSimulatedAircraft aircraftAfterModelApplied(getAircraftInRangeForCallsign(newRemoteAircraft.getCallsign()));
|
||||||
|
|
||||||
CAircraftIcaoData icao = newRemoteAircraft.getIcaoInfo();
|
|
||||||
QString livery = aircraftModel.getLivery().getCombinedCode(); //! \todo livery resolution for XP
|
QString livery = aircraftModel.getLivery().getCombinedCode(); //! \todo livery resolution for XP
|
||||||
m_traffic->addPlane(newRemoteAircraft.getCallsign().asString(), aircraftModel.getModelString(), icao.getAircraftDesignator(), icao.getAirlineDesignator(), livery);
|
m_traffic->addPlane(newRemoteAircraft.getCallsign().asString(), aircraftModel.getModelString(),
|
||||||
|
newRemoteAircraft.getAircraftIcaoCode().getDesignator(),
|
||||||
|
newRemoteAircraft.getAirlineIcaoCode().getDesignator(),
|
||||||
|
livery);
|
||||||
updateAircraftRendered(newRemoteAircraft.getCallsign(), true, identifier());
|
updateAircraftRendered(newRemoteAircraft.getCallsign(), true, identifier());
|
||||||
CLogMessage(this).info("XP: Added aircraft %1") << newRemoteAircraft.getCallsign().toQString();
|
CLogMessage(this).info("XP: Added aircraft %1") << newRemoteAircraft.getCallsign().toQString();
|
||||||
|
|
||||||
@@ -458,12 +461,6 @@ namespace BlackSimPlugin
|
|||||||
return this->changeRemoteAircraftEnabled(aircraft, originator);
|
return this->changeRemoteAircraftEnabled(aircraft, originator);
|
||||||
}
|
}
|
||||||
|
|
||||||
CAircraftIcaoData CSimulatorXPlane::getIcaoForModelString(const QString &modelString) const
|
|
||||||
{
|
|
||||||
Q_UNUSED(modelString);
|
|
||||||
return CAircraftIcaoData();
|
|
||||||
}
|
|
||||||
|
|
||||||
bool CSimulatorXPlane::changeRemoteAircraftEnabled(const CSimulatedAircraft &aircraft, const CIdentifier &originator)
|
bool CSimulatorXPlane::changeRemoteAircraftEnabled(const CSimulatedAircraft &aircraft, const CIdentifier &originator)
|
||||||
{
|
{
|
||||||
if (originator == this->identifier()) { return false; }
|
if (originator == this->identifier()) { return false; }
|
||||||
|
|||||||
@@ -44,9 +44,6 @@ namespace BlackSimPlugin
|
|||||||
//! \copydoc ISimulator::isTimeSynchronized
|
//! \copydoc ISimulator::isTimeSynchronized
|
||||||
virtual bool isTimeSynchronized() const override { return false; } // TODO: Can we query the XP intrinisc feature?
|
virtual bool isTimeSynchronized() const override { return false; } // TODO: Can we query the XP intrinisc feature?
|
||||||
|
|
||||||
//! \copydoc BlackCore::ISimulator::getIcaoForModelString
|
|
||||||
virtual BlackMisc::Aviation::CAircraftIcaoData getIcaoForModelString(const QString &modelString) const override;
|
|
||||||
|
|
||||||
//! \copydoc BlackCore::ISimulator::connectTo
|
//! \copydoc BlackCore::ISimulator::connectTo
|
||||||
virtual bool connectTo() override;
|
virtual bool connectTo() override;
|
||||||
|
|
||||||
@@ -75,7 +72,7 @@ namespace BlackSimPlugin
|
|||||||
virtual bool changeRemoteAircraftEnabled(const BlackMisc::Simulation::CSimulatedAircraft &aircraft, const BlackMisc::CIdentifier &originator) override;
|
virtual bool changeRemoteAircraftEnabled(const BlackMisc::Simulation::CSimulatedAircraft &aircraft, const BlackMisc::CIdentifier &originator) override;
|
||||||
|
|
||||||
//! \copydoc BlackCore::ISimulator::updateOwnSimulatorCockpit
|
//! \copydoc BlackCore::ISimulator::updateOwnSimulatorCockpit
|
||||||
virtual bool updateOwnSimulatorCockpit(const BlackMisc::Aviation::CAircraft &aircraft, const BlackMisc::CIdentifier &originator) override;
|
virtual bool updateOwnSimulatorCockpit(const BlackMisc::Simulation::CSimulatedAircraft &aircraft, const BlackMisc::CIdentifier &originator) override;
|
||||||
|
|
||||||
//! \copydoc BlackCore::ISimulator::displayStatusMessage
|
//! \copydoc BlackCore::ISimulator::displayStatusMessage
|
||||||
virtual void displayStatusMessage(const BlackMisc::CStatusMessage &message) const override;
|
virtual void displayStatusMessage(const BlackMisc::CStatusMessage &message) const override;
|
||||||
|
|||||||
Reference in New Issue
Block a user