Issue #37 Reset FPS counter when network is connected

This commit is contained in:
Mat Sutcliffe
2021-08-09 00:11:03 +01:00
parent 81d2dbbac9
commit a89ca2d59a
6 changed files with 30 additions and 1 deletions

View File

@@ -226,6 +226,15 @@ namespace BlackSimPlugin
CSimulatorPluginCommon::callbackReceivedRequestedElevation(plane, callsign, isWater);
}
void CSimulatorXPlane::setFlightNetworkConnected(bool connected)
{
if (connected && !this->isShuttingDownOrDisconnected())
{
m_serviceProxy->resetFrameTotals();
}
CSimulatorPluginCommon::setFlightNetworkConnected(connected);
}
bool CSimulatorXPlane::isSuspiciousTerrainValue(const CElevationPlane &elevation)
{
if (!elevation.hasMSLGeodeticHeight()) { return true; }

View File

@@ -146,6 +146,7 @@ namespace BlackSimPlugin
virtual bool testSendSituationAndParts(const BlackMisc::Aviation::CCallsign &callsign, const BlackMisc::Aviation::CAircraftSituation &situation, const BlackMisc::Aviation::CAircraftParts &parts) override;
virtual void injectWeatherGrid(const BlackMisc::Weather::CWeatherGrid &weatherGrid) override;
virtual void callbackReceivedRequestedElevation(const BlackMisc::Geo::CElevationPlane &plane, const BlackMisc::Aviation::CCallsign &callsign, bool isWater) override;
virtual void setFlightNetworkConnected(bool connected) override;
//! @}
//! \copydoc BlackMisc::Simulation::ISimulationEnvironmentProvider::requestElevation

View File

@@ -358,6 +358,11 @@ namespace BlackSimPlugin
m_dbusInterface->callDBusAsync(QLatin1String("getFrameStats"), callback);
}
void CXSwiftBusServiceProxy::resetFrameTotals()
{
m_dbusInterface->callDBus(QLatin1String("resetFrameTotals"));
}
double CXSwiftBusServiceProxy::getLatitudeDeg() const
{
return m_dbusInterface->callDBusRet<double>(QLatin1String("getLatitudeDeg"));
@@ -746,5 +751,6 @@ namespace BlackSimPlugin
{
m_dbusInterface->callDBus(QLatin1String("setSettingsJson"), json);
}
} // ns
}
// ns
} // ns

View File

@@ -217,6 +217,9 @@ namespace BlackSimPlugin
void getFrameStatsAsync(double *o_averageFps, double *o_simTimeRatio, double *o_trackMilesShort, double *o_minutesLate);
//! @}
//! \copydoc XSwiftBus::CService::resetFrameTotals
void resetFrameTotals();
//! \copydoc XSwiftBus::CService::getLatitudeDeg
//! @{
double getLatitudeDeg() const;