mirror of
https://github.com/hawkeye-stan/msfs-popout-panel-manager.git
synced 2024-11-25 15:20:10 +00:00
110 lines
4 KiB
C#
110 lines
4 KiB
C#
using MSFSPopoutPanelManager.Shared;
|
|
using Newtonsoft.Json;
|
|
using Newtonsoft.Json.Serialization;
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Dynamic;
|
|
using System.IO;
|
|
using System.Timers;
|
|
|
|
namespace MSFSPopoutPanelManager.SimConnectAgent.TouchPanel
|
|
{
|
|
public class DataProvider
|
|
{
|
|
private const int MSFS_DATA_REFRESH_TIMEOUT = 50;
|
|
|
|
private TouchPanelSimConnector _simConnector;
|
|
private Timer _requestDataTimer;
|
|
private bool _isHandlingCriticalError;
|
|
|
|
public event EventHandler<string> OnDataRefreshed;
|
|
public event EventHandler<string> OnCriticalErrorReceived;
|
|
|
|
public DataProvider(TouchPanelSimConnector simConnector)
|
|
{
|
|
_simConnector = simConnector;
|
|
}
|
|
|
|
public void Start()
|
|
{
|
|
_requestDataTimer = new Timer();
|
|
_requestDataTimer.Interval = MSFS_DATA_REFRESH_TIMEOUT;
|
|
_requestDataTimer.Enabled = true;
|
|
_requestDataTimer.Elapsed += HandleDataRequested;
|
|
_requestDataTimer.Elapsed += HandleMessageReceived;
|
|
|
|
_simConnector.OnReceivedData += HandleDataReceived;
|
|
}
|
|
|
|
public void Stop()
|
|
{
|
|
if (_requestDataTimer != null)
|
|
{
|
|
_requestDataTimer.Enabled = false;
|
|
_simConnector.OnReceivedData -= HandleDataReceived;
|
|
OnDataRefreshed?.Invoke(this, null);
|
|
}
|
|
}
|
|
|
|
public string GetFlightPlan()
|
|
{
|
|
// MSFS 2020 Windows Store version: C:\Users\{username}\AppData\Local\Packages\Microsoft.FlightSimulator_8wekyb3d8bbwe\LocalState\MISSIONS\Custom\CustomFlight\CustomFlight.FLT
|
|
// MSFS 2020 Steam version: C:\Users\{username}\AppData\Roaming\Microsoft Flight Simulator\MISSIONS\Custom\CustomFlight\CustomFlight.FLT
|
|
var filePathMSStore = Environment.ExpandEnvironmentVariables("%LocalAppData%") + @"\Packages\Microsoft.FlightSimulator_8wekyb3d8bbwe\LocalState\MISSIONS\Custom\CustomFlight\CustomFlight.FLT";
|
|
var filePathSteam = Environment.ExpandEnvironmentVariables("%AppData%") + @"\Microsoft Flight Simulator\MISSIONS\Custom\CustomFlight\CustomFlight.FLT";
|
|
|
|
string filePath;
|
|
|
|
if (File.Exists(filePathMSStore))
|
|
filePath = filePathMSStore;
|
|
else if (File.Exists(filePathSteam))
|
|
filePath = filePathSteam;
|
|
else
|
|
filePath = null;
|
|
|
|
// cannot find CustomFlight.PLN, return empty set of waypoints
|
|
if (filePath == null)
|
|
return JsonConvert.SerializeObject(new List<ExpandoObject>());
|
|
|
|
return FlightPlanProvider.ParseCustomFLT(filePath);
|
|
}
|
|
|
|
private void HandleDataRequested(object sender, ElapsedEventArgs e)
|
|
{
|
|
try
|
|
{
|
|
_simConnector.RequestData();
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
if (!_isHandlingCriticalError)
|
|
{
|
|
_isHandlingCriticalError = true;
|
|
OnCriticalErrorReceived?.Invoke(this, $"TouchPanel DataProvider: SimConnect HandleDataRequested Error - {ex.Message}");
|
|
}
|
|
}
|
|
}
|
|
|
|
private void HandleMessageReceived(object sender, ElapsedEventArgs e)
|
|
{
|
|
try
|
|
{
|
|
_simConnector.ReceiveMessage();
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
FileLogger.WriteLog($"TouchPanel DataProvider: SimConnect HandleMessageReceived Error - {ex.Message}", StatusMessageType.Error);
|
|
}
|
|
}
|
|
|
|
public void HandleDataReceived(object sender, List<SimConnectDataDefinition> e)
|
|
{
|
|
var jsonData = JsonConvert.SerializeObject(e, Formatting.Indented, new JsonSerializerSettings { ContractResolver = new CamelCasePropertyNamesContractResolver() });
|
|
|
|
// Invoke on data refresh event by listener
|
|
OnDataRefreshed?.Invoke(this, jsonData);
|
|
}
|
|
}
|
|
}
|
|
|
|
|