mirror of
https://github.com/swift-project/pilotclient.git
synced 2026-03-30 20:15:35 +08:00
* added unload function to disconnect signals / slots and simulator * changed remote provider to return signal/slot connections to manually disconnect functor connects * flag so pause can freeze or continue AI aircraft * slightly changed unload behaviour in simulator context Remark: Tested for FSX only Solves #424 for FSX
146 lines
6.0 KiB
C++
146 lines
6.0 KiB
C++
/* Copyright (C) 2015
|
|
* swift project Community / Contributors
|
|
*
|
|
* This file is part of swift project. It is subject to the license terms in the LICENSE file found in the top-level
|
|
* directory of this distribution and at http://www.swift-project.org/license.html. No part of swift project,
|
|
* including this file, may be copied, modified, propagated, or distributed except according to the terms
|
|
* contained in the LICENSE file.
|
|
*/
|
|
|
|
#include "remoteaircraftproviderdummy.h"
|
|
|
|
using namespace BlackMisc::Aviation;
|
|
|
|
namespace BlackMisc
|
|
{
|
|
namespace Simulation
|
|
{
|
|
|
|
CRemoteAircraftProviderDummy::CRemoteAircraftProviderDummy(QObject *parent) : QObject(parent)
|
|
{ }
|
|
|
|
CSimulatedAircraftList CRemoteAircraftProviderDummy::getAircraftInRange() const
|
|
{
|
|
return m_aircraft;
|
|
}
|
|
|
|
int CRemoteAircraftProviderDummy::getAircraftInRangeCount() const
|
|
{
|
|
return m_aircraft.size();
|
|
}
|
|
|
|
CSimulatedAircraft CRemoteAircraftProviderDummy::getAircraftInRangeForCallsign(const CCallsign &callsign) const
|
|
{
|
|
return m_aircraft.findFirstByCallsign(callsign);
|
|
}
|
|
|
|
CAirspaceAircraftSnapshot CRemoteAircraftProviderDummy::getLatestAirspaceAircraftSnapshot() const
|
|
{
|
|
return CAirspaceAircraftSnapshot(m_aircraft);
|
|
}
|
|
|
|
CAircraftPartsList CRemoteAircraftProviderDummy::remoteAircraftParts(const BlackMisc::Aviation::CCallsign &callsign, qint64 cutoffTimeBefore) const
|
|
{
|
|
if (cutoffTimeBefore < 0) { return m_parts.findByCallsign(callsign); }
|
|
return m_parts.findByCallsign(callsign).findBefore(cutoffTimeBefore);
|
|
}
|
|
|
|
CAircraftSituationList CRemoteAircraftProviderDummy::remoteAircraftSituations(const BlackMisc::Aviation::CCallsign &callsign) const
|
|
{
|
|
return m_situations.findByCallsign(callsign);
|
|
}
|
|
|
|
int CRemoteAircraftProviderDummy::remoteAircraftSituationsCount(const CCallsign &callsign) const
|
|
{
|
|
return remoteAircraftSituations(callsign).size();
|
|
}
|
|
|
|
CCallsignSet CRemoteAircraftProviderDummy::remoteAircraftSupportingParts() const
|
|
{
|
|
return m_parts.getCallsigns();
|
|
}
|
|
|
|
bool CRemoteAircraftProviderDummy::isRemoteAircraftSupportingParts(const CCallsign &callsign) const
|
|
{
|
|
return remoteAircraftParts(callsign).size() > 0;
|
|
}
|
|
|
|
QList<QMetaObject::Connection> CRemoteAircraftProviderDummy::connectRemoteAircraftProviderSignals(
|
|
std::function<void (const CAircraftSituation &)> situationSlot,
|
|
std::function<void (const CAircraftParts &)> partsSlot,
|
|
std::function<void (const CCallsign &)> removedAircraftSlot,
|
|
std::function<void (const CAirspaceAircraftSnapshot &)> aircraftSnapshotSlot
|
|
)
|
|
{
|
|
QList<QMetaObject::Connection> c(
|
|
{
|
|
connect(this, &CRemoteAircraftProviderDummy::addedRemoteAircraftSituation, situationSlot) ,
|
|
connect(this, &CRemoteAircraftProviderDummy::addedRemoteAircraftParts, partsSlot) ,
|
|
connect(this, &CRemoteAircraftProviderDummy::removedRemoteAircraft, removedAircraftSlot) ,
|
|
connect(this, &CRemoteAircraftProviderDummy::airspaceAircraftSnapshot, aircraftSnapshotSlot)
|
|
});
|
|
return c;
|
|
}
|
|
|
|
bool CRemoteAircraftProviderDummy::updateAircraftEnabled(const CCallsign &callsign, bool enabledForRendering, const QString &originator)
|
|
{
|
|
Q_UNUSED(originator);
|
|
CPropertyIndexVariantMap vm(CSimulatedAircraft::IndexEnabled, CVariant::fromValue(enabledForRendering));
|
|
int n = this->m_aircraft.applyIfCallsign(callsign, vm);
|
|
return n > 0;
|
|
}
|
|
|
|
bool CRemoteAircraftProviderDummy::updateAircraftModel(const CCallsign &callsign, const CAircraftModel &model, const QString &originator)
|
|
{
|
|
Q_UNUSED(originator);
|
|
CPropertyIndexVariantMap vm(CSimulatedAircraft::IndexModel, model.toCVariant());
|
|
int n = this->m_aircraft.applyIfCallsign(callsign, vm);
|
|
return n > 0;
|
|
}
|
|
|
|
bool CRemoteAircraftProviderDummy::updateFastPositionEnabled(const CCallsign &callsign, bool enableFastPositionUpdates, const QString &originator)
|
|
{
|
|
Q_UNUSED(originator);
|
|
CPropertyIndexVariantMap vm(CSimulatedAircraft::IndexFastPositionUpdates, CVariant::fromValue(enableFastPositionUpdates));
|
|
int n = this->m_aircraft.applyIfCallsign(callsign, vm);
|
|
return n > 0;
|
|
}
|
|
|
|
bool CRemoteAircraftProviderDummy::updateAircraftRendered(const CCallsign &callsign, bool rendered, const QString &originator)
|
|
{
|
|
Q_UNUSED(originator);
|
|
CPropertyIndexVariantMap vm(CSimulatedAircraft::IndexRendered, CVariant::fromValue(rendered));
|
|
int n = this->m_aircraft.applyIfCallsign(callsign, vm);
|
|
return n > 0;
|
|
}
|
|
|
|
void CRemoteAircraftProviderDummy::updateMarkAllAsNotRendered(const QString &originator)
|
|
{
|
|
Q_UNUSED(originator);
|
|
this->m_aircraft.markAllAsNotRendered();
|
|
}
|
|
|
|
void CRemoteAircraftProviderDummy::insertNewSituation(const CAircraftSituation &situation)
|
|
{
|
|
this->m_situations.push_front(situation);
|
|
this->m_situations.sortLatestFirst(); // like in real world, latest should be first
|
|
emit addedRemoteAircraftSituation(situation);
|
|
}
|
|
|
|
void CRemoteAircraftProviderDummy::insertNewAircraftParts(const CAircraftParts &parts)
|
|
{
|
|
this->m_parts.push_front(parts);
|
|
this->m_parts.sortLatestFirst(); // like in real world, latest should be first
|
|
emit addedRemoteAircraftParts(parts);
|
|
}
|
|
|
|
void CRemoteAircraftProviderDummy::clear()
|
|
{
|
|
m_situations.clear();
|
|
m_parts.clear();
|
|
m_aircraft.clear();
|
|
}
|
|
|
|
} // namespace
|
|
} // namespace
|