mirror of
https://github.com/swift-project/pilotclient.git
synced 2026-04-21 04:45:31 +08:00
Ref T292, Ref T285 removed model set loader from UI components and replaced by central cache
This commit is contained in:
@@ -49,9 +49,9 @@ namespace BlackGui
|
|||||||
connect(sGui->getWebDataServices()->getDatabaseWriter(), &CDatabaseWriter::publishedModels, this, &CDbQuickMappingWizard::onPublishedModels, Qt::QueuedConnection);
|
connect(sGui->getWebDataServices()->getDatabaseWriter(), &CDatabaseWriter::publishedModels, this, &CDbQuickMappingWizard::onPublishedModels, Qt::QueuedConnection);
|
||||||
|
|
||||||
connect(this, &CDbQuickMappingWizard::currentIdChanged, this, &CDbQuickMappingWizard::currentWizardPageChanged);
|
connect(this, &CDbQuickMappingWizard::currentIdChanged, this, &CDbQuickMappingWizard::currentWizardPageChanged);
|
||||||
connect(ui->selector_AircraftIcaoCode, &CDbAircraftIcaoSelectorComponent::changedAircraftIcao, this, &CDbQuickMappingWizard::onAircraftSelected);
|
connect(ui->selector_AircraftIcaoCode, &CDbAircraftIcaoSelectorComponent::changedAircraftIcao, this, &CDbQuickMappingWizard::onAircraftSelected, Qt::QueuedConnection);
|
||||||
connect(ui->selector_AirlineIcaoCode, &CDbAirlineIcaoSelectorComponent::changedAirlineIcao, this, &CDbQuickMappingWizard::onAirlineSelected);
|
connect(ui->selector_AirlineIcaoCode, &CDbAirlineIcaoSelectorComponent::changedAirlineIcao, this, &CDbQuickMappingWizard::onAirlineSelected, Qt::QueuedConnection);
|
||||||
connect(ui->selector_AirlineName, &CDbAirlineIcaoSelectorComponent::changedAirlineIcao, this, &CDbQuickMappingWizard::onAirlineSelected);
|
connect(ui->selector_AirlineName, &CDbAirlineIcaoSelectorComponent::changedAirlineIcao, this, &CDbQuickMappingWizard::onAirlineSelected, Qt::QueuedConnection);
|
||||||
|
|
||||||
ui->comp_Log->showFilterDialog(); // filter for log normally not needed, so dialog (not bar)
|
ui->comp_Log->showFilterDialog(); // filter for log normally not needed, so dialog (not bar)
|
||||||
|
|
||||||
|
|||||||
@@ -10,17 +10,18 @@
|
|||||||
#include "blackcore/webdataservices.h"
|
#include "blackcore/webdataservices.h"
|
||||||
#include "blackgui/components/distributorpreferencescomponent.h"
|
#include "blackgui/components/distributorpreferencescomponent.h"
|
||||||
#include "blackgui/components/simulatorselector.h"
|
#include "blackgui/components/simulatorselector.h"
|
||||||
#include "blackgui/guiapplication.h"
|
|
||||||
#include "blackgui/guiutility.h"
|
|
||||||
#include "blackgui/models/distributorlistmodel.h"
|
|
||||||
#include "blackgui/overlaymessagesframe.h"
|
|
||||||
#include "blackgui/views/distributorview.h"
|
#include "blackgui/views/distributorview.h"
|
||||||
#include "blackgui/views/viewbase.h"
|
#include "blackgui/views/viewbase.h"
|
||||||
#include "blackmisc/logmessage.h"
|
#include "blackgui/models/distributorlistmodel.h"
|
||||||
#include "blackmisc/orderable.h"
|
#include "blackgui/overlaymessagesframe.h"
|
||||||
|
#include "blackgui/guiapplication.h"
|
||||||
|
#include "blackgui/guiutility.h"
|
||||||
|
#include "blackmisc/simulation/data/modelcaches.h"
|
||||||
#include "blackmisc/simulation/aircraftmodellist.h"
|
#include "blackmisc/simulation/aircraftmodellist.h"
|
||||||
#include "blackmisc/simulation/distributor.h"
|
#include "blackmisc/simulation/distributor.h"
|
||||||
#include "blackmisc/simulation/distributorlistpreferences.h"
|
#include "blackmisc/simulation/distributorlistpreferences.h"
|
||||||
|
#include "blackmisc/logmessage.h"
|
||||||
|
#include "blackmisc/orderable.h"
|
||||||
#include "blackmisc/statusmessage.h"
|
#include "blackmisc/statusmessage.h"
|
||||||
#include "ui_distributorpreferencescomponent.h"
|
#include "ui_distributorpreferencescomponent.h"
|
||||||
|
|
||||||
@@ -29,9 +30,11 @@
|
|||||||
#include <QTimer>
|
#include <QTimer>
|
||||||
#include <Qt>
|
#include <Qt>
|
||||||
#include <QtGlobal>
|
#include <QtGlobal>
|
||||||
|
#include <QPointer>
|
||||||
|
|
||||||
using namespace BlackMisc;
|
using namespace BlackMisc;
|
||||||
using namespace BlackMisc::Simulation;
|
using namespace BlackMisc::Simulation;
|
||||||
|
using namespace BlackMisc::Simulation::Data;
|
||||||
using namespace BlackMisc::Network;
|
using namespace BlackMisc::Network;
|
||||||
using namespace BlackGui::Views;
|
using namespace BlackGui::Views;
|
||||||
using namespace BlackGui::Models;
|
using namespace BlackGui::Models;
|
||||||
@@ -41,110 +44,111 @@ namespace BlackGui
|
|||||||
namespace Components
|
namespace Components
|
||||||
{
|
{
|
||||||
CDistributorPreferencesComponent::CDistributorPreferencesComponent(QWidget *parent) :
|
CDistributorPreferencesComponent::CDistributorPreferencesComponent(QWidget *parent) :
|
||||||
QFrame(parent),
|
COverlayMessagesFrame(parent),
|
||||||
ui(new Ui::CDistributorPreferencesComponent)
|
ui(new Ui::CDistributorPreferencesComponent)
|
||||||
{
|
{
|
||||||
const CSimulatorInfo simulator = this->m_modelSetLoader.getSimulator();
|
|
||||||
|
|
||||||
ui->setupUi(this);
|
ui->setupUi(this);
|
||||||
ui->comp_SimulatorSelector->setMode(CSimulatorSelector::RadioButtons);
|
ui->comp_SimulatorSelector->setMode(CSimulatorSelector::RadioButtons);
|
||||||
ui->comp_SimulatorSelector->setRememberSelection(true);
|
ui->comp_SimulatorSelector->setRememberSelectionAndSetToLastSelection();
|
||||||
ui->comp_SimulatorSelector->setValue(simulator);
|
|
||||||
|
|
||||||
connect(ui->pb_All, &QPushButton::pressed, this, &CDistributorPreferencesComponent::ps_loadAll);
|
connect(ui->pb_All, &QPushButton::pressed, this, &CDistributorPreferencesComponent::loadAllDistributors);
|
||||||
connect(ui->pb_AllForSimulator, &QPushButton::pressed, this, &CDistributorPreferencesComponent::ps_loadAllForSimulator);
|
connect(ui->pb_AllForSimulator, &QPushButton::pressed, this, &CDistributorPreferencesComponent::loadDistributorsForSimulator);
|
||||||
connect(ui->pb_AllInSet, &QPushButton::pressed, this, &CDistributorPreferencesComponent::ps_loadDistributorsFromSet);
|
connect(ui->pb_AllInSet, &QPushButton::pressed, this, &CDistributorPreferencesComponent::loadDistributorsFromSet);
|
||||||
connect(ui->pb_Save, &QPushButton::pressed, this, &CDistributorPreferencesComponent::ps_save);
|
connect(ui->pb_Save, &QPushButton::pressed, this, &CDistributorPreferencesComponent::save);
|
||||||
connect(ui->comp_SimulatorSelector, &CSimulatorSelector::changed, this, &CDistributorPreferencesComponent::ps_simulatorChanged);
|
connect(ui->comp_SimulatorSelector, &CSimulatorSelector::changed, this, &CDistributorPreferencesComponent::onSimulatorChanged);
|
||||||
|
|
||||||
this->m_overlayMessageFrame = CGuiUtility::nextOverlayMessageFrame(this);
|
|
||||||
Q_ASSERT_X(this->m_overlayMessageFrame, Q_FUNC_INFO, "Missing message frame");
|
|
||||||
|
|
||||||
ui->tvp_Distributors->setDistributorMode(CDistributorListModel::NormalWithOrder);
|
ui->tvp_Distributors->setDistributorMode(CDistributorListModel::NormalWithOrder);
|
||||||
ui->tvp_Distributors->menuRemoveItems(CDistributorView::MenuBackend | CDistributorView::MenuDisplayAutomaticallyAndRefresh | CDistributorView::MenuLoadAndSave);
|
ui->tvp_Distributors->menuRemoveItems(CDistributorView::MenuBackend | CDistributorView::MenuDisplayAutomaticallyAndRefresh | CDistributorView::MenuLoadAndSave);
|
||||||
ui->tvp_Distributors->menuAddItems(CDistributorView::MenuClear | CDistributorView::MenuOrderable | CDistributorView::MenuRemoveSelectedRows);
|
ui->tvp_Distributors->menuAddItems(CDistributorView::MenuClear | CDistributorView::MenuOrderable | CDistributorView::MenuRemoveSelectedRows);
|
||||||
ui->tvp_Distributors->initAsOrderable();
|
ui->tvp_Distributors->initAsOrderable();
|
||||||
|
|
||||||
QTimer::singleShot(1000, this, &CDistributorPreferencesComponent::ps_deferredInit);
|
this->triggerDeferredSimulatorChange();
|
||||||
}
|
}
|
||||||
|
|
||||||
CDistributorPreferencesComponent::~CDistributorPreferencesComponent()
|
CDistributorPreferencesComponent::~CDistributorPreferencesComponent()
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
void CDistributorPreferencesComponent::ps_preferencesChanged()
|
void CDistributorPreferencesComponent::onPreferencesChanged()
|
||||||
{
|
{
|
||||||
// changed somewhere else
|
// changed somewhere else
|
||||||
const CSimulatorInfo sim(ui->comp_SimulatorSelector->getValue());
|
const CSimulatorInfo sim(ui->comp_SimulatorSelector->getValue());
|
||||||
const CDistributorList distributors = this->m_distributorPreferences.getThreadLocal().getDistributors(sim);
|
const CDistributorList distributors = m_distributorPreferences.getThreadLocal().getDistributors(sim);
|
||||||
this->updateContainerMaybeAsync(distributors);
|
this->updateContainerMaybeAsync(distributors);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CDistributorPreferencesComponent::ps_loadAll()
|
void CDistributorPreferencesComponent::loadAllDistributors()
|
||||||
{
|
{
|
||||||
Q_ASSERT_X(sGui, Q_FUNC_INFO, "Missing application");
|
Q_ASSERT_X(sGui, Q_FUNC_INFO, "Missing application");
|
||||||
const CDistributorList distributors(sGui->getWebDataServices()->getDistributors());
|
const CDistributorList distributors(sGui->getWebDataServices()->getDistributors());
|
||||||
if (distributors.isEmpty())
|
if (distributors.isEmpty())
|
||||||
{
|
{
|
||||||
const CStatusMessage m = CStatusMessage(this).error("No distributors");
|
const CStatusMessage m = CStatusMessage(this).error("No distributors");
|
||||||
this->m_overlayMessageFrame->showOverlayMessage(m);
|
this->showOverlayMessage(m);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
this->updateContainerMaybeAsync(distributors);
|
this->updateContainerMaybeAsync(distributors);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CDistributorPreferencesComponent::ps_loadAllForSimulator()
|
void CDistributorPreferencesComponent::loadDistributorsForSimulator()
|
||||||
{
|
{
|
||||||
const CSimulatorInfo sim(ui->comp_SimulatorSelector->getValue());
|
const CSimulatorInfo sim(ui->comp_SimulatorSelector->getValue());
|
||||||
const CDistributorList distributors(sGui->getWebDataServices()->getDistributors().matchesSimulator(sim));
|
const CDistributorList distributors(sGui->getWebDataServices()->getDistributors().matchesSimulator(sim));
|
||||||
if (distributors.isEmpty())
|
if (distributors.isEmpty())
|
||||||
{
|
{
|
||||||
const CStatusMessage m = CStatusMessage(this).error("No distributors, or no distributors matching %1") << sim.toQString();
|
const CStatusMessage m = CStatusMessage(this).error("No distributors, or no distributors matching %1") << sim.toQString();
|
||||||
this->m_overlayMessageFrame->showOverlayMessage(m);
|
this->showOverlayMessage(m);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
this->updateContainerMaybeAsync(distributors);
|
this->updateContainerMaybeAsync(distributors);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CDistributorPreferencesComponent::ps_loadDistributorsFromSet()
|
void CDistributorPreferencesComponent::loadDistributorsFromSet()
|
||||||
{
|
{
|
||||||
const CSimulatorInfo sim(ui->comp_SimulatorSelector->getValue());
|
const CSimulatorInfo sim(ui->comp_SimulatorSelector->getValue());
|
||||||
const CAircraftModelList models = this->m_modelSetLoader.getAircraftModels(sim);
|
const CAircraftModelList models = CCentralMultiSimulatorModelSetCachesProvider::modelCachesInstance().getCachedModels(sim);
|
||||||
if (models.isEmpty())
|
if (models.isEmpty())
|
||||||
{
|
{
|
||||||
const CStatusMessage m = CStatusMessage(this).error("No data in model set %1") << sim.toQString();
|
const CStatusMessage m = CStatusMessage(this).error("No data in model set %1") << sim.toQString();
|
||||||
this->m_overlayMessageFrame->showOverlayMessage(m);
|
this->showOverlayMessage(m);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
const CDistributorList distributors = models.getDistributors();
|
const CDistributorList distributors = models.getDistributors();
|
||||||
if (distributors.isEmpty())
|
if (distributors.isEmpty())
|
||||||
{
|
{
|
||||||
const CStatusMessage m = CStatusMessage(this).error("No distributors for model set %1") << sim.toQString();
|
const CStatusMessage m = CStatusMessage(this).error("No distributors for model set %1") << sim.toQString();
|
||||||
this->m_overlayMessageFrame->showOverlayMessage(m);
|
this->showOverlayMessage(m);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
this->updateContainerMaybeAsync(distributors);
|
this->updateContainerMaybeAsync(distributors);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CDistributorPreferencesComponent::ps_save()
|
void CDistributorPreferencesComponent::save()
|
||||||
{
|
{
|
||||||
const CDistributorList distributors(ui->tvp_Distributors->container());
|
const CDistributorList distributors(ui->tvp_Distributors->container());
|
||||||
const CSimulatorInfo simulator = ui->comp_SimulatorSelector->getValue();
|
const CSimulatorInfo simulator = ui->comp_SimulatorSelector->getValue();
|
||||||
CDistributorListPreferences preferences = this->m_distributorPreferences.getThreadLocal();
|
CDistributorListPreferences preferences = m_distributorPreferences.getThreadLocal();
|
||||||
preferences.setDistributors(distributors, simulator);
|
preferences.setDistributors(distributors, simulator);
|
||||||
const CStatusMessage m = this->m_distributorPreferences.setAndSave(preferences);
|
const CStatusMessage m = m_distributorPreferences.setAndSave(preferences);
|
||||||
CLogMessage::preformatted(m);
|
CLogMessage::preformatted(m);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CDistributorPreferencesComponent::ps_simulatorChanged(const CSimulatorInfo &simulator)
|
void CDistributorPreferencesComponent::onSimulatorChanged(const CSimulatorInfo &simulator)
|
||||||
{
|
{
|
||||||
Q_ASSERT_X(simulator.isSingleSimulator(), Q_FUNC_INFO, "Expect single simulator");
|
Q_ASSERT_X(simulator.isSingleSimulator(), Q_FUNC_INFO, "Expect single simulator");
|
||||||
const CDistributorList distributors(this->m_distributorPreferences.getThreadLocal().getDistributors(simulator));
|
const CDistributorList distributors(m_distributorPreferences.getThreadLocal().getDistributors(simulator));
|
||||||
ui->tvp_Distributors->updateContainerMaybeAsync(distributors);
|
ui->tvp_Distributors->updateContainerMaybeAsync(distributors);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CDistributorPreferencesComponent::ps_deferredInit()
|
void CDistributorPreferencesComponent::triggerDeferredSimulatorChange()
|
||||||
{
|
{
|
||||||
this->ps_simulatorChanged(ui->comp_SimulatorSelector->getValue());
|
QPointer<CDistributorPreferencesComponent> myself(this);
|
||||||
|
QTimer::singleShot(1000, this, [ = ]
|
||||||
|
{
|
||||||
|
if (!myself) { return; }
|
||||||
|
if (!sApp || sApp->isShuttingDown()) { return; }
|
||||||
|
const CSimulatorInfo sim = ui->comp_SimulatorSelector->getValue();
|
||||||
|
this->onSimulatorChanged(sim);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
void CDistributorPreferencesComponent::updateContainerMaybeAsync(const CDistributorList &models, bool sortByOrder)
|
void CDistributorPreferencesComponent::updateContainerMaybeAsync(const CDistributorList &models, bool sortByOrder)
|
||||||
|
|||||||
@@ -12,17 +12,14 @@
|
|||||||
#ifndef BLACKGUI_COMPONENTS_DISTRIBUTORPREFERENCESCOMPONENT_H
|
#ifndef BLACKGUI_COMPONENTS_DISTRIBUTORPREFERENCESCOMPONENT_H
|
||||||
#define BLACKGUI_COMPONENTS_DISTRIBUTORPREFERENCESCOMPONENT_H
|
#define BLACKGUI_COMPONENTS_DISTRIBUTORPREFERENCESCOMPONENT_H
|
||||||
|
|
||||||
#include "blackmisc/settingscache.h"
|
#include "blackgui/overlaymessagesframe.h"
|
||||||
#include "blackmisc/simulation/aircraftmodelsetloader.h"
|
|
||||||
#include "blackmisc/simulation/settings/modelsettings.h"
|
#include "blackmisc/simulation/settings/modelsettings.h"
|
||||||
#include "blackmisc/simulation/simulatorinfo.h"
|
#include "blackmisc/simulation/simulatorinfo.h"
|
||||||
|
#include "blackmisc/settingscache.h"
|
||||||
|
|
||||||
#include <QFrame>
|
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QScopedPointer>
|
#include <QScopedPointer>
|
||||||
|
|
||||||
class QWidget;
|
|
||||||
|
|
||||||
namespace Ui { class CDistributorPreferencesComponent; }
|
namespace Ui { class CDistributorPreferencesComponent; }
|
||||||
namespace BlackGui
|
namespace BlackGui
|
||||||
{
|
{
|
||||||
@@ -33,7 +30,7 @@ namespace BlackGui
|
|||||||
/*!
|
/*!
|
||||||
* Set and order distributors (to be used for model set)
|
* Set and order distributors (to be used for model set)
|
||||||
*/
|
*/
|
||||||
class CDistributorPreferencesComponent : public QFrame
|
class CDistributorPreferencesComponent : public COverlayMessagesFrame
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
@@ -44,33 +41,31 @@ namespace BlackGui
|
|||||||
//! Destructor
|
//! Destructor
|
||||||
virtual ~CDistributorPreferencesComponent();
|
virtual ~CDistributorPreferencesComponent();
|
||||||
|
|
||||||
private slots:
|
private:
|
||||||
//! Changed preferences
|
//! Changed preferences
|
||||||
void ps_preferencesChanged();
|
void onPreferencesChanged();
|
||||||
|
|
||||||
//! Load all distributors
|
//! Load all distributors
|
||||||
void ps_loadAll();
|
void loadAllDistributors();
|
||||||
|
|
||||||
//! Load all distributors for current simulator
|
//! Load all distributors for current simulator
|
||||||
void ps_loadAllForSimulator();
|
void loadDistributorsForSimulator();
|
||||||
|
|
||||||
//! Load distributors from set
|
//! Load distributors from set
|
||||||
void ps_loadDistributorsFromSet();
|
void loadDistributorsFromSet();
|
||||||
|
|
||||||
//! Save the preferences
|
//! Save the preferences
|
||||||
void ps_save();
|
void save();
|
||||||
|
|
||||||
//! Simulator has been changed
|
//! Simulator has been changed
|
||||||
void ps_simulatorChanged(const BlackMisc::Simulation::CSimulatorInfo &simulator);
|
void onSimulatorChanged(const BlackMisc::Simulation::CSimulatorInfo &simulator);
|
||||||
|
|
||||||
// Init
|
// Init
|
||||||
void ps_deferredInit();
|
void triggerDeferredSimulatorChange();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QScopedPointer<Ui::CDistributorPreferencesComponent> ui;
|
QScopedPointer<Ui::CDistributorPreferencesComponent> ui;
|
||||||
BlackGui::COverlayMessagesFrame *m_overlayMessageFrame = nullptr;
|
BlackMisc::CSetting<BlackMisc::Simulation::Settings::TDistributorListPreferences> m_distributorPreferences { this, &CDistributorPreferencesComponent::onPreferencesChanged };
|
||||||
BlackMisc::Simulation::CAircraftModelSetLoader m_modelSetLoader { this };
|
|
||||||
BlackMisc::CSetting<BlackMisc::Simulation::Settings::TDistributorListPreferences> m_distributorPreferences { this, &CDistributorPreferencesComponent::ps_preferencesChanged };
|
|
||||||
|
|
||||||
//! Update
|
//! Update
|
||||||
void updateContainerMaybeAsync(const BlackMisc::Simulation::CDistributorList &models, bool sortByOrder = true);
|
void updateContainerMaybeAsync(const BlackMisc::Simulation::CDistributorList &models, bool sortByOrder = true);
|
||||||
|
|||||||
@@ -93,8 +93,8 @@ namespace BlackGui
|
|||||||
ui->pb_CreateModelSet->setEnabled(modelsCount > 0);
|
ui->pb_CreateModelSet->setEnabled(modelsCount > 0);
|
||||||
|
|
||||||
static const QString modelsSetNo("Model set is empty");
|
static const QString modelsSetNo("Model set is empty");
|
||||||
const int modelsSetCount = this->modelSetLoader().getAircraftModelsCount();
|
const int modelsSetCount = m_modelSetDialog->modelSetComponent()->getModelSetCount();
|
||||||
ui->le_ModelSetInfo->setText(modelsSetCount > 0 ? this->modelSetLoader().getModelCacheCountAndTimestamp(simulator) : modelsSetNo);
|
ui->le_ModelSetInfo->setText(modelsSetCount > 0 ? m_modelSetDialog->modelSetComponent()->getModelCacheCountAndTimestamp() : modelsSetNo);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CFirstModelSetComponent::onSettingsChanged(const CSimulatorInfo &simulator)
|
void CFirstModelSetComponent::onSettingsChanged(const CSimulatorInfo &simulator)
|
||||||
@@ -142,11 +142,6 @@ namespace BlackGui
|
|||||||
return m_modelsDialog->modelsComponent()->modelLoader();
|
return m_modelsDialog->modelsComponent()->modelLoader();
|
||||||
}
|
}
|
||||||
|
|
||||||
const CAircraftModelSetLoader &CFirstModelSetComponent::modelSetLoader() const
|
|
||||||
{
|
|
||||||
return this->modelSetComponent()->modelSetLoader();
|
|
||||||
}
|
|
||||||
|
|
||||||
void CFirstModelSetComponent::openOwnModelsDialog()
|
void CFirstModelSetComponent::openOwnModelsDialog()
|
||||||
{
|
{
|
||||||
if (!sGui || sGui->isShuttingDown() || !sGui->getWebDataServices()) { return; }
|
if (!sGui || sGui->isShuttingDown() || !sGui->getWebDataServices()) { return; }
|
||||||
@@ -214,8 +209,8 @@ namespace BlackGui
|
|||||||
|
|
||||||
void CFirstModelSetComponent::createModelSet()
|
void CFirstModelSetComponent::createModelSet()
|
||||||
{
|
{
|
||||||
const CSimulatorInfo sim = ui->comp_SimulatorSelector->getValue();
|
const CSimulatorInfo simulator = ui->comp_SimulatorSelector->getValue();
|
||||||
const int modelsCount = this->modelLoader()->getCachedModelsCount(sim);
|
const int modelsCount = this->modelLoader()->getCachedModelsCount(simulator);
|
||||||
if (modelsCount < 1)
|
if (modelsCount < 1)
|
||||||
{
|
{
|
||||||
static const CStatusMessage msg = CStatusMessage(this).validationError("No models indexed so far. Try 'reload'!");
|
static const CStatusMessage msg = CStatusMessage(this).validationError("No models indexed so far. Try 'reload'!");
|
||||||
@@ -238,14 +233,14 @@ namespace BlackGui
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
CAircraftModelList modelsForSet = this->modelLoader()->getCachedModels(sim);
|
CAircraftModelList modelsForSet = this->modelLoader()->getCachedModels(simulator);
|
||||||
if (!useAllModels)
|
if (!useAllModels)
|
||||||
{
|
{
|
||||||
const CDistributorList distributors = ui->comp_Distributors->getSelectedDistributors();
|
const CDistributorList distributors = ui->comp_Distributors->getSelectedDistributors();
|
||||||
modelsForSet = modelsForSet.findByDistributors(distributors);
|
modelsForSet = modelsForSet.findByDistributors(distributors);
|
||||||
}
|
}
|
||||||
|
|
||||||
m_modelSetDialog->modelSetComponent()->setModelSet(modelsForSet, sim);
|
m_modelSetDialog->modelSetComponent()->setModelSet(modelsForSet, simulator);
|
||||||
ui->pb_ModelSet->click();
|
ui->pb_ModelSet->click();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -16,7 +16,6 @@
|
|||||||
#include "blackgui/overlaymessagesframe.h"
|
#include "blackgui/overlaymessagesframe.h"
|
||||||
#include "blackcore/application/applicationsettings.h"
|
#include "blackcore/application/applicationsettings.h"
|
||||||
#include "blackmisc/simulation/settings/simulatorsettings.h"
|
#include "blackmisc/simulation/settings/simulatorsettings.h"
|
||||||
#include "blackmisc/simulation/aircraftmodelsetloader.h"
|
|
||||||
#include "blackmisc/simulation/aircraftmodelloader.h"
|
#include "blackmisc/simulation/aircraftmodelloader.h"
|
||||||
#include "blackmisc/simulation/simulatorinfo.h"
|
#include "blackmisc/simulation/simulatorinfo.h"
|
||||||
#include "blackmisc/logcategorylist.h"
|
#include "blackmisc/logcategorylist.h"
|
||||||
@@ -75,9 +74,6 @@ namespace BlackGui
|
|||||||
//! Direct access to component's loader
|
//! Direct access to component's loader
|
||||||
BlackMisc::Simulation::IAircraftModelLoader *modelLoader() const;
|
BlackMisc::Simulation::IAircraftModelLoader *modelLoader() const;
|
||||||
|
|
||||||
//! Model set loader
|
|
||||||
const BlackMisc::Simulation::CAircraftModelSetLoader &modelSetLoader() const;
|
|
||||||
|
|
||||||
//! Open own models dialog
|
//! Open own models dialog
|
||||||
void openOwnModelsDialog();
|
void openOwnModelsDialog();
|
||||||
|
|
||||||
|
|||||||
@@ -122,8 +122,8 @@ namespace BlackGui
|
|||||||
ui->le_AircraftCombinedType->setMaxLength(3);
|
ui->le_AircraftCombinedType->setMaxLength(3);
|
||||||
ui->le_AircraftCombinedType->setValidator(new CUpperCaseValidator(this));
|
ui->le_AircraftCombinedType->setValidator(new CUpperCaseValidator(this));
|
||||||
connect(ui->le_AircraftCombinedType, &QLineEdit::editingFinished, this, &CLoginComponent::validateAircraftValues);
|
connect(ui->le_AircraftCombinedType, &QLineEdit::editingFinished, this, &CLoginComponent::validateAircraftValues);
|
||||||
connect(ui->selector_AircraftIcao, &CDbAircraftIcaoSelectorComponent::changedAircraftIcao, this, &CLoginComponent::changedAircraftIcao);
|
connect(ui->selector_AircraftIcao, &CDbAircraftIcaoSelectorComponent::changedAircraftIcao, this, &CLoginComponent::changedAircraftIcao, Qt::QueuedConnection);
|
||||||
connect(ui->selector_AirlineIcao, &CDbAirlineIcaoSelectorComponent::changedAirlineIcao, this, &CLoginComponent::changedAirlineIcao);
|
connect(ui->selector_AirlineIcao, &CDbAirlineIcaoSelectorComponent::changedAirlineIcao, this, &CLoginComponent::changedAirlineIcao, Qt::QueuedConnection);
|
||||||
connect(ui->tb_SimulatorIcaoReverseLookup, &QToolButton::clicked, this, &CLoginComponent::reverseLookupAircraftModel);
|
connect(ui->tb_SimulatorIcaoReverseLookup, &QToolButton::clicked, this, &CLoginComponent::reverseLookupAircraftModel);
|
||||||
|
|
||||||
if (sGui && sGui->getIContextSimulator())
|
if (sGui && sGui->getIContextSimulator())
|
||||||
|
|||||||
@@ -14,11 +14,12 @@
|
|||||||
#include "blackgui/components/dbliveryselectorcomponent.h"
|
#include "blackgui/components/dbliveryselectorcomponent.h"
|
||||||
#include "blackgui/components/modelmatchercomponent.h"
|
#include "blackgui/components/modelmatchercomponent.h"
|
||||||
#include "blackgui/components/simulatorselector.h"
|
#include "blackgui/components/simulatorselector.h"
|
||||||
|
#include "blackgui/models/statusmessagelistmodel.h"
|
||||||
|
#include "blackgui/views/statusmessageview.h"
|
||||||
|
#include "blackgui/uppercasevalidator.h"
|
||||||
#include "blackgui/guiapplication.h"
|
#include "blackgui/guiapplication.h"
|
||||||
#include "blackgui/guiutility.h"
|
#include "blackgui/guiutility.h"
|
||||||
#include "blackgui/models/statusmessagelistmodel.h"
|
#include "blackmisc/simulation/data/modelcaches.h"
|
||||||
#include "blackgui/uppercasevalidator.h"
|
|
||||||
#include "blackgui/views/statusmessageview.h"
|
|
||||||
#include "blackmisc/aviation/aircrafticaocode.h"
|
#include "blackmisc/aviation/aircrafticaocode.h"
|
||||||
#include "blackmisc/aviation/airlineicaocode.h"
|
#include "blackmisc/aviation/airlineicaocode.h"
|
||||||
#include "blackmisc/aviation/callsign.h"
|
#include "blackmisc/aviation/callsign.h"
|
||||||
@@ -40,6 +41,7 @@
|
|||||||
using namespace BlackMisc;
|
using namespace BlackMisc;
|
||||||
using namespace BlackMisc::Aviation;
|
using namespace BlackMisc::Aviation;
|
||||||
using namespace BlackMisc::Simulation;
|
using namespace BlackMisc::Simulation;
|
||||||
|
using namespace BlackMisc::Simulation::Data;
|
||||||
using namespace BlackMisc::Network;
|
using namespace BlackMisc::Network;
|
||||||
using namespace BlackGui::Models;
|
using namespace BlackGui::Models;
|
||||||
using namespace BlackCore;
|
using namespace BlackCore;
|
||||||
@@ -57,6 +59,7 @@ namespace BlackGui
|
|||||||
|
|
||||||
ui->setupUi(this);
|
ui->setupUi(this);
|
||||||
ui->comp_SimulatorSelector->setMode(CSimulatorSelector::RadioButtons);
|
ui->comp_SimulatorSelector->setMode(CSimulatorSelector::RadioButtons);
|
||||||
|
ui->comp_SimulatorSelector->setRememberSelectionAndSetToLastSelection();
|
||||||
ui->comp_AirlineSelector->displayWithIcaoDescription(false);
|
ui->comp_AirlineSelector->displayWithIcaoDescription(false);
|
||||||
ui->comp_AircraftSelector->displayWithIcaoDescription(false);
|
ui->comp_AircraftSelector->displayWithIcaoDescription(false);
|
||||||
ui->comp_LiverySelector->withLiveryDescription(false);
|
ui->comp_LiverySelector->withLiveryDescription(false);
|
||||||
@@ -72,8 +75,6 @@ namespace BlackGui
|
|||||||
connect(ui->pb_ReverseLookup, &QPushButton::pressed, this, &CModelMatcherComponent::reverseLookup);
|
connect(ui->pb_ReverseLookup, &QPushButton::pressed, this, &CModelMatcherComponent::reverseLookup);
|
||||||
connect(sGui->getWebDataServices(), &CWebDataServices::dataRead, this, &CModelMatcherComponent::onWebDataRed);
|
connect(sGui->getWebDataServices(), &CWebDataServices::dataRead, this, &CModelMatcherComponent::onWebDataRed);
|
||||||
|
|
||||||
const CSimulatorInfo sim(m_modelSetLoader.getSimulator());
|
|
||||||
ui->comp_SimulatorSelector->setValue(sim);
|
|
||||||
this->redisplay();
|
this->redisplay();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -91,11 +92,11 @@ namespace BlackGui
|
|||||||
this->redisplay();
|
this->redisplay();
|
||||||
}
|
}
|
||||||
|
|
||||||
void CModelMatcherComponent::onSimulatorChanged(const BlackMisc::Simulation::CSimulatorInfo &simulator)
|
void CModelMatcherComponent::onSimulatorChanged(const CSimulatorInfo &simulator)
|
||||||
{
|
{
|
||||||
Q_ASSERT_X(simulator.isSingleSimulator(), Q_FUNC_INFO, "Need single simulator");
|
Q_ASSERT_X(simulator.isSingleSimulator(), Q_FUNC_INFO, "Need single simulator");
|
||||||
m_modelSetLoader.setSimulator(simulator);
|
const CAircraftModelList models = CCentralMultiSimulatorModelSetCachesProvider::modelCachesInstance().getCachedModels(simulator);
|
||||||
m_matcher.setModelSet(m_modelSetLoader.getAircraftModels(), simulator);
|
m_matcher.setModelSet(models, simulator);
|
||||||
this->redisplay();
|
this->redisplay();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -147,10 +148,24 @@ namespace BlackGui
|
|||||||
|
|
||||||
void CModelMatcherComponent::redisplay()
|
void CModelMatcherComponent::redisplay()
|
||||||
{
|
{
|
||||||
const int c = m_modelSetLoader.getAircraftModelsCount();
|
const int c = this->getModelSetModelsCount();
|
||||||
ui->le_ModelSetCount->setText(QString::number(c));
|
ui->le_ModelSetCount->setText(QString::number(c));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CAircraftModelList CModelMatcherComponent::getModelSetModels() const
|
||||||
|
{
|
||||||
|
const CSimulatorInfo simulator = ui->comp_SimulatorSelector->getValue();
|
||||||
|
const CAircraftModelList models = CCentralMultiSimulatorModelSetCachesProvider::modelCachesInstance().getCachedModels(simulator);
|
||||||
|
return models;
|
||||||
|
}
|
||||||
|
|
||||||
|
int CModelMatcherComponent::getModelSetModelsCount() const
|
||||||
|
{
|
||||||
|
const CSimulatorInfo simulator = ui->comp_SimulatorSelector->getValue();
|
||||||
|
const int modelCount = CCentralMultiSimulatorModelSetCachesProvider::modelCachesInstance().getCachedModelsCount(simulator);
|
||||||
|
return modelCount;
|
||||||
|
}
|
||||||
|
|
||||||
CSimulatedAircraft CModelMatcherComponent::createAircraft() const
|
CSimulatedAircraft CModelMatcherComponent::createAircraft() const
|
||||||
{
|
{
|
||||||
const QString airline(ui->comp_AirlineSelector->getRawDesignator());
|
const QString airline(ui->comp_AirlineSelector->getRawDesignator());
|
||||||
|
|||||||
@@ -16,7 +16,6 @@
|
|||||||
#include "blackgui/blackguiexport.h"
|
#include "blackgui/blackguiexport.h"
|
||||||
#include "blackmisc/network/entityflags.h"
|
#include "blackmisc/network/entityflags.h"
|
||||||
#include "blackmisc/simulation/aircraftmodel.h"
|
#include "blackmisc/simulation/aircraftmodel.h"
|
||||||
#include "blackmisc/simulation/aircraftmodelsetloader.h"
|
|
||||||
#include "blackmisc/simulation/simulatedaircraft.h"
|
#include "blackmisc/simulation/simulatedaircraft.h"
|
||||||
#include "blackmisc/simulation/simulatorinfo.h"
|
#include "blackmisc/simulation/simulatorinfo.h"
|
||||||
|
|
||||||
@@ -24,8 +23,6 @@
|
|||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QScopedPointer>
|
#include <QScopedPointer>
|
||||||
|
|
||||||
class QWidget;
|
|
||||||
|
|
||||||
namespace Ui { class CModelMatcherComponent; }
|
namespace Ui { class CModelMatcherComponent; }
|
||||||
namespace BlackGui
|
namespace BlackGui
|
||||||
{
|
{
|
||||||
@@ -67,6 +64,12 @@ namespace BlackGui
|
|||||||
//! Init
|
//! Init
|
||||||
void redisplay();
|
void redisplay();
|
||||||
|
|
||||||
|
//! The current model set models
|
||||||
|
BlackMisc::Simulation::CAircraftModelList getModelSetModels() const;
|
||||||
|
|
||||||
|
//! The current model set models size
|
||||||
|
int getModelSetModelsCount() const;
|
||||||
|
|
||||||
//! Pseudo aircraft created from entries
|
//! Pseudo aircraft created from entries
|
||||||
BlackMisc::Simulation::CSimulatedAircraft createAircraft() const;
|
BlackMisc::Simulation::CSimulatedAircraft createAircraft() const;
|
||||||
|
|
||||||
@@ -74,7 +77,6 @@ namespace BlackGui
|
|||||||
BlackMisc::Simulation::CAircraftModel defaultModel() const;
|
BlackMisc::Simulation::CAircraftModel defaultModel() const;
|
||||||
|
|
||||||
QScopedPointer<Ui::CModelMatcherComponent> ui;
|
QScopedPointer<Ui::CModelMatcherComponent> ui;
|
||||||
BlackMisc::Simulation::CAircraftModelSetLoader m_modelSetLoader { this };
|
|
||||||
BlackCore::CAircraftMatcher m_matcher { BlackCore::CAircraftMatcher::All, this };
|
BlackCore::CAircraftMatcher m_matcher { BlackCore::CAircraftMatcher::All, this };
|
||||||
};
|
};
|
||||||
} // ns
|
} // ns
|
||||||
|
|||||||
Reference in New Issue
Block a user