From 1f90faf3db8122af66d0179786abe6d1f50cdc49 Mon Sep 17 00:00:00 2001 From: Arturs Ziborovs Date: Tue, 20 Aug 2019 19:57:31 +0300 Subject: [PATCH 01/67] Added a simple Elite: Dangerous profile - added an icon - added a simple background layer - added a simple Overview --- .../Control_EliteDangerous.xaml | 44 +++++++++++ .../Control_EliteDangerous.xaml.cs | 72 ++++++++++++++++++ .../EliteDangerousApplication.cs | 45 +++++++++++ .../EliteDangerous/EliteDangerousProfile.cs | 28 +++++++ .../GSI/GameState_EliteDangerous.cs | 18 +++++ ...Control_EliteDangerousBackgroundLayer.xaml | 13 ++++ ...trol_EliteDangerousBackgroundLayer.xaml.cs | 72 ++++++++++++++++++ .../EliteDangerousBackgroundLayerHandler.cs | 59 ++++++++++++++ .../Profiles/LightingStateManager.cs | 3 +- .../Project-Aurora/Project-Aurora.csproj | 21 ++++- .../Resources/elite_dangerous_256x256.png | Bin 0 -> 73578 bytes 11 files changed, 373 insertions(+), 2 deletions(-) create mode 100644 Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Control_EliteDangerous.xaml create mode 100644 Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Control_EliteDangerous.xaml.cs create mode 100644 Project-Aurora/Project-Aurora/Profiles/EliteDangerous/EliteDangerousApplication.cs create mode 100644 Project-Aurora/Project-Aurora/Profiles/EliteDangerous/EliteDangerousProfile.cs create mode 100644 Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/GameState_EliteDangerous.cs create mode 100644 Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/Control_EliteDangerousBackgroundLayer.xaml create mode 100644 Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/Control_EliteDangerousBackgroundLayer.xaml.cs create mode 100644 Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousBackgroundLayerHandler.cs create mode 100644 Project-Aurora/Project-Aurora/Resources/elite_dangerous_256x256.png diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Control_EliteDangerous.xaml b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Control_EliteDangerous.xaml new file mode 100644 index 000000000..dfa935dd4 --- /dev/null +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Control_EliteDangerous.xaml @@ -0,0 +1,44 @@ + + + + + + + + + + + + + + + + + + + + + + + + + Elite: Dangerous support works using the games Journal API. This means that no memory reading or other potentially bannable methods are involved. + + + + + + diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Control_EliteDangerous.xaml.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Control_EliteDangerous.xaml.cs new file mode 100644 index 000000000..e9c68351a --- /dev/null +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Control_EliteDangerous.xaml.cs @@ -0,0 +1,72 @@ +using Aurora.Controls; +using Aurora.Utils; +using System; +using System.IO; +using Ionic.Zip; +using System.Timers; +using System.Windows; +using System.Windows.Controls; +using System.Windows.Input; +using System.Windows.Media; +using System.Windows.Navigation; +using Aurora.Devices; +using Aurora.Settings; +using Xceed.Wpf.Toolkit; +using Aurora.Profiles.EliteDangerous.GSI; +using MessageBox = System.Windows.MessageBox; + +namespace Aurora.Profiles.EliteDangerous +{ + /// + /// Interaction logic for Control_EliteDangerous.xaml + /// + public partial class Control_EliteDangerous : UserControl + { + private Application profile_manager; + + public Control_EliteDangerous(Application profile) + { + InitializeComponent(); + + profile_manager = profile; + + SetSettings(); + + if (!(profile_manager.Settings as FirstTimeApplicationSettings).IsFirstTimeInstalled) + { + (profile_manager.Settings as FirstTimeApplicationSettings).IsFirstTimeInstalled = true; + } + + profile_manager.ProfileChanged += Control_EliteDangerous_ProfileChanged; + + } + + private void Control_EliteDangerous_ProfileChanged(object sender, EventArgs e) + { + SetSettings(); + } + + private void SetSettings() + { + this.game_enabled.IsChecked = profile_manager.Settings.IsEnabled; + + } + + //Overview + + private void game_enabled_Checked(object sender, RoutedEventArgs e) + { + if (IsLoaded) + { + profile_manager.Settings.IsEnabled = (this.game_enabled.IsChecked.HasValue) ? this.game_enabled.IsChecked.Value : false; + profile_manager.SaveProfiles(); + } + } + + private void Hyperlink_RequestNavigate(object sender, RequestNavigateEventArgs e) + { + System.Diagnostics.Process.Start(new System.Diagnostics.ProcessStartInfo(e.Uri.AbsoluteUri)); + e.Handled = true; + } + } +} \ No newline at end of file diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/EliteDangerousApplication.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/EliteDangerousApplication.cs new file mode 100644 index 000000000..d01ad810f --- /dev/null +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/EliteDangerousApplication.cs @@ -0,0 +1,45 @@ +using Aurora.Settings; +using Aurora.Profiles.EliteDangerous.Layers; +using System; +using System.Text; +using System.Windows.Media.Imaging; +using System.Windows.Controls; +using System.Windows.Media; +using System.IO; +using Newtonsoft.Json; +using Aurora.Settings.Layers; +using System.Collections.Generic; + +namespace Aurora.Profiles.EliteDangerous +{ + public class EliteDangerous : Application + { + public EliteDangerous() + : base(new LightEventConfig + { + Name = "Elite: Dangerous", + ID = "EliteDangerous", + ProcessNames = new[] { "EliteDangerous64.exe" }, + SettingsType = typeof(FirstTimeApplicationSettings), + ProfileType = typeof(EliteDangerousProfile), + OverviewControlType = typeof(Control_EliteDangerous), + GameStateType = typeof(GSI.GameState_EliteDangerous), + Event = new GameEvent_Generic(), + IconURI = "Resources/elite_dangerous_256x256.png" + }) + { + + var extra = new List + { + new LayerHandlerEntry("EliteDangerousBackground", "Elite: Dangerous Background Layer", typeof(EliteDangerousBackgroundLayerHandler)), + }; + + Global.LightingStateManager.RegisterLayerHandlers(extra, false); + + foreach (var entry in extra) + { + Config.ExtraAvailableLayers.Add(entry.Key); + } + } + } +} \ No newline at end of file diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/EliteDangerousProfile.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/EliteDangerousProfile.cs new file mode 100644 index 000000000..217d47773 --- /dev/null +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/EliteDangerousProfile.cs @@ -0,0 +1,28 @@ +using Aurora.Settings; +using Aurora.Settings.Layers; +using System; +using System.Collections.Generic; +using System.Drawing; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace Aurora.Profiles.EliteDangerous +{ + public class EliteDangerousProfile : ApplicationProfile + { + public EliteDangerousProfile() : base() + { + + } + + public override void Reset() + { + base.Reset(); + Layers = new System.Collections.ObjectModel.ObservableCollection() + { + new Layer("Background", new Layers.EliteDangerousBackgroundLayerHandler()), + }; + } + } +} diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/GameState_EliteDangerous.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/GameState_EliteDangerous.cs new file mode 100644 index 000000000..583d8e3ac --- /dev/null +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/GameState_EliteDangerous.cs @@ -0,0 +1,18 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace Aurora.Profiles.EliteDangerous.GSI +{ + class GameState_EliteDangerous : GameState + { + /// + /// Creates a default GameState_EliteDangerous instance. + /// + public GameState_EliteDangerous() : base() + { + } + } +} diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/Control_EliteDangerousBackgroundLayer.xaml b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/Control_EliteDangerousBackgroundLayer.xaml new file mode 100644 index 000000000..86048b09e --- /dev/null +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/Control_EliteDangerousBackgroundLayer.xaml @@ -0,0 +1,13 @@ + + + + + diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/Control_EliteDangerousBackgroundLayer.xaml.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/Control_EliteDangerousBackgroundLayer.xaml.cs new file mode 100644 index 000000000..c9bfd29de --- /dev/null +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/Control_EliteDangerousBackgroundLayer.xaml.cs @@ -0,0 +1,72 @@ +using Aurora.Settings; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using System.Windows; +using System.Windows.Controls; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Input; +using System.Windows.Media; +using System.Windows.Media.Imaging; +using System.Windows.Navigation; +using System.Windows.Shapes; + +namespace Aurora.Profiles.EliteDangerous.Layers +{ + /// + /// Interaction logic for Control_EliteDangerousBackgroundLayer.xaml + /// + public partial class Control_EliteDangerousBackgroundLayer : UserControl + { + private bool settingsset = false; + private bool profileset = false; + + public Control_EliteDangerousBackgroundLayer() + { + InitializeComponent(); + } + + public Control_EliteDangerousBackgroundLayer(EliteDangerousBackgroundLayerHandler datacontext) + { + InitializeComponent(); + + this.DataContext = datacontext; + } + + public void SetSettings() + { + if (this.DataContext is EliteDangerousBackgroundLayerHandler && !settingsset) + { + this.ColorPicker_Default.SelectedColor = Utils.ColorUtils.DrawingColorToMediaColor((this.DataContext as EliteDangerousBackgroundLayerHandler).Properties._DefaultColor ?? System.Drawing.Color.Empty); + + settingsset = true; + } + } + + internal void SetProfile(Application profile) + { + if (profile != null && !profileset) + { + var var_types_numerical = profile.ParameterLookup?.Where(kvp => Utils.TypeUtils.IsNumericType(kvp.Value.Item1)); + + profileset = true; + } + } + + private void UserControl_Loaded(object sender, RoutedEventArgs e) + { + SetSettings(); + + this.Loaded -= UserControl_Loaded; + } + + private void ColorPicker_Default_SelectedColorChanged(object sender, RoutedPropertyChangedEventArgs e) + { + if (IsLoaded && settingsset && this.DataContext is EliteDangerousBackgroundLayerHandler && sender is Xceed.Wpf.Toolkit.ColorPicker && (sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.HasValue) + (this.DataContext as EliteDangerousBackgroundLayerHandler).Properties._DefaultColor = Utils.ColorUtils.MediaColorToDrawingColor((sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.Value); + } + } +} diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousBackgroundLayerHandler.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousBackgroundLayerHandler.cs new file mode 100644 index 000000000..2f459ee97 --- /dev/null +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousBackgroundLayerHandler.cs @@ -0,0 +1,59 @@ +using Aurora.EffectsEngine; +using Aurora.Settings; +using Aurora.Settings.Layers; +using Newtonsoft.Json; +using System; +using System.Collections.Generic; +using System.Drawing; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using System.Windows.Controls; + +namespace Aurora.Profiles.EliteDangerous.Layers +{ + public class EliteDangerousBackgroundHandlerProperties : LayerHandlerProperties2Color + { + public Color? _DefaultColor { get; set; } + + public Color DefaultColor { get { return Logic._DefaultColor ?? _DefaultColor ?? Color.Empty; } } + + public EliteDangerousBackgroundHandlerProperties() : base() { } + + public EliteDangerousBackgroundHandlerProperties(bool assign_default = false) : base(assign_default) { } + + public override void Default() + { + base.Default(); + this._DefaultColor = Color.FromArgb(255, 60, 0, 0); + } + } + public class EliteDangerousBackgroundLayerHandler : LayerHandler + { + public EliteDangerousBackgroundLayerHandler() : base() + { + _ID = "EliteDangerousBackground"; + } + + protected override UserControl CreateControl() + { + return new Control_EliteDangerousBackgroundLayer(this); + } + + public override EffectLayer Render(IGameState state) + { + EffectLayer bg_layer = new EffectLayer("Elite: Dangerous - Background"); + + Color bg_color = this.Properties.DefaultColor; + bg_layer.Fill(bg_color); + + return bg_layer; + } + + public override void SetApplication(Application profile) + { + (Control as Control_EliteDangerousBackgroundLayer).SetProfile(profile); + base.SetApplication(profile); + } + } +} diff --git a/Project-Aurora/Project-Aurora/Profiles/LightingStateManager.cs b/Project-Aurora/Project-Aurora/Profiles/LightingStateManager.cs index d9848b1a8..d1100530c 100755 --- a/Project-Aurora/Project-Aurora/Profiles/LightingStateManager.cs +++ b/Project-Aurora/Project-Aurora/Profiles/LightingStateManager.cs @@ -148,7 +148,8 @@ public bool Initialize() new ResidentEvil2.ResidentEvil2(), new CloneHero.CloneHero(), new Osu.Osu(), - new Slime_Rancher.Slime_Rancher() + new Slime_Rancher.Slime_Rancher(), + new EliteDangerous.EliteDangerous() }); RegisterLayerHandlers(new List { diff --git a/Project-Aurora/Project-Aurora/Project-Aurora.csproj b/Project-Aurora/Project-Aurora/Project-Aurora.csproj index 0ed21f438..ad3be9f5f 100755 --- a/Project-Aurora/Project-Aurora/Project-Aurora.csproj +++ b/Project-Aurora/Project-Aurora/Project-Aurora.csproj @@ -1,4 +1,4 @@ - + @@ -451,6 +451,16 @@ + + Control_EliteDangerous.xaml + + + + + + Control_EliteDangerousBackgroundLayer.xaml + + Control_ResidentEvil2RankLayer.xaml @@ -1518,6 +1528,7 @@ + PreserveNewest @@ -1718,6 +1729,14 @@ MSBuild:Compile Designer + + Designer + MSBuild:Compile + + + Designer + MSBuild:Compile + MSBuild:Compile Designer diff --git a/Project-Aurora/Project-Aurora/Resources/elite_dangerous_256x256.png b/Project-Aurora/Project-Aurora/Resources/elite_dangerous_256x256.png new file mode 100644 index 0000000000000000000000000000000000000000..ee187f90f9a47529ec2912159a6f84c2edeb41dd GIT binary patch literal 73578 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

0a$LD4GSw?|Wd`*U># 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 nBa|x{#y-p9;bqGU` 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 literal 0 HcmV?d00001 From f39778d4407a15b8c61f4dc941f19d0f171e5076 Mon Sep 17 00:00:00 2001 From: Arturs Ziborovs Date: Tue, 20 Aug 2019 20:17:06 +0300 Subject: [PATCH 02/67] Don't provide alpha for color since it's not needed --- .../Layers/EliteDangerousBackgroundLayerHandler.cs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousBackgroundLayerHandler.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousBackgroundLayerHandler.cs index 2f459ee97..7332446ab 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousBackgroundLayerHandler.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousBackgroundLayerHandler.cs @@ -25,7 +25,7 @@ public EliteDangerousBackgroundHandlerProperties(bool assign_default = false) : public override void Default() { base.Default(); - this._DefaultColor = Color.FromArgb(255, 60, 0, 0); + this._DefaultColor = Color.FromArgb(60, 0, 0); } } public class EliteDangerousBackgroundLayerHandler : LayerHandler From ec5abf24f7138d9da36b31337fbcd2b35fc2d914 Mon Sep 17 00:00:00 2001 From: Arturs Ziborovs Date: Thu, 22 Aug 2019 01:14:06 +0300 Subject: [PATCH 03/67] Added a layer and color pickers for initial control color groups --- .../EliteDangerousApplication.cs | 21 +- .../EliteDangerous/EliteDangerousProfile.cs | 1 + .../Control_EliteDangerousKeyBindsLayer.xaml | 76 +++++++ ...ontrol_EliteDangerousKeyBindsLayer.xaml.cs | 198 ++++++++++++++++++ .../EliteDangerousKeyBindsLayerHandler.cs | 123 +++++++++++ .../Project-Aurora/Project-Aurora.csproj | 8 + 6 files changed, 419 insertions(+), 8 deletions(-) create mode 100644 Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/Control_EliteDangerousKeyBindsLayer.xaml create mode 100644 Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/Control_EliteDangerousKeyBindsLayer.xaml.cs create mode 100644 Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/EliteDangerousApplication.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/EliteDangerousApplication.cs index d01ad810f..9f5096854 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/EliteDangerousApplication.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/EliteDangerousApplication.cs @@ -1,13 +1,5 @@ using Aurora.Settings; using Aurora.Profiles.EliteDangerous.Layers; -using System; -using System.Text; -using System.Windows.Media.Imaging; -using System.Windows.Controls; -using System.Windows.Media; -using System.IO; -using Newtonsoft.Json; -using Aurora.Settings.Layers; using System.Collections.Generic; namespace Aurora.Profiles.EliteDangerous @@ -32,6 +24,7 @@ public EliteDangerous() var extra = new List { new LayerHandlerEntry("EliteDangerousBackground", "Elite: Dangerous Background Layer", typeof(EliteDangerousBackgroundLayerHandler)), + new LayerHandlerEntry("EliteDangerousKeyBinds", "Elite: Dangerous Key Binds Layer", typeof(EliteDangerousKeyBindsLayerHandler)), }; Global.LightingStateManager.RegisterLayerHandlers(extra, false); @@ -41,5 +34,17 @@ public EliteDangerous() Config.ExtraAvailableLayers.Add(entry.Key); } } + + public override void OnActivate() + { + Global.logger.Info("OnActivate ED"); + base.OnActivate(); + } + + public override void OnDeactivate() + { + Global.logger.Info("OnDeactivate ED"); + base.OnDeactivate(); + } } } \ No newline at end of file diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/EliteDangerousProfile.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/EliteDangerousProfile.cs index 217d47773..d5aaaa8a2 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/EliteDangerousProfile.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/EliteDangerousProfile.cs @@ -21,6 +21,7 @@ public override void Reset() base.Reset(); Layers = new System.Collections.ObjectModel.ObservableCollection() { + new Layer("Key Binds", new Layers.EliteDangerousKeyBindsLayerHandler()), new Layer("Background", new Layers.EliteDangerousBackgroundLayerHandler()), }; } diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/Control_EliteDangerousKeyBindsLayer.xaml b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/Control_EliteDangerousKeyBindsLayer.xaml new file mode 100644 index 000000000..3cc8c1b8b --- /dev/null +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/Control_EliteDangerousKeyBindsLayer.xaml @@ -0,0 +1,76 @@ + + + + + + + + + + + + + + + + + + + + + + + diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/Control_EliteDangerousKeyBindsLayer.xaml.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/Control_EliteDangerousKeyBindsLayer.xaml.cs new file mode 100644 index 000000000..42421892d --- /dev/null +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/Control_EliteDangerousKeyBindsLayer.xaml.cs @@ -0,0 +1,198 @@ +using Aurora.Settings; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using System.Windows; +using System.Windows.Controls; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Input; +using System.Windows.Media; +using System.Windows.Media.Imaging; +using System.Windows.Navigation; +using System.Windows.Shapes; + +namespace Aurora.Profiles.EliteDangerous.Layers +{ + ///

+ /// Interaction logic for Control_EliteDangerousKeyBindsLayer.xaml + /// + public partial class Control_EliteDangerousKeyBindsLayer : UserControl + { + private bool settingsset = false; + private bool profileset = false; + + public Control_EliteDangerousKeyBindsLayer() + { + InitializeComponent(); + } + + public Control_EliteDangerousKeyBindsLayer(EliteDangerousKeyBindsLayerHandler datacontext) + { + InitializeComponent(); + + this.DataContext = datacontext; + } + + public void SetSettings() + { + if (this.DataContext is EliteDangerousKeyBindsLayerHandler && !settingsset) + { + this.ColorPicker_HudModeCombat.SelectedColor = Utils.ColorUtils.DrawingColorToMediaColor((this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._HudModeCombatColor ?? System.Drawing.Color.Empty); + this.ColorPicker_HudModeDiscovery.SelectedColor = Utils.ColorUtils.DrawingColorToMediaColor((this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._HudModeDiscoveryColor ?? System.Drawing.Color.Empty); + this.ColorPicker_None.SelectedColor = Utils.ColorUtils.DrawingColorToMediaColor((this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._NoneColor ?? System.Drawing.Color.Empty); + this.ColorPicker_Other.SelectedColor = Utils.ColorUtils.DrawingColorToMediaColor((this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._OtherColor ?? System.Drawing.Color.Empty); + this.ColorPicker_Ui.SelectedColor = Utils.ColorUtils.DrawingColorToMediaColor((this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._UiColor ?? System.Drawing.Color.Empty); + this.ColorPicker_UiAlt.SelectedColor = Utils.ColorUtils.DrawingColorToMediaColor((this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._UiAltColor ?? System.Drawing.Color.Empty); + this.ColorPicker_ShipStuff.SelectedColor = Utils.ColorUtils.DrawingColorToMediaColor((this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._ShipStuffColor ?? System.Drawing.Color.Empty); + this.ColorPicker_Camera.SelectedColor = Utils.ColorUtils.DrawingColorToMediaColor((this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._CameraColor ?? System.Drawing.Color.Empty); + this.ColorPicker_Defence.SelectedColor = Utils.ColorUtils.DrawingColorToMediaColor((this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._DefenceColor ?? System.Drawing.Color.Empty); + this.ColorPicker_DefenceDimmed.SelectedColor = Utils.ColorUtils.DrawingColorToMediaColor((this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._DefenceDimmedColor ?? System.Drawing.Color.Empty); + this.ColorPicker_Offence.SelectedColor = Utils.ColorUtils.DrawingColorToMediaColor((this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._OffenceColor ?? System.Drawing.Color.Empty); + this.ColorPicker_OffenceDimmed.SelectedColor = Utils.ColorUtils.DrawingColorToMediaColor((this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._OffenceDimmedColor ?? System.Drawing.Color.Empty); + this.ColorPicker_MovementSpeed.SelectedColor = Utils.ColorUtils.DrawingColorToMediaColor((this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._MovementSpeedColor ?? System.Drawing.Color.Empty); + this.ColorPicker_MovementSpeedDimmed.SelectedColor = Utils.ColorUtils.DrawingColorToMediaColor((this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._MovementSpeedDimmedColor ?? System.Drawing.Color.Empty); + this.ColorPicker_MovementSecondary.SelectedColor = Utils.ColorUtils.DrawingColorToMediaColor((this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._MovementSecondaryColor ?? System.Drawing.Color.Empty); + this.ColorPicker_Wing.SelectedColor = Utils.ColorUtils.DrawingColorToMediaColor((this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._WingColor ?? System.Drawing.Color.Empty); + this.ColorPicker_Navigation.SelectedColor = Utils.ColorUtils.DrawingColorToMediaColor((this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._NavigationColor ?? System.Drawing.Color.Empty); + this.ColorPicker_ModeEnable.SelectedColor = Utils.ColorUtils.DrawingColorToMediaColor((this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._ModeEnableColor ?? System.Drawing.Color.Empty); + this.ColorPicker_ModeDisable.SelectedColor = Utils.ColorUtils.DrawingColorToMediaColor((this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._ModeDisableColor ?? System.Drawing.Color.Empty); + + settingsset = true; + } + } + + internal void SetProfile(Application profile) + { + if (profile != null && !profileset) + { + var var_types_numerical = profile.ParameterLookup?.Where(kvp => Utils.TypeUtils.IsNumericType(kvp.Value.Item1)); + + profileset = true; + } + } + + private void UserControl_Loaded(object sender, RoutedEventArgs e) + { + SetSettings(); + + this.Loaded -= UserControl_Loaded; + } + + private void ColorPicker_HudModeCombat_SelectedColorChanged(object sender, RoutedPropertyChangedEventArgs e) + { + if (IsLoaded && settingsset && this.DataContext is EliteDangerousKeyBindsLayerHandler && sender is Xceed.Wpf.Toolkit.ColorPicker && (sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.HasValue) + (this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._HudModeCombatColor = Utils.ColorUtils.MediaColorToDrawingColor((sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.Value); + } + + private void ColorPicker_HudModeDiscovery_SelectedColorChanged(object sender, RoutedPropertyChangedEventArgs e) + { + if (IsLoaded && settingsset && this.DataContext is EliteDangerousKeyBindsLayerHandler && sender is Xceed.Wpf.Toolkit.ColorPicker && (sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.HasValue) + (this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._HudModeDiscoveryColor = Utils.ColorUtils.MediaColorToDrawingColor((sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.Value); + } + + private void ColorPicker_None_SelectedColorChanged(object sender, RoutedPropertyChangedEventArgs e) + { + if (IsLoaded && settingsset && this.DataContext is EliteDangerousKeyBindsLayerHandler && sender is Xceed.Wpf.Toolkit.ColorPicker && (sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.HasValue) + (this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._NoneColor = Utils.ColorUtils.MediaColorToDrawingColor((sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.Value); + } + + private void ColorPicker_Other_SelectedColorChanged(object sender, RoutedPropertyChangedEventArgs e) + { + if (IsLoaded && settingsset && this.DataContext is EliteDangerousKeyBindsLayerHandler && sender is Xceed.Wpf.Toolkit.ColorPicker && (sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.HasValue) + (this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._OtherColor = Utils.ColorUtils.MediaColorToDrawingColor((sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.Value); + } + + private void ColorPicker_Ui_SelectedColorChanged(object sender, RoutedPropertyChangedEventArgs e) + { + if (IsLoaded && settingsset && this.DataContext is EliteDangerousKeyBindsLayerHandler && sender is Xceed.Wpf.Toolkit.ColorPicker && (sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.HasValue) + (this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._UiColor = Utils.ColorUtils.MediaColorToDrawingColor((sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.Value); + } + + private void ColorPicker_UiAlt_SelectedColorChanged(object sender, RoutedPropertyChangedEventArgs e) + { + if (IsLoaded && settingsset && this.DataContext is EliteDangerousKeyBindsLayerHandler && sender is Xceed.Wpf.Toolkit.ColorPicker && (sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.HasValue) + (this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._UiAltColor = Utils.ColorUtils.MediaColorToDrawingColor((sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.Value); + } + + private void ColorPicker_ShipStuff_SelectedColorChanged(object sender, RoutedPropertyChangedEventArgs e) + { + if (IsLoaded && settingsset && this.DataContext is EliteDangerousKeyBindsLayerHandler && sender is Xceed.Wpf.Toolkit.ColorPicker && (sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.HasValue) + (this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._ShipStuffColor = Utils.ColorUtils.MediaColorToDrawingColor((sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.Value); + } + + private void ColorPicker_Camera_SelectedColorChanged(object sender, RoutedPropertyChangedEventArgs e) + { + if (IsLoaded && settingsset && this.DataContext is EliteDangerousKeyBindsLayerHandler && sender is Xceed.Wpf.Toolkit.ColorPicker && (sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.HasValue) + (this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._CameraColor = Utils.ColorUtils.MediaColorToDrawingColor((sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.Value); + } + + private void ColorPicker_Defence_SelectedColorChanged(object sender, RoutedPropertyChangedEventArgs e) + { + if (IsLoaded && settingsset && this.DataContext is EliteDangerousKeyBindsLayerHandler && sender is Xceed.Wpf.Toolkit.ColorPicker && (sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.HasValue) + (this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._DefenceColor = Utils.ColorUtils.MediaColorToDrawingColor((sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.Value); + } + + private void ColorPicker_DefenceDimmed_SelectedColorChanged(object sender, RoutedPropertyChangedEventArgs e) + { + if (IsLoaded && settingsset && this.DataContext is EliteDangerousKeyBindsLayerHandler && sender is Xceed.Wpf.Toolkit.ColorPicker && (sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.HasValue) + (this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._DefenceDimmedColor = Utils.ColorUtils.MediaColorToDrawingColor((sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.Value); + } + + private void ColorPicker_Offence_SelectedColorChanged(object sender, RoutedPropertyChangedEventArgs e) + { + if (IsLoaded && settingsset && this.DataContext is EliteDangerousKeyBindsLayerHandler && sender is Xceed.Wpf.Toolkit.ColorPicker && (sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.HasValue) + (this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._OffenceColor = Utils.ColorUtils.MediaColorToDrawingColor((sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.Value); + } + + private void ColorPicker_OffenceDimmed_SelectedColorChanged(object sender, RoutedPropertyChangedEventArgs e) + { + if (IsLoaded && settingsset && this.DataContext is EliteDangerousKeyBindsLayerHandler && sender is Xceed.Wpf.Toolkit.ColorPicker && (sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.HasValue) + (this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._OffenceDimmedColor = Utils.ColorUtils.MediaColorToDrawingColor((sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.Value); + } + + private void ColorPicker_MovementSpeed_SelectedColorChanged(object sender, RoutedPropertyChangedEventArgs e) + { + if (IsLoaded && settingsset && this.DataContext is EliteDangerousKeyBindsLayerHandler && sender is Xceed.Wpf.Toolkit.ColorPicker && (sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.HasValue) + (this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._MovementSpeedColor = Utils.ColorUtils.MediaColorToDrawingColor((sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.Value); + } + + private void ColorPicker_MovementSpeedDimmed_SelectedColorChanged(object sender, RoutedPropertyChangedEventArgs e) + { + if (IsLoaded && settingsset && this.DataContext is EliteDangerousKeyBindsLayerHandler && sender is Xceed.Wpf.Toolkit.ColorPicker && (sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.HasValue) + (this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._MovementSpeedDimmedColor = Utils.ColorUtils.MediaColorToDrawingColor((sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.Value); + } + + private void ColorPicker_MovementSecondary_SelectedColorChanged(object sender, RoutedPropertyChangedEventArgs e) + { + if (IsLoaded && settingsset && this.DataContext is EliteDangerousKeyBindsLayerHandler && sender is Xceed.Wpf.Toolkit.ColorPicker && (sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.HasValue) + (this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._MovementSecondaryColor = Utils.ColorUtils.MediaColorToDrawingColor((sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.Value); + } + + private void ColorPicker_Wing_SelectedColorChanged(object sender, RoutedPropertyChangedEventArgs e) + { + if (IsLoaded && settingsset && this.DataContext is EliteDangerousKeyBindsLayerHandler && sender is Xceed.Wpf.Toolkit.ColorPicker && (sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.HasValue) + (this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._WingColor = Utils.ColorUtils.MediaColorToDrawingColor((sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.Value); + } + + private void ColorPicker_Navigation_SelectedColorChanged(object sender, RoutedPropertyChangedEventArgs e) + { + if (IsLoaded && settingsset && this.DataContext is EliteDangerousKeyBindsLayerHandler && sender is Xceed.Wpf.Toolkit.ColorPicker && (sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.HasValue) + (this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._NavigationColor = Utils.ColorUtils.MediaColorToDrawingColor((sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.Value); + } + + private void ColorPicker_ModeEnable_SelectedColorChanged(object sender, RoutedPropertyChangedEventArgs e) + { + if (IsLoaded && settingsset && this.DataContext is EliteDangerousKeyBindsLayerHandler && sender is Xceed.Wpf.Toolkit.ColorPicker && (sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.HasValue) + (this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._ModeEnableColor = Utils.ColorUtils.MediaColorToDrawingColor((sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.Value); + } + + private void ColorPicker_ModeDisable_SelectedColorChanged(object sender, RoutedPropertyChangedEventArgs e) + { + if (IsLoaded && settingsset && this.DataContext is EliteDangerousKeyBindsLayerHandler && sender is Xceed.Wpf.Toolkit.ColorPicker && (sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.HasValue) + (this.DataContext as EliteDangerousKeyBindsLayerHandler).Properties._ModeDisableColor = Utils.ColorUtils.MediaColorToDrawingColor((sender as Xceed.Wpf.Toolkit.ColorPicker).SelectedColor.Value); + } + } +} diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs new file mode 100644 index 000000000..9ef7e133e --- /dev/null +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs @@ -0,0 +1,123 @@ +using Aurora.EffectsEngine; +using Aurora.Settings.Layers; +using System.Drawing; +using System.Windows.Controls; + +namespace Aurora.Profiles.EliteDangerous.Layers +{ + public class EliteDangerousKeyBindsHandlerProperties : LayerHandlerProperties2Color + { + public Color? _HudModeCombatColor { get; set; } + public Color HudModeCombatColor { get { return Logic._HudModeCombatColor ?? _HudModeCombatColor ?? Color.Empty; } } + + public Color? _HudModeDiscoveryColor { get; set; } + public Color HudModeDiscoveryColor { get { return Logic._HudModeDiscoveryColor ?? _HudModeDiscoveryColor ?? Color.Empty; } } + + public Color? _NoneColor { get; set; } + public Color NoneColor { get { return Logic._NoneColor ?? _NoneColor ?? Color.Empty; } } + + public Color? _OtherColor { get; set; } + public Color OtherColor { get { return Logic._OtherColor ?? _OtherColor ?? Color.Empty; } } + + public Color? _UiColor { get; set; } + public Color UiColor { get { return Logic._UiColor ?? _UiColor ?? Color.Empty; } } + + public Color? _UiAltColor { get; set; } + public Color UiAltColor { get { return Logic._UiAltColor ?? _UiAltColor ?? Color.Empty; } } + + public Color? _ShipStuffColor { get; set; } + public Color ShipStuffColor { get { return Logic._ShipStuffColor ?? _ShipStuffColor ?? Color.Empty; } } + + public Color? _CameraColor { get; set; } + public Color CameraColor { get { return Logic._CameraColor ?? _CameraColor ?? Color.Empty; } } + + public Color? _DefenceColor { get; set; } + public Color DefenceColor { get { return Logic._DefenceColor ?? _DefenceColor ?? Color.Empty; } } + + public Color? _DefenceDimmedColor { get; set; } + public Color DefenceDimmedColor { get { return Logic._DefenceDimmedColor ?? _DefenceDimmedColor ?? Color.Empty; } } + + public Color? _OffenceColor { get; set; } + public Color OffenceColor { get { return Logic._OffenceColor ?? _OffenceColor ?? Color.Empty; } } + + public Color? _OffenceDimmedColor { get; set; } + public Color OffenceDimmedColor { get { return Logic._OffenceDimmedColor ?? _OffenceDimmedColor ?? Color.Empty; } } + + public Color? _MovementSpeedColor { get; set; } + public Color MovementSpeedColor { get { return Logic._MovementSpeedColor ?? _MovementSpeedColor ?? Color.Empty; } } + + public Color? _MovementSpeedDimmedColor { get; set; } + public Color MovementSpeedDimmedColor { get { return Logic._MovementSpeedDimmedColor ?? _MovementSpeedDimmedColor ?? Color.Empty; } } + + public Color? _MovementSecondaryColor { get; set; } + public Color MovementSecondaryColor { get { return Logic._MovementSecondaryColor ?? _MovementSecondaryColor ?? Color.Empty; } } + + public Color? _WingColor { get; set; } + public Color WingColor { get { return Logic._WingColor ?? _WingColor ?? Color.Empty; } } + + public Color? _NavigationColor { get; set; } + public Color NavigationColor { get { return Logic._NavigationColor ?? _NavigationColor ?? Color.Empty; } } + + public Color? _ModeEnableColor { get; set; } + public Color ModeEnableColor { get { return Logic._ModeEnableColor ?? _ModeEnableColor ?? Color.Empty; } } + + public Color? _ModeDisableColor { get; set; } + public Color ModeDisableColor { get { return Logic._ModeDisableColor ?? _ModeDisableColor ?? Color.Empty; } } + + public EliteDangerousKeyBindsHandlerProperties() : base() { } + + public EliteDangerousKeyBindsHandlerProperties(bool assign_default = false) : base(assign_default) { } + + public override void Default() + { + base.Default(); + this._HudModeCombatColor = Color.FromArgb(255, 80, 0); + this._HudModeDiscoveryColor = Color.FromArgb(0, 160, 255); + this._NoneColor = Color.FromArgb(0, 0, 0); + this._OtherColor = Color.FromArgb(60, 0, 0); + this._UiColor = Color.FromArgb(255, 80, 0); + this._UiAltColor = Color.FromArgb(255, 115, 70); + this._ShipStuffColor = Color.FromArgb(0, 255, 0); + this._CameraColor = Color.FromArgb(71, 164, 79); + this._DefenceColor = Color.FromArgb(0, 220, 255); + this._DefenceDimmedColor = Color.FromArgb(0, 70, 80); + this._OffenceColor = Color.FromArgb(255, 0, 0); + this._OffenceDimmedColor = Color.FromArgb(100, 0, 0); + this._MovementSpeedColor = Color.FromArgb(136, 0, 255); + this._MovementSpeedDimmedColor = Color.FromArgb(50, 0, 100); + this._MovementSecondaryColor = Color.FromArgb(255, 0, 255); + this._WingColor = Color.FromArgb(0, 0, 255); + this._NavigationColor = Color.FromArgb(255, 220, 0); + this._ModeEnableColor = Color.FromArgb(153, 167, 255); + this._ModeDisableColor = Color.FromArgb(61, 88, 156); + } + } + public class EliteDangerousKeyBindsLayerHandler : LayerHandler + { + public EliteDangerousKeyBindsLayerHandler() : base() + { + _ID = "EliteDangerousKeyBinds"; + } + + protected override UserControl CreateControl() + { + return new Control_EliteDangerousKeyBindsLayer(this); + } + + public override EffectLayer Render(IGameState state) + { + EffectLayer bg_layer = new EffectLayer("Elite: Dangerous - Key Binds"); + +// Color bg_color = this.Properties.DefaultColor; +// bg_layer.Fill(bg_color); + + return bg_layer; + } + + public override void SetApplication(Application profile) + { + (Control as Control_EliteDangerousKeyBindsLayer).SetProfile(profile); + base.SetApplication(profile); + } + } +} diff --git a/Project-Aurora/Project-Aurora/Project-Aurora.csproj b/Project-Aurora/Project-Aurora/Project-Aurora.csproj index ad3be9f5f..7bd0553ca 100755 --- a/Project-Aurora/Project-Aurora/Project-Aurora.csproj +++ b/Project-Aurora/Project-Aurora/Project-Aurora.csproj @@ -460,7 +460,11 @@ Control_EliteDangerousBackgroundLayer.xaml + + Control_EliteDangerousKeyBindsLayer.xaml + + Control_ResidentEvil2RankLayer.xaml @@ -1737,6 +1741,10 @@ Designer MSBuild:Compile
+ + MSBuild:Compile + Designer + MSBuild:Compile Designer From 8b5efe4cd89ff53d71201b126aa0c68355ed9dfa Mon Sep 17 00:00:00 2001 From: Arturs Ziborovs Date: Thu, 22 Aug 2019 01:31:03 +0300 Subject: [PATCH 04/67] Started working on highlighting key binds --- .../Layers/EliteDangerousKeyBindsLayerHandler.cs | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs index 9ef7e133e..140f23ce2 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs @@ -2,6 +2,7 @@ using Aurora.Settings.Layers; using System.Drawing; using System.Windows.Controls; +using Aurora.Devices; namespace Aurora.Profiles.EliteDangerous.Layers { @@ -106,12 +107,13 @@ protected override UserControl CreateControl() public override EffectLayer Render(IGameState state) { - EffectLayer bg_layer = new EffectLayer("Elite: Dangerous - Key Binds"); + EffectLayer keyBindsLayer = new EffectLayer("Elite: Dangerous - Key Binds"); -// Color bg_color = this.Properties.DefaultColor; -// bg_layer.Fill(bg_color); + keyBindsLayer.Set(DeviceKeys.C, this.Properties.ShipStuffColor); + keyBindsLayer.Set(DeviceKeys.V, this.Properties.DefenceColor); + keyBindsLayer.Set(DeviceKeys.B, this.Properties.DefenceDimmedColor); - return bg_layer; + return keyBindsLayer; } public override void SetApplication(Application profile) From 2d2f9adfafe6acf5841867a664cd497e92f52581 Mon Sep 17 00:00:00 2001 From: Arturs Ziborovs Date: Thu, 22 Aug 2019 22:35:04 +0300 Subject: [PATCH 05/67] Working on blinking keys --- .../EliteDangerousKeyBindsLayerHandler.cs | 27 ++++++++++++++++++- 1 file changed, 26 insertions(+), 1 deletion(-) diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs index 140f23ce2..fc9153aaa 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs @@ -1,8 +1,10 @@ -using Aurora.EffectsEngine; +using System; +using Aurora.EffectsEngine; using Aurora.Settings.Layers; using System.Drawing; using System.Windows.Controls; using Aurora.Devices; +using CSScriptLibrary; namespace Aurora.Profiles.EliteDangerous.Layers { @@ -95,6 +97,7 @@ public override void Default() } public class EliteDangerousKeyBindsLayerHandler : LayerHandler { + private int blinkSpeed = 20; public EliteDangerousKeyBindsLayerHandler() : base() { _ID = "EliteDangerousKeyBinds"; @@ -105,6 +108,27 @@ protected override UserControl CreateControl() return new Control_EliteDangerousKeyBindsLayer(this); } + private float GetBlinkStep() + { + float animationPosition = Utils.Time.GetMillisecondsSinceEpoch() % (10000L / blinkSpeed) / (10000.0f / blinkSpeed); + float animationStep = animationPosition * 2; + return animationStep > 1 ? 1F + (1F - animationStep) : animationStep; + } + + private Color GetBlinkingColor(Color baseColor) + { + return Utils.ColorUtils.BlendColors( + this.Properties.ShipStuffColor, + Color.FromArgb( + 0, + this.Properties.ShipStuffColor.R, + this.Properties.ShipStuffColor.G, + this.Properties.ShipStuffColor.B + ), + GetBlinkStep() + ); + } + public override EffectLayer Render(IGameState state) { EffectLayer keyBindsLayer = new EffectLayer("Elite: Dangerous - Key Binds"); @@ -112,6 +136,7 @@ public override EffectLayer Render(IGameState state) keyBindsLayer.Set(DeviceKeys.C, this.Properties.ShipStuffColor); keyBindsLayer.Set(DeviceKeys.V, this.Properties.DefenceColor); keyBindsLayer.Set(DeviceKeys.B, this.Properties.DefenceDimmedColor); + keyBindsLayer.Set(DeviceKeys.A, GetBlinkingColor(Properties.ShipStuffColor)); return keyBindsLayer; } From 427a08faff7ffc1199da66a19722dc3b81eaaa48 Mon Sep 17 00:00:00 2001 From: Arturs Ziborovs Date: Thu, 22 Aug 2019 23:13:50 +0300 Subject: [PATCH 06/67] Added Status node for Elite: Dangerous - started working on Elite: Dangerous game state and event --- .../EliteDangerousApplication.cs | 14 +--------- .../GSI/GameState_EliteDangerous.cs | 13 +++++++++ .../EliteDangerous/GSI/Nodes/Status.cs | 17 ++++++++++++ .../GameEvent_EliteDangerous.cs | 27 +++++++++++++++++++ .../Project-Aurora/Project-Aurora.csproj | 2 ++ 5 files changed, 60 insertions(+), 13 deletions(-) create mode 100644 Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Status.cs create mode 100644 Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/EliteDangerousApplication.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/EliteDangerousApplication.cs index 9f5096854..c772ae41f 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/EliteDangerousApplication.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/EliteDangerousApplication.cs @@ -16,7 +16,7 @@ public EliteDangerous() ProfileType = typeof(EliteDangerousProfile), OverviewControlType = typeof(Control_EliteDangerous), GameStateType = typeof(GSI.GameState_EliteDangerous), - Event = new GameEvent_Generic(), + Event = new GameEvent_EliteDangerous(), IconURI = "Resources/elite_dangerous_256x256.png" }) { @@ -34,17 +34,5 @@ public EliteDangerous() Config.ExtraAvailableLayers.Add(entry.Key); } } - - public override void OnActivate() - { - Global.logger.Info("OnActivate ED"); - base.OnActivate(); - } - - public override void OnDeactivate() - { - Global.logger.Info("OnDeactivate ED"); - base.OnDeactivate(); - } } } \ No newline at end of file diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/GameState_EliteDangerous.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/GameState_EliteDangerous.cs index 583d8e3ac..f5bb1621f 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/GameState_EliteDangerous.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/GameState_EliteDangerous.cs @@ -3,11 +3,24 @@ using System.Linq; using System.Text; using System.Threading.Tasks; +using Aurora.Profiles.EliteDangerous.GSI.Nodes; namespace Aurora.Profiles.EliteDangerous.GSI { class GameState_EliteDangerous : GameState { + private Status status; + + public Status Status + { + get + { + if (status == null) + status = new Status(); + + return status; + } + } /// /// Creates a default GameState_EliteDangerous instance. /// diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Status.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Status.cs new file mode 100644 index 000000000..b5af7612a --- /dev/null +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Status.cs @@ -0,0 +1,17 @@ +namespace Aurora.Profiles.EliteDangerous.GSI.Nodes +{ + /// + /// Class representing player status + /// + public class Status : Node + { + public string timestamp; + public string @event; + public long Flags; + public int[] Pips; + public int FireGroup; + public int GuiFocus; + public double Fuel; + public double Cargo; + } +} \ No newline at end of file diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs new file mode 100644 index 000000000..c31df6834 --- /dev/null +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs @@ -0,0 +1,27 @@ +using System.Collections.Generic; +using System.IO; +using System.Linq; +using Aurora.EffectsEngine; +using Aurora.Profiles.EliteDangerous.GSI; +using Aurora.Settings; + +namespace Aurora.Profiles.EliteDangerous +{ + public class GameEvent_EliteDangerous : GameEvent_Generic + { + public GameEvent_EliteDangerous() : base() + { + //TODO: Read initial game configuration + } + + public override void OnActivate() + { + //TODO: Enable Journal API reading + } + + public override void OnDeactivate() + { + //TODO: Disable Journal API reading + } + } +} \ No newline at end of file diff --git a/Project-Aurora/Project-Aurora/Project-Aurora.csproj b/Project-Aurora/Project-Aurora/Project-Aurora.csproj index 7bd0553ca..77919916f 100755 --- a/Project-Aurora/Project-Aurora/Project-Aurora.csproj +++ b/Project-Aurora/Project-Aurora/Project-Aurora.csproj @@ -456,7 +456,9 @@
+ + Control_EliteDangerousBackgroundLayer.xaml From 088e5d8aab79d0d6492968ec3d082ddc45ff8dc2 Mon Sep 17 00:00:00 2001 From: Arturs Ziborovs Date: Thu, 22 Aug 2019 23:30:08 +0300 Subject: [PATCH 07/67] Fixed overridden methods --- .../Profiles/EliteDangerous/GameEvent_EliteDangerous.cs | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs index c31df6834..cfc299c16 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs @@ -14,12 +14,12 @@ public GameEvent_EliteDangerous() : base() //TODO: Read initial game configuration } - public override void OnActivate() + public override void OnResume() { //TODO: Enable Journal API reading } - public override void OnDeactivate() + public override void OnPause() { //TODO: Disable Journal API reading } From 74de390d6f4a42ce2d8c8168d1cd848a232e0e02 Mon Sep 17 00:00:00 2001 From: Arturs Ziborovs Date: Fri, 23 Aug 2019 00:38:30 +0300 Subject: [PATCH 08/67] Implemented detection of currend binds file - implemented a file watcher for bind files - stop/start file watchers as needed --- .../GameEvent_EliteDangerous.cs | 86 +++++++++++++++++-- 1 file changed, 79 insertions(+), 7 deletions(-) diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs index cfc299c16..ca520a7e5 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs @@ -1,26 +1,98 @@ -using System.Collections.Generic; +using System; using System.IO; -using System.Linq; -using Aurora.EffectsEngine; -using Aurora.Profiles.EliteDangerous.GSI; -using Aurora.Settings; namespace Aurora.Profiles.EliteDangerous { public class GameEvent_EliteDangerous : GameEvent_Generic { - public GameEvent_EliteDangerous() : base() + + private static readonly string journalFolder = Path.Combine( + Environment.GetFolderPath(Environment.SpecialFolder.UserProfile), + "Saved Games", + "Frontier Developments", + "Elite Dangerous" + ); + private static readonly string statusFile = Path.Combine(journalFolder, "Status.json"); + + private static readonly string bindingsFolder = Path.Combine( + Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData), + "Frontier Developments", + "Elite Dangerous", + "Options", + "Bindings" + ); + private static readonly string bindingsPresetFile = Path.Combine(bindingsFolder, "StartPreset.start"); + + private string currentBindFile = null; + private FileSystemWatcher bindWatcher = null; + + public GameEvent_EliteDangerous() : base() {} + + public void WatchBindFiles() + { + StopWatchingBindFiles(); + if (Directory.Exists(bindingsFolder)) + { + bindWatcher = new FileSystemWatcher() + { + Path = bindingsFolder, + NotifyFilter = NotifyFilters.LastWrite, + EnableRaisingEvents = true + }; + bindWatcher.Changed += OnBindsFileChanged; + } + } + + public void StopWatchingBindFiles() + { + if (bindWatcher != null) + { + bindWatcher.Dispose(); + bindWatcher = null; + } + } + + private void OnBindsFileChanged(object sender, FileSystemEventArgs e) + { + // This is a fix for multiple change events being triggered + if (bindWatcher != null) bindWatcher.EnableRaisingEvents = false; + ReadBindFiles(); + if (bindWatcher != null) bindWatcher.EnableRaisingEvents = true; + } + + private void ReadBindFiles() + { + if (File.Exists(bindingsPresetFile)) + { + string currentBindPrefix = File.ReadAllText(bindingsPresetFile).Trim(); + foreach (string bindFile in Directory.GetFiles(bindingsFolder, currentBindPrefix + ".*.binds")) + { + currentBindFile = bindFile; + } + + if (currentBindFile != null) + { + ParseBindFile(); + } + } + } + + private void ParseBindFile() { - //TODO: Read initial game configuration + //TODO: Parse configuration XML + Global.logger.Error("Current bind file: " + currentBindFile); } public override void OnResume() { + ReadBindFiles(); + WatchBindFiles(); //TODO: Enable Journal API reading } public override void OnPause() { + StopWatchingBindFiles(); //TODO: Disable Journal API reading } } From d0a9f127df7d4b2af4db5e7235a8c19ab017b8f8 Mon Sep 17 00:00:00 2001 From: Arturs Ziborovs Date: Fri, 23 Aug 2019 01:02:24 +0300 Subject: [PATCH 09/67] Fixed lifecycle method names --- .../Profiles/EliteDangerous/GameEvent_EliteDangerous.cs | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs index ca520a7e5..260292620 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs @@ -83,14 +83,14 @@ private void ParseBindFile() Global.logger.Error("Current bind file: " + currentBindFile); } - public override void OnResume() + public override void OnStart() { ReadBindFiles(); WatchBindFiles(); //TODO: Enable Journal API reading } - public override void OnPause() + public override void OnStop() { StopWatchingBindFiles(); //TODO: Disable Journal API reading From 458479f7ebf6f48a2092d4bef78ba5b8cc81a84d Mon Sep 17 00:00:00 2001 From: Arturs Ziborovs Date: Sun, 25 Aug 2019 22:16:25 +0300 Subject: [PATCH 10/67] Started parsing binds file - added some classes for the future --- .../EliteDangerous/GSI/Nodes/Controls.cs | 278 ++++++++++++++++++ .../EliteDangerous/GSI/Nodes/Status.cs | 66 +++++ .../GameEvent_EliteDangerous.cs | 22 ++ .../Project-Aurora/Project-Aurora.csproj | 1 + 4 files changed, 367 insertions(+) create mode 100644 Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Controls.cs diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Controls.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Controls.cs new file mode 100644 index 000000000..9df1a10a1 --- /dev/null +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Controls.cs @@ -0,0 +1,278 @@ +namespace Aurora.Profiles.EliteDangerous.GSI.Nodes +{ + + public class EliteBind + { + public static readonly string MODIFIER = "MODIFIER"; + public static readonly string MouseReset = "MouseReset"; + public static readonly string YawLeftButton = "YawLeftButton"; + public static readonly string YawRightButton = "YawRightButton"; + public static readonly string YawToRollButton = "YawToRollButton"; + public static readonly string RollLeftButton = "RollLeftButton"; + public static readonly string RollRightButton = "RollRightButton"; + public static readonly string PitchUpButton = "PitchUpButton"; + public static readonly string PitchDownButton = "PitchDownButton"; + public static readonly string LeftThrustButton = "LeftThrustButton"; + public static readonly string RightThrustButton = "RightThrustButton"; + public static readonly string UpThrustButton = "UpThrustButton"; + public static readonly string DownThrustButton = "DownThrustButton"; + public static readonly string ForwardThrustButton = "ForwardThrustButton"; + public static readonly string BackwardThrustButton = "BackwardThrustButton"; + public static readonly string UseAlternateFlightValuesToggle = "UseAlternateFlightValuesToggle"; + public static readonly string ToggleReverseThrottleInput = "ToggleReverseThrottleInput"; + public static readonly string ForwardKey = "ForwardKey"; + public static readonly string BackwardKey = "BackwardKey"; + public static readonly string SetSpeedMinus100 = "SetSpeedMinus100"; + public static readonly string SetSpeedMinus75 = "SetSpeedMinus75"; + public static readonly string SetSpeedMinus50 = "SetSpeedMinus50"; + public static readonly string SetSpeedMinus25 = "SetSpeedMinus25"; + public static readonly string SetSpeedZero = "SetSpeedZero"; + public static readonly string SetSpeed25 = "SetSpeed25"; + public static readonly string SetSpeed50 = "SetSpeed50"; + public static readonly string SetSpeed75 = "SetSpeed75"; + public static readonly string SetSpeed100 = "SetSpeed100"; + public static readonly string YawLeftButton_Landing = "YawLeftButton_Landing"; + public static readonly string YawRightButton_Landing = "YawRightButton_Landing"; + public static readonly string PitchUpButton_Landing = "PitchUpButton_Landing"; + public static readonly string PitchDownButton_Landing = "PitchDownButton_Landing"; + public static readonly string RollLeftButton_Landing = "RollLeftButton_Landing"; + public static readonly string RollRightButton_Landing = "RollRightButton_Landing"; + public static readonly string LeftThrustButton_Landing = "LeftThrustButton_Landing"; + public static readonly string RightThrustButton_Landing = "RightThrustButton_Landing"; + public static readonly string UpThrustButton_Landing = "UpThrustButton_Landing"; + public static readonly string DownThrustButton_Landing = "DownThrustButton_Landing"; + public static readonly string ForwardThrustButton_Landing = "ForwardThrustButton_Landing"; + public static readonly string BackwardThrustButton_Landing = "BackwardThrustButton_Landing"; + public static readonly string ToggleFlightAssist = "ToggleFlightAssist"; + public static readonly string UseBoostJuice = "UseBoostJuice"; + public static readonly string HyperSuperCombination = "HyperSuperCombination"; + public static readonly string Supercruise = "Supercruise"; + public static readonly string Hyperspace = "Hyperspace"; + public static readonly string DisableRotationCorrectToggle = "DisableRotationCorrectToggle"; + public static readonly string OrbitLinesToggle = "OrbitLinesToggle"; + public static readonly string SelectTarget = "SelectTarget"; + public static readonly string CycleNextTarget = "CycleNextTarget"; + public static readonly string CyclePreviousTarget = "CyclePreviousTarget"; + public static readonly string SelectHighestThreat = "SelectHighestThreat"; + public static readonly string CycleNextHostileTarget = "CycleNextHostileTarget"; + public static readonly string CyclePreviousHostileTarget = "CyclePreviousHostileTarget"; + public static readonly string TargetWingman0 = "TargetWingman0"; + public static readonly string TargetWingman1 = "TargetWingman1"; + public static readonly string TargetWingman2 = "TargetWingman2"; + public static readonly string SelectTargetsTarget = "SelectTargetsTarget"; + public static readonly string WingNavLock = "WingNavLock"; + public static readonly string CycleNextSubsystem = "CycleNextSubsystem"; + public static readonly string CyclePreviousSubsystem = "CyclePreviousSubsystem"; + public static readonly string TargetNextRouteSystem = "TargetNextRouteSystem"; + public static readonly string PrimaryFire = "PrimaryFire"; + public static readonly string SecondaryFire = "SecondaryFire"; + public static readonly string CycleFireGroupNext = "CycleFireGroupNext"; + public static readonly string CycleFireGroupPrevious = "CycleFireGroupPrevious"; + public static readonly string DeployHardpointToggle = "DeployHardpointToggle"; + public static readonly string ToggleButtonUpInput = "ToggleButtonUpInput"; + public static readonly string DeployHeatSink = "DeployHeatSink"; + public static readonly string ShipSpotLightToggle = "ShipSpotLightToggle"; + public static readonly string RadarIncreaseRange = "RadarIncreaseRange"; + public static readonly string RadarDecreaseRange = "RadarDecreaseRange"; + public static readonly string IncreaseEnginesPower = "IncreaseEnginesPower"; + public static readonly string IncreaseWeaponsPower = "IncreaseWeaponsPower"; + public static readonly string IncreaseSystemsPower = "IncreaseSystemsPower"; + public static readonly string ResetPowerDistribution = "ResetPowerDistribution"; + public static readonly string HMDReset = "HMDReset"; + public static readonly string ToggleCargoScoop = "ToggleCargoScoop"; + public static readonly string EjectAllCargo = "EjectAllCargo"; + public static readonly string LandingGearToggle = "LandingGearToggle"; + public static readonly string MicrophoneMute = "MicrophoneMute"; + public static readonly string UseShieldCell = "UseShieldCell"; + public static readonly string FireChaffLauncher = "FireChaffLauncher"; + public static readonly string ChargeECM = "ChargeECM"; + public static readonly string WeaponColourToggle = "WeaponColourToggle"; + public static readonly string EngineColourToggle = "EngineColourToggle"; + public static readonly string NightVisionToggle = "NightVisionToggle"; + public static readonly string UIFocus = "UIFocus"; + public static readonly string FocusLeftPanel = "FocusLeftPanel"; + public static readonly string FocusCommsPanel = "FocusCommsPanel"; + public static readonly string QuickCommsPanel = "QuickCommsPanel"; + public static readonly string FocusRadarPanel = "FocusRadarPanel"; + public static readonly string FocusRightPanel = "FocusRightPanel"; + public static readonly string GalaxyMapOpen = "GalaxyMapOpen"; + public static readonly string SystemMapOpen = "SystemMapOpen"; + public static readonly string ShowPGScoreSummaryInput = "ShowPGScoreSummaryInput"; + public static readonly string HeadLookToggle = "HeadLookToggle"; + public static readonly string Pause = "Pause"; + public static readonly string FriendsMenu = "FriendsMenu"; + public static readonly string OpenCodexGoToDiscovery = "OpenCodexGoToDiscovery"; + public static readonly string PlayerHUDModeToggle = "PlayerHUDModeToggle"; + public static readonly string UI_Up = "UI_Up"; + public static readonly string UI_Down = "UI_Down"; + public static readonly string UI_Left = "UI_Left"; + public static readonly string UI_Right = "UI_Right"; + public static readonly string UI_Select = "UI_Select"; + public static readonly string UI_Back = "UI_Back"; + public static readonly string UI_Toggle = "UI_Toggle"; + public static readonly string CycleNextPanel = "CycleNextPanel"; + public static readonly string CyclePreviousPanel = "CyclePreviousPanel"; + public static readonly string CycleNextPage = "CycleNextPage"; + public static readonly string CyclePreviousPage = "CyclePreviousPage"; + public static readonly string HeadLookReset = "HeadLookReset"; + public static readonly string HeadLookPitchUp = "HeadLookPitchUp"; + public static readonly string HeadLookPitchDown = "HeadLookPitchDown"; + public static readonly string HeadLookYawLeft = "HeadLookYawLeft"; + public static readonly string HeadLookYawRight = "HeadLookYawRight"; + public static readonly string CamPitchUp = "CamPitchUp"; + public static readonly string CamPitchDown = "CamPitchDown"; + public static readonly string CamYawLeft = "CamYawLeft"; + public static readonly string CamYawRight = "CamYawRight"; + public static readonly string CamTranslateForward = "CamTranslateForward"; + public static readonly string CamTranslateBackward = "CamTranslateBackward"; + public static readonly string CamTranslateLeft = "CamTranslateLeft"; + public static readonly string CamTranslateRight = "CamTranslateRight"; + public static readonly string CamTranslateUp = "CamTranslateUp"; + public static readonly string CamTranslateDown = "CamTranslateDown"; + public static readonly string CamZoomIn = "CamZoomIn"; + public static readonly string CamZoomOut = "CamZoomOut"; + public static readonly string CamTranslateZHold = "CamTranslateZHold"; + public static readonly string ToggleDriveAssist = "ToggleDriveAssist"; + public static readonly string SteerLeftButton = "SteerLeftButton"; + public static readonly string SteerRightButton = "SteerRightButton"; + public static readonly string BuggyRollLeftButton = "BuggyRollLeftButton"; + public static readonly string BuggyRollRightButton = "BuggyRollRightButton"; + public static readonly string BuggyPitchUpButton = "BuggyPitchUpButton"; + public static readonly string BuggyPitchDownButton = "BuggyPitchDownButton"; + public static readonly string VerticalThrustersButton = "VerticalThrustersButton"; + public static readonly string BuggyPrimaryFireButton = "BuggyPrimaryFireButton"; + public static readonly string BuggySecondaryFireButton = "BuggySecondaryFireButton"; + public static readonly string AutoBreakBuggyButton = "AutoBreakBuggyButton"; + public static readonly string HeadlightsBuggyButton = "HeadlightsBuggyButton"; + public static readonly string ToggleBuggyTurretButton = "ToggleBuggyTurretButton"; + public static readonly string SelectTarget_Buggy = "SelectTarget_Buggy"; + public static readonly string BuggyTurretYawLeftButton = "BuggyTurretYawLeftButton"; + public static readonly string BuggyTurretYawRightButton = "BuggyTurretYawRightButton"; + public static readonly string BuggyTurretPitchUpButton = "BuggyTurretPitchUpButton"; + public static readonly string BuggyTurretPitchDownButton = "BuggyTurretPitchDownButton"; + public static readonly string BuggyToggleReverseThrottleInput = "BuggyToggleReverseThrottleInput"; + public static readonly string IncreaseSpeedButtonMax = "IncreaseSpeedButtonMax"; + public static readonly string DecreaseSpeedButtonMax = "DecreaseSpeedButtonMax"; + public static readonly string IncreaseEnginesPower_Buggy = "IncreaseEnginesPower_Buggy"; + public static readonly string IncreaseWeaponsPower_Buggy = "IncreaseWeaponsPower_Buggy"; + public static readonly string IncreaseSystemsPower_Buggy = "IncreaseSystemsPower_Buggy"; + public static readonly string ResetPowerDistribution_Buggy = "ResetPowerDistribution_Buggy"; + public static readonly string ToggleCargoScoop_Buggy = "ToggleCargoScoop_Buggy"; + public static readonly string EjectAllCargo_Buggy = "EjectAllCargo_Buggy"; + public static readonly string RecallDismissShip = "RecallDismissShip"; + public static readonly string UIFocus_Buggy = "UIFocus_Buggy"; + public static readonly string FocusLeftPanel_Buggy = "FocusLeftPanel_Buggy"; + public static readonly string FocusCommsPanel_Buggy = "FocusCommsPanel_Buggy"; + public static readonly string QuickCommsPanel_Buggy = "QuickCommsPanel_Buggy"; + public static readonly string FocusRadarPanel_Buggy = "FocusRadarPanel_Buggy"; + public static readonly string FocusRightPanel_Buggy = "FocusRightPanel_Buggy"; + public static readonly string GalaxyMapOpen_Buggy = "GalaxyMapOpen_Buggy"; + public static readonly string SystemMapOpen_Buggy = "SystemMapOpen_Buggy"; + public static readonly string HeadLookToggle_Buggy = "HeadLookToggle_Buggy"; + public static readonly string MultiCrewToggleMode = "MultiCrewToggleMode"; + public static readonly string MultiCrewPrimaryFire = "MultiCrewPrimaryFire"; + public static readonly string MultiCrewSecondaryFire = "MultiCrewSecondaryFire"; + public static readonly string MultiCrewPrimaryUtilityFire = "MultiCrewPrimaryUtilityFire"; + public static readonly string MultiCrewSecondaryUtilityFire = "MultiCrewSecondaryUtilityFire"; + public static readonly string MultiCrewThirdPersonYawLeftButton = "MultiCrewThirdPersonYawLeftButton"; + public static readonly string MultiCrewThirdPersonYawRightButton = "MultiCrewThirdPersonYawRightButton"; + public static readonly string MultiCrewThirdPersonPitchUpButton = "MultiCrewThirdPersonPitchUpButton"; + public static readonly string MultiCrewThirdPersonPitchDownButton = "MultiCrewThirdPersonPitchDownButton"; + public static readonly string MultiCrewThirdPersonFovOutButton = "MultiCrewThirdPersonFovOutButton"; + public static readonly string MultiCrewThirdPersonFovInButton = "MultiCrewThirdPersonFovInButton"; + public static readonly string MultiCrewCockpitUICycleForward = "MultiCrewCockpitUICycleForward"; + public static readonly string MultiCrewCockpitUICycleBackward = "MultiCrewCockpitUICycleBackward"; + public static readonly string OrderRequestDock = "OrderRequestDock"; + public static readonly string OrderDefensiveBehaviour = "OrderDefensiveBehaviour"; + public static readonly string OrderAggressiveBehaviour = "OrderAggressiveBehaviour"; + public static readonly string OrderFocusTarget = "OrderFocusTarget"; + public static readonly string OrderHoldFire = "OrderHoldFire"; + public static readonly string OrderHoldPosition = "OrderHoldPosition"; + public static readonly string OrderFollow = "OrderFollow"; + public static readonly string OpenOrders = "OpenOrders"; + public static readonly string PhotoCameraToggle = "PhotoCameraToggle"; + public static readonly string PhotoCameraToggle_Buggy = "PhotoCameraToggle_Buggy"; + public static readonly string VanityCameraScrollLeft = "VanityCameraScrollLeft"; + public static readonly string VanityCameraScrollRight = "VanityCameraScrollRight"; + public static readonly string ToggleFreeCam = "ToggleFreeCam"; + public static readonly string VanityCameraOne = "VanityCameraOne"; + public static readonly string VanityCameraTwo = "VanityCameraTwo"; + public static readonly string VanityCameraThree = "VanityCameraThree"; + public static readonly string VanityCameraFour = "VanityCameraFour"; + public static readonly string VanityCameraFive = "VanityCameraFive"; + public static readonly string VanityCameraSix = "VanityCameraSix"; + public static readonly string VanityCameraSeven = "VanityCameraSeven"; + public static readonly string VanityCameraEight = "VanityCameraEight"; + public static readonly string VanityCameraNine = "VanityCameraNine"; + public static readonly string FreeCamToggleHUD = "FreeCamToggleHUD"; + public static readonly string FreeCamSpeedInc = "FreeCamSpeedInc"; + public static readonly string FreeCamSpeedDec = "FreeCamSpeedDec"; + public static readonly string ToggleReverseThrottleInputFreeCam = "ToggleReverseThrottleInputFreeCam"; + public static readonly string MoveFreeCamForward = "MoveFreeCamForward"; + public static readonly string MoveFreeCamBackwards = "MoveFreeCamBackwards"; + public static readonly string MoveFreeCamRight = "MoveFreeCamRight"; + public static readonly string MoveFreeCamLeft = "MoveFreeCamLeft"; + public static readonly string MoveFreeCamUp = "MoveFreeCamUp"; + public static readonly string MoveFreeCamDown = "MoveFreeCamDown"; + public static readonly string PitchCameraUp = "PitchCameraUp"; + public static readonly string PitchCameraDown = "PitchCameraDown"; + public static readonly string YawCameraLeft = "YawCameraLeft"; + public static readonly string YawCameraRight = "YawCameraRight"; + public static readonly string RollCameraLeft = "RollCameraLeft"; + public static readonly string RollCameraRight = "RollCameraRight"; + public static readonly string ToggleRotationLock = "ToggleRotationLock"; + public static readonly string FixCameraRelativeToggle = "FixCameraRelativeToggle"; + public static readonly string FixCameraWorldToggle = "FixCameraWorldToggle"; + public static readonly string QuitCamera = "QuitCamera"; + public static readonly string ToggleAdvanceMode = "ToggleAdvanceMode"; + public static readonly string FreeCamZoomIn = "FreeCamZoomIn"; + public static readonly string FreeCamZoomOut = "FreeCamZoomOut"; + public static readonly string FStopDec = "FStopDec"; + public static readonly string FStopInc = "FStopInc"; + public static readonly string CommanderCreator_Undo = "CommanderCreator_Undo"; + public static readonly string CommanderCreator_Redo = "CommanderCreator_Redo"; + public static readonly string CommanderCreator_Rotation_MouseToggle = "CommanderCreator_Rotation_MouseToggle"; + public static readonly string GalnetAudio_Play_Pause = "GalnetAudio_Play_Pause"; + public static readonly string GalnetAudio_SkipForward = "GalnetAudio_SkipForward"; + public static readonly string GalnetAudio_SkipBackward = "GalnetAudio_SkipBackward"; + public static readonly string GalnetAudio_ClearQueue = "GalnetAudio_ClearQueue"; + public static readonly string ExplorationFSSEnter = "ExplorationFSSEnter"; + public static readonly string ExplorationFSSCameraPitchIncreaseButton = "ExplorationFSSCameraPitchIncreaseButton"; + public static readonly string ExplorationFSSCameraPitchDecreaseButton = "ExplorationFSSCameraPitchDecreaseButton"; + public static readonly string ExplorationFSSCameraYawIncreaseButton = "ExplorationFSSCameraYawIncreaseButton"; + public static readonly string ExplorationFSSCameraYawDecreaseButton = "ExplorationFSSCameraYawDecreaseButton"; + public static readonly string ExplorationFSSZoomIn = "ExplorationFSSZoomIn"; + public static readonly string ExplorationFSSZoomOut = "ExplorationFSSZoomOut"; + public static readonly string ExplorationFSSMiniZoomIn = "ExplorationFSSMiniZoomIn"; + public static readonly string ExplorationFSSMiniZoomOut = "ExplorationFSSMiniZoomOut"; + public static readonly string ExplorationFSSRadioTuningX_Increase = "ExplorationFSSRadioTuningX_Increase"; + public static readonly string ExplorationFSSRadioTuningX_Decrease = "ExplorationFSSRadioTuningX_Decrease"; + public static readonly string ExplorationFSSDiscoveryScan = "ExplorationFSSDiscoveryScan"; + public static readonly string ExplorationFSSQuit = "ExplorationFSSQuit"; + public static readonly string ExplorationFSSTarget = "ExplorationFSSTarget"; + public static readonly string ExplorationFSSShowHelp = "ExplorationFSSShowHelp"; + public static readonly string ExplorationSAAChangeScannedAreaViewToggle = "ExplorationSAAChangeScannedAreaViewToggle"; + public static readonly string ExplorationSAAExitThirdPerson = "ExplorationSAAExitThirdPerson"; + public static readonly string SAAThirdPersonYawLeftButton = "SAAThirdPersonYawLeftButton"; + public static readonly string SAAThirdPersonYawRightButton = "SAAThirdPersonYawRightButton"; + public static readonly string SAAThirdPersonPitchUpButton = "SAAThirdPersonPitchUpButton"; + public static readonly string SAAThirdPersonPitchDownButton = "SAAThirdPersonPitchDownButton"; + public static readonly string SAAThirdPersonFovOutButton = "SAAThirdPersonFovOutButton"; + public static readonly string SAAThirdPersonFovInButton = "SAAThirdPersonFovInButton"; + } + + /// + /// Class representing current controls configuration + /// + public class Controls : Node + { + public string timestamp; + public string @event; + public long Flags; + public int[] Pips; + public int FireGroup; + public int GuiFocus; + public double Fuel; + public double Cargo; + } +} \ No newline at end of file diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Status.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Status.cs index b5af7612a..8af14a720 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Status.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Status.cs @@ -1,5 +1,71 @@ namespace Aurora.Profiles.EliteDangerous.GSI.Nodes { + + public class StatusState + { + long flagsSet = -1; + long flagsNotSet = -1; + int guiFocus = -1; + + public StatusState(long flagsSet, int guiFocus, long flagsNotSet) + { + this.flagsSet = flagsSet; + this.guiFocus = guiFocus; + this.flagsNotSet = flagsNotSet; + } + + public bool ConditionSatisfied(long flags, int guiFocus) { + if(this.guiFocus != -1 && this.guiFocus != guiFocus) { + return false; + } + if(this.flagsSet != -1 && !Flag.IsFlagSet(flags, this.flagsSet)) { + return false; + } + if(this.flagsNotSet != -1 && Flag.IsFlagSet(flags, this.flagsNotSet)) { + return false; + } + + return true; + } + } + + public static class Flag + { + public static readonly int DOCKED = 1; + public static readonly int LANDED_PLANET = 1 << 1; + public static readonly int LANDING_GEAR = 1 << 2; + public static readonly int SHIELDS_UP = 1 << 3; + public static readonly int SUPERCRUISE = 1 << 4; + public static readonly int FA_OFF = 1 << 5; + public static readonly int HARDPOINTS = 1 << 6; + public static readonly int IN_WING = 1 << 7; + public static readonly int SHIP_LIGHTS = 1 << 8; + public static readonly int CARGO_SCOOP = 1 << 9; + public static readonly int SILENT_RUNNING = 1 << 10; + public static readonly int SCOOPING = 1 << 11; + public static readonly int SRV_HANDBRAKE = 1 << 12; + public static readonly int SRV_TURRET = 1 << 13; + public static readonly int SRV_UNDER_SHIP = 1 << 14; + public static readonly int SRV_DRIVE_ASSIST = 1 << 15; + public static readonly int MASS_LOCK = 1 << 16; + public static readonly int FSD_CHARGING = 1 << 17; + public static readonly int FSD_COOLDOWN = 1 << 18; + public static readonly int LOW_FUEL = 1 << 19; // Less than 25% + public static readonly int OVERHEATING = 1 << 20; // More than 100% + public static readonly int HAS_LAT_LONG = 1 << 21; + public static readonly int IN_DANGER = 1 << 22; + public static readonly int INTERDICTION = 1 << 23; + public static readonly int IN_SHIP = 1 << 24; + public static readonly int IN_FIGHTER = 1 << 25; + public static readonly int IN_SRV = 1 << 26; + public static readonly int HUD_DISCOVERY_MODE = 1 << 27; + public static readonly int NIGHT_VISION = 1 << 28; + + public static bool IsFlagSet(long bitmask, long flag) { + return (bitmask & flag) == flag; + } + } + /// /// Class representing player status /// diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs index 260292620..a141f4614 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs @@ -1,5 +1,6 @@ using System; using System.IO; +using System.Xml; namespace Aurora.Profiles.EliteDangerous { @@ -81,6 +82,27 @@ private void ParseBindFile() { //TODO: Parse configuration XML Global.logger.Error("Current bind file: " + currentBindFile); + XmlDocument doc = new XmlDocument(); + try + { + doc.Load(currentBindFile); + XmlNodeList binds = doc.DocumentElement.ChildNodes; + foreach(XmlNode bind in binds) + { + foreach (XmlNode mapping in bind.ChildNodes) + { + if(mapping.Name == "Primary" || mapping.Name == "Secondary") { + // This is a bind + Global.logger.Error(bind.Name + " " + mapping.Name + ": " + mapping.Attributes["Device"].Value + " " + mapping.Attributes["Key"].Value); + } + } + } + + } + catch (System.IO.FileNotFoundException) + { + Global.logger.Error("Error loading binds file: " + currentBindFile); + } } public override void OnStart() diff --git a/Project-Aurora/Project-Aurora/Project-Aurora.csproj b/Project-Aurora/Project-Aurora/Project-Aurora.csproj index 77919916f..d71ddd7af 100755 --- a/Project-Aurora/Project-Aurora/Project-Aurora.csproj +++ b/Project-Aurora/Project-Aurora/Project-Aurora.csproj @@ -458,6 +458,7 @@ + Control_EliteDangerousBackgroundLayer.xaml From b4aab5ba1c73fa44735c1d472a0144e3da2ddb8f Mon Sep 17 00:00:00 2001 From: Arturs Ziborovs Date: Mon, 26 Aug 2019 00:25:09 +0300 Subject: [PATCH 11/67] Implemented binds file parsing - added structures for binds - started implementing control/color groups --- .../GSI/GameState_EliteDangerous.cs | 19 +- .../EliteDangerous/GSI/Nodes/Controls.cs | 718 +++++++++++------- .../GameEvent_EliteDangerous.cs | 55 +- .../EliteDangerousKeyBindsLayerHandler.cs | 55 +- 4 files changed, 564 insertions(+), 283 deletions(-) diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/GameState_EliteDangerous.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/GameState_EliteDangerous.cs index f5bb1621f..00e50557c 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/GameState_EliteDangerous.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/GameState_EliteDangerous.cs @@ -1,15 +1,11 @@ -using System; -using System.Collections.Generic; -using System.Linq; -using System.Text; -using System.Threading.Tasks; -using Aurora.Profiles.EliteDangerous.GSI.Nodes; +using Aurora.Profiles.EliteDangerous.GSI.Nodes; namespace Aurora.Profiles.EliteDangerous.GSI { class GameState_EliteDangerous : GameState { private Status status; + private Nodes.Controls controls; public Status Status { @@ -21,6 +17,17 @@ public Status Status return status; } } + + public Nodes.Controls Controls + { + get + { + if (controls == null) + controls = new Nodes.Controls(); + + return controls; + } + } /// /// Creates a default GameState_EliteDangerous instance. /// diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Controls.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Controls.cs index 9df1a10a1..182a06ca4 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Controls.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Controls.cs @@ -1,264 +1,431 @@ -namespace Aurora.Profiles.EliteDangerous.GSI.Nodes +using System.Collections.Generic; +using System.Drawing; +using System.Linq; +using Aurora.Devices; +using CSScriptLibrary; + +namespace Aurora.Profiles.EliteDangerous.GSI.Nodes { - public class EliteBind + public class Bind { - public static readonly string MODIFIER = "MODIFIER"; - public static readonly string MouseReset = "MouseReset"; - public static readonly string YawLeftButton = "YawLeftButton"; - public static readonly string YawRightButton = "YawRightButton"; - public static readonly string YawToRollButton = "YawToRollButton"; - public static readonly string RollLeftButton = "RollLeftButton"; - public static readonly string RollRightButton = "RollRightButton"; - public static readonly string PitchUpButton = "PitchUpButton"; - public static readonly string PitchDownButton = "PitchDownButton"; - public static readonly string LeftThrustButton = "LeftThrustButton"; - public static readonly string RightThrustButton = "RightThrustButton"; - public static readonly string UpThrustButton = "UpThrustButton"; - public static readonly string DownThrustButton = "DownThrustButton"; - public static readonly string ForwardThrustButton = "ForwardThrustButton"; - public static readonly string BackwardThrustButton = "BackwardThrustButton"; - public static readonly string UseAlternateFlightValuesToggle = "UseAlternateFlightValuesToggle"; - public static readonly string ToggleReverseThrottleInput = "ToggleReverseThrottleInput"; - public static readonly string ForwardKey = "ForwardKey"; - public static readonly string BackwardKey = "BackwardKey"; - public static readonly string SetSpeedMinus100 = "SetSpeedMinus100"; - public static readonly string SetSpeedMinus75 = "SetSpeedMinus75"; - public static readonly string SetSpeedMinus50 = "SetSpeedMinus50"; - public static readonly string SetSpeedMinus25 = "SetSpeedMinus25"; - public static readonly string SetSpeedZero = "SetSpeedZero"; - public static readonly string SetSpeed25 = "SetSpeed25"; - public static readonly string SetSpeed50 = "SetSpeed50"; - public static readonly string SetSpeed75 = "SetSpeed75"; - public static readonly string SetSpeed100 = "SetSpeed100"; - public static readonly string YawLeftButton_Landing = "YawLeftButton_Landing"; - public static readonly string YawRightButton_Landing = "YawRightButton_Landing"; - public static readonly string PitchUpButton_Landing = "PitchUpButton_Landing"; - public static readonly string PitchDownButton_Landing = "PitchDownButton_Landing"; - public static readonly string RollLeftButton_Landing = "RollLeftButton_Landing"; - public static readonly string RollRightButton_Landing = "RollRightButton_Landing"; - public static readonly string LeftThrustButton_Landing = "LeftThrustButton_Landing"; - public static readonly string RightThrustButton_Landing = "RightThrustButton_Landing"; - public static readonly string UpThrustButton_Landing = "UpThrustButton_Landing"; - public static readonly string DownThrustButton_Landing = "DownThrustButton_Landing"; - public static readonly string ForwardThrustButton_Landing = "ForwardThrustButton_Landing"; - public static readonly string BackwardThrustButton_Landing = "BackwardThrustButton_Landing"; - public static readonly string ToggleFlightAssist = "ToggleFlightAssist"; - public static readonly string UseBoostJuice = "UseBoostJuice"; - public static readonly string HyperSuperCombination = "HyperSuperCombination"; - public static readonly string Supercruise = "Supercruise"; - public static readonly string Hyperspace = "Hyperspace"; - public static readonly string DisableRotationCorrectToggle = "DisableRotationCorrectToggle"; - public static readonly string OrbitLinesToggle = "OrbitLinesToggle"; - public static readonly string SelectTarget = "SelectTarget"; - public static readonly string CycleNextTarget = "CycleNextTarget"; - public static readonly string CyclePreviousTarget = "CyclePreviousTarget"; - public static readonly string SelectHighestThreat = "SelectHighestThreat"; - public static readonly string CycleNextHostileTarget = "CycleNextHostileTarget"; - public static readonly string CyclePreviousHostileTarget = "CyclePreviousHostileTarget"; - public static readonly string TargetWingman0 = "TargetWingman0"; - public static readonly string TargetWingman1 = "TargetWingman1"; - public static readonly string TargetWingman2 = "TargetWingman2"; - public static readonly string SelectTargetsTarget = "SelectTargetsTarget"; - public static readonly string WingNavLock = "WingNavLock"; - public static readonly string CycleNextSubsystem = "CycleNextSubsystem"; - public static readonly string CyclePreviousSubsystem = "CyclePreviousSubsystem"; - public static readonly string TargetNextRouteSystem = "TargetNextRouteSystem"; - public static readonly string PrimaryFire = "PrimaryFire"; - public static readonly string SecondaryFire = "SecondaryFire"; - public static readonly string CycleFireGroupNext = "CycleFireGroupNext"; - public static readonly string CycleFireGroupPrevious = "CycleFireGroupPrevious"; - public static readonly string DeployHardpointToggle = "DeployHardpointToggle"; - public static readonly string ToggleButtonUpInput = "ToggleButtonUpInput"; - public static readonly string DeployHeatSink = "DeployHeatSink"; - public static readonly string ShipSpotLightToggle = "ShipSpotLightToggle"; - public static readonly string RadarIncreaseRange = "RadarIncreaseRange"; - public static readonly string RadarDecreaseRange = "RadarDecreaseRange"; - public static readonly string IncreaseEnginesPower = "IncreaseEnginesPower"; - public static readonly string IncreaseWeaponsPower = "IncreaseWeaponsPower"; - public static readonly string IncreaseSystemsPower = "IncreaseSystemsPower"; - public static readonly string ResetPowerDistribution = "ResetPowerDistribution"; - public static readonly string HMDReset = "HMDReset"; - public static readonly string ToggleCargoScoop = "ToggleCargoScoop"; - public static readonly string EjectAllCargo = "EjectAllCargo"; - public static readonly string LandingGearToggle = "LandingGearToggle"; - public static readonly string MicrophoneMute = "MicrophoneMute"; - public static readonly string UseShieldCell = "UseShieldCell"; - public static readonly string FireChaffLauncher = "FireChaffLauncher"; - public static readonly string ChargeECM = "ChargeECM"; - public static readonly string WeaponColourToggle = "WeaponColourToggle"; - public static readonly string EngineColourToggle = "EngineColourToggle"; - public static readonly string NightVisionToggle = "NightVisionToggle"; - public static readonly string UIFocus = "UIFocus"; - public static readonly string FocusLeftPanel = "FocusLeftPanel"; - public static readonly string FocusCommsPanel = "FocusCommsPanel"; - public static readonly string QuickCommsPanel = "QuickCommsPanel"; - public static readonly string FocusRadarPanel = "FocusRadarPanel"; - public static readonly string FocusRightPanel = "FocusRightPanel"; - public static readonly string GalaxyMapOpen = "GalaxyMapOpen"; - public static readonly string SystemMapOpen = "SystemMapOpen"; - public static readonly string ShowPGScoreSummaryInput = "ShowPGScoreSummaryInput"; - public static readonly string HeadLookToggle = "HeadLookToggle"; - public static readonly string Pause = "Pause"; - public static readonly string FriendsMenu = "FriendsMenu"; - public static readonly string OpenCodexGoToDiscovery = "OpenCodexGoToDiscovery"; - public static readonly string PlayerHUDModeToggle = "PlayerHUDModeToggle"; - public static readonly string UI_Up = "UI_Up"; - public static readonly string UI_Down = "UI_Down"; - public static readonly string UI_Left = "UI_Left"; - public static readonly string UI_Right = "UI_Right"; - public static readonly string UI_Select = "UI_Select"; - public static readonly string UI_Back = "UI_Back"; - public static readonly string UI_Toggle = "UI_Toggle"; - public static readonly string CycleNextPanel = "CycleNextPanel"; - public static readonly string CyclePreviousPanel = "CyclePreviousPanel"; - public static readonly string CycleNextPage = "CycleNextPage"; - public static readonly string CyclePreviousPage = "CyclePreviousPage"; - public static readonly string HeadLookReset = "HeadLookReset"; - public static readonly string HeadLookPitchUp = "HeadLookPitchUp"; - public static readonly string HeadLookPitchDown = "HeadLookPitchDown"; - public static readonly string HeadLookYawLeft = "HeadLookYawLeft"; - public static readonly string HeadLookYawRight = "HeadLookYawRight"; - public static readonly string CamPitchUp = "CamPitchUp"; - public static readonly string CamPitchDown = "CamPitchDown"; - public static readonly string CamYawLeft = "CamYawLeft"; - public static readonly string CamYawRight = "CamYawRight"; - public static readonly string CamTranslateForward = "CamTranslateForward"; - public static readonly string CamTranslateBackward = "CamTranslateBackward"; - public static readonly string CamTranslateLeft = "CamTranslateLeft"; - public static readonly string CamTranslateRight = "CamTranslateRight"; - public static readonly string CamTranslateUp = "CamTranslateUp"; - public static readonly string CamTranslateDown = "CamTranslateDown"; - public static readonly string CamZoomIn = "CamZoomIn"; - public static readonly string CamZoomOut = "CamZoomOut"; - public static readonly string CamTranslateZHold = "CamTranslateZHold"; - public static readonly string ToggleDriveAssist = "ToggleDriveAssist"; - public static readonly string SteerLeftButton = "SteerLeftButton"; - public static readonly string SteerRightButton = "SteerRightButton"; - public static readonly string BuggyRollLeftButton = "BuggyRollLeftButton"; - public static readonly string BuggyRollRightButton = "BuggyRollRightButton"; - public static readonly string BuggyPitchUpButton = "BuggyPitchUpButton"; - public static readonly string BuggyPitchDownButton = "BuggyPitchDownButton"; - public static readonly string VerticalThrustersButton = "VerticalThrustersButton"; - public static readonly string BuggyPrimaryFireButton = "BuggyPrimaryFireButton"; - public static readonly string BuggySecondaryFireButton = "BuggySecondaryFireButton"; - public static readonly string AutoBreakBuggyButton = "AutoBreakBuggyButton"; - public static readonly string HeadlightsBuggyButton = "HeadlightsBuggyButton"; - public static readonly string ToggleBuggyTurretButton = "ToggleBuggyTurretButton"; - public static readonly string SelectTarget_Buggy = "SelectTarget_Buggy"; - public static readonly string BuggyTurretYawLeftButton = "BuggyTurretYawLeftButton"; - public static readonly string BuggyTurretYawRightButton = "BuggyTurretYawRightButton"; - public static readonly string BuggyTurretPitchUpButton = "BuggyTurretPitchUpButton"; - public static readonly string BuggyTurretPitchDownButton = "BuggyTurretPitchDownButton"; - public static readonly string BuggyToggleReverseThrottleInput = "BuggyToggleReverseThrottleInput"; - public static readonly string IncreaseSpeedButtonMax = "IncreaseSpeedButtonMax"; - public static readonly string DecreaseSpeedButtonMax = "DecreaseSpeedButtonMax"; - public static readonly string IncreaseEnginesPower_Buggy = "IncreaseEnginesPower_Buggy"; - public static readonly string IncreaseWeaponsPower_Buggy = "IncreaseWeaponsPower_Buggy"; - public static readonly string IncreaseSystemsPower_Buggy = "IncreaseSystemsPower_Buggy"; - public static readonly string ResetPowerDistribution_Buggy = "ResetPowerDistribution_Buggy"; - public static readonly string ToggleCargoScoop_Buggy = "ToggleCargoScoop_Buggy"; - public static readonly string EjectAllCargo_Buggy = "EjectAllCargo_Buggy"; - public static readonly string RecallDismissShip = "RecallDismissShip"; - public static readonly string UIFocus_Buggy = "UIFocus_Buggy"; - public static readonly string FocusLeftPanel_Buggy = "FocusLeftPanel_Buggy"; - public static readonly string FocusCommsPanel_Buggy = "FocusCommsPanel_Buggy"; - public static readonly string QuickCommsPanel_Buggy = "QuickCommsPanel_Buggy"; - public static readonly string FocusRadarPanel_Buggy = "FocusRadarPanel_Buggy"; - public static readonly string FocusRightPanel_Buggy = "FocusRightPanel_Buggy"; - public static readonly string GalaxyMapOpen_Buggy = "GalaxyMapOpen_Buggy"; - public static readonly string SystemMapOpen_Buggy = "SystemMapOpen_Buggy"; - public static readonly string HeadLookToggle_Buggy = "HeadLookToggle_Buggy"; - public static readonly string MultiCrewToggleMode = "MultiCrewToggleMode"; - public static readonly string MultiCrewPrimaryFire = "MultiCrewPrimaryFire"; - public static readonly string MultiCrewSecondaryFire = "MultiCrewSecondaryFire"; - public static readonly string MultiCrewPrimaryUtilityFire = "MultiCrewPrimaryUtilityFire"; - public static readonly string MultiCrewSecondaryUtilityFire = "MultiCrewSecondaryUtilityFire"; - public static readonly string MultiCrewThirdPersonYawLeftButton = "MultiCrewThirdPersonYawLeftButton"; - public static readonly string MultiCrewThirdPersonYawRightButton = "MultiCrewThirdPersonYawRightButton"; - public static readonly string MultiCrewThirdPersonPitchUpButton = "MultiCrewThirdPersonPitchUpButton"; - public static readonly string MultiCrewThirdPersonPitchDownButton = "MultiCrewThirdPersonPitchDownButton"; - public static readonly string MultiCrewThirdPersonFovOutButton = "MultiCrewThirdPersonFovOutButton"; - public static readonly string MultiCrewThirdPersonFovInButton = "MultiCrewThirdPersonFovInButton"; - public static readonly string MultiCrewCockpitUICycleForward = "MultiCrewCockpitUICycleForward"; - public static readonly string MultiCrewCockpitUICycleBackward = "MultiCrewCockpitUICycleBackward"; - public static readonly string OrderRequestDock = "OrderRequestDock"; - public static readonly string OrderDefensiveBehaviour = "OrderDefensiveBehaviour"; - public static readonly string OrderAggressiveBehaviour = "OrderAggressiveBehaviour"; - public static readonly string OrderFocusTarget = "OrderFocusTarget"; - public static readonly string OrderHoldFire = "OrderHoldFire"; - public static readonly string OrderHoldPosition = "OrderHoldPosition"; - public static readonly string OrderFollow = "OrderFollow"; - public static readonly string OpenOrders = "OpenOrders"; - public static readonly string PhotoCameraToggle = "PhotoCameraToggle"; - public static readonly string PhotoCameraToggle_Buggy = "PhotoCameraToggle_Buggy"; - public static readonly string VanityCameraScrollLeft = "VanityCameraScrollLeft"; - public static readonly string VanityCameraScrollRight = "VanityCameraScrollRight"; - public static readonly string ToggleFreeCam = "ToggleFreeCam"; - public static readonly string VanityCameraOne = "VanityCameraOne"; - public static readonly string VanityCameraTwo = "VanityCameraTwo"; - public static readonly string VanityCameraThree = "VanityCameraThree"; - public static readonly string VanityCameraFour = "VanityCameraFour"; - public static readonly string VanityCameraFive = "VanityCameraFive"; - public static readonly string VanityCameraSix = "VanityCameraSix"; - public static readonly string VanityCameraSeven = "VanityCameraSeven"; - public static readonly string VanityCameraEight = "VanityCameraEight"; - public static readonly string VanityCameraNine = "VanityCameraNine"; - public static readonly string FreeCamToggleHUD = "FreeCamToggleHUD"; - public static readonly string FreeCamSpeedInc = "FreeCamSpeedInc"; - public static readonly string FreeCamSpeedDec = "FreeCamSpeedDec"; - public static readonly string ToggleReverseThrottleInputFreeCam = "ToggleReverseThrottleInputFreeCam"; - public static readonly string MoveFreeCamForward = "MoveFreeCamForward"; - public static readonly string MoveFreeCamBackwards = "MoveFreeCamBackwards"; - public static readonly string MoveFreeCamRight = "MoveFreeCamRight"; - public static readonly string MoveFreeCamLeft = "MoveFreeCamLeft"; - public static readonly string MoveFreeCamUp = "MoveFreeCamUp"; - public static readonly string MoveFreeCamDown = "MoveFreeCamDown"; - public static readonly string PitchCameraUp = "PitchCameraUp"; - public static readonly string PitchCameraDown = "PitchCameraDown"; - public static readonly string YawCameraLeft = "YawCameraLeft"; - public static readonly string YawCameraRight = "YawCameraRight"; - public static readonly string RollCameraLeft = "RollCameraLeft"; - public static readonly string RollCameraRight = "RollCameraRight"; - public static readonly string ToggleRotationLock = "ToggleRotationLock"; - public static readonly string FixCameraRelativeToggle = "FixCameraRelativeToggle"; - public static readonly string FixCameraWorldToggle = "FixCameraWorldToggle"; - public static readonly string QuitCamera = "QuitCamera"; - public static readonly string ToggleAdvanceMode = "ToggleAdvanceMode"; - public static readonly string FreeCamZoomIn = "FreeCamZoomIn"; - public static readonly string FreeCamZoomOut = "FreeCamZoomOut"; - public static readonly string FStopDec = "FStopDec"; - public static readonly string FStopInc = "FStopInc"; - public static readonly string CommanderCreator_Undo = "CommanderCreator_Undo"; - public static readonly string CommanderCreator_Redo = "CommanderCreator_Redo"; - public static readonly string CommanderCreator_Rotation_MouseToggle = "CommanderCreator_Rotation_MouseToggle"; - public static readonly string GalnetAudio_Play_Pause = "GalnetAudio_Play_Pause"; - public static readonly string GalnetAudio_SkipForward = "GalnetAudio_SkipForward"; - public static readonly string GalnetAudio_SkipBackward = "GalnetAudio_SkipBackward"; - public static readonly string GalnetAudio_ClearQueue = "GalnetAudio_ClearQueue"; - public static readonly string ExplorationFSSEnter = "ExplorationFSSEnter"; - public static readonly string ExplorationFSSCameraPitchIncreaseButton = "ExplorationFSSCameraPitchIncreaseButton"; - public static readonly string ExplorationFSSCameraPitchDecreaseButton = "ExplorationFSSCameraPitchDecreaseButton"; - public static readonly string ExplorationFSSCameraYawIncreaseButton = "ExplorationFSSCameraYawIncreaseButton"; - public static readonly string ExplorationFSSCameraYawDecreaseButton = "ExplorationFSSCameraYawDecreaseButton"; - public static readonly string ExplorationFSSZoomIn = "ExplorationFSSZoomIn"; - public static readonly string ExplorationFSSZoomOut = "ExplorationFSSZoomOut"; - public static readonly string ExplorationFSSMiniZoomIn = "ExplorationFSSMiniZoomIn"; - public static readonly string ExplorationFSSMiniZoomOut = "ExplorationFSSMiniZoomOut"; - public static readonly string ExplorationFSSRadioTuningX_Increase = "ExplorationFSSRadioTuningX_Increase"; - public static readonly string ExplorationFSSRadioTuningX_Decrease = "ExplorationFSSRadioTuningX_Decrease"; - public static readonly string ExplorationFSSDiscoveryScan = "ExplorationFSSDiscoveryScan"; - public static readonly string ExplorationFSSQuit = "ExplorationFSSQuit"; - public static readonly string ExplorationFSSTarget = "ExplorationFSSTarget"; - public static readonly string ExplorationFSSShowHelp = "ExplorationFSSShowHelp"; - public static readonly string ExplorationSAAChangeScannedAreaViewToggle = "ExplorationSAAChangeScannedAreaViewToggle"; - public static readonly string ExplorationSAAExitThirdPerson = "ExplorationSAAExitThirdPerson"; - public static readonly string SAAThirdPersonYawLeftButton = "SAAThirdPersonYawLeftButton"; - public static readonly string SAAThirdPersonYawRightButton = "SAAThirdPersonYawRightButton"; - public static readonly string SAAThirdPersonPitchUpButton = "SAAThirdPersonPitchUpButton"; - public static readonly string SAAThirdPersonPitchDownButton = "SAAThirdPersonPitchDownButton"; - public static readonly string SAAThirdPersonFovOutButton = "SAAThirdPersonFovOutButton"; - public static readonly string SAAThirdPersonFovInButton = "SAAThirdPersonFovInButton"; + public static class EliteBindName + { + public static readonly string MouseReset = "MouseReset"; + public static readonly string YawLeftButton = "YawLeftButton"; + public static readonly string YawRightButton = "YawRightButton"; + public static readonly string YawToRollButton = "YawToRollButton"; + public static readonly string RollLeftButton = "RollLeftButton"; + public static readonly string RollRightButton = "RollRightButton"; + public static readonly string PitchUpButton = "PitchUpButton"; + public static readonly string PitchDownButton = "PitchDownButton"; + public static readonly string LeftThrustButton = "LeftThrustButton"; + public static readonly string RightThrustButton = "RightThrustButton"; + public static readonly string UpThrustButton = "UpThrustButton"; + public static readonly string DownThrustButton = "DownThrustButton"; + public static readonly string ForwardThrustButton = "ForwardThrustButton"; + public static readonly string BackwardThrustButton = "BackwardThrustButton"; + public static readonly string UseAlternateFlightValuesToggle = "UseAlternateFlightValuesToggle"; + public static readonly string ToggleReverseThrottleInput = "ToggleReverseThrottleInput"; + public static readonly string ForwardKey = "ForwardKey"; + public static readonly string BackwardKey = "BackwardKey"; + public static readonly string SetSpeedMinus100 = "SetSpeedMinus100"; + public static readonly string SetSpeedMinus75 = "SetSpeedMinus75"; + public static readonly string SetSpeedMinus50 = "SetSpeedMinus50"; + public static readonly string SetSpeedMinus25 = "SetSpeedMinus25"; + public static readonly string SetSpeedZero = "SetSpeedZero"; + public static readonly string SetSpeed25 = "SetSpeed25"; + public static readonly string SetSpeed50 = "SetSpeed50"; + public static readonly string SetSpeed75 = "SetSpeed75"; + public static readonly string SetSpeed100 = "SetSpeed100"; + public static readonly string YawLeftButton_Landing = "YawLeftButton_Landing"; + public static readonly string YawRightButton_Landing = "YawRightButton_Landing"; + public static readonly string PitchUpButton_Landing = "PitchUpButton_Landing"; + public static readonly string PitchDownButton_Landing = "PitchDownButton_Landing"; + public static readonly string RollLeftButton_Landing = "RollLeftButton_Landing"; + public static readonly string RollRightButton_Landing = "RollRightButton_Landing"; + public static readonly string LeftThrustButton_Landing = "LeftThrustButton_Landing"; + public static readonly string RightThrustButton_Landing = "RightThrustButton_Landing"; + public static readonly string UpThrustButton_Landing = "UpThrustButton_Landing"; + public static readonly string DownThrustButton_Landing = "DownThrustButton_Landing"; + public static readonly string ForwardThrustButton_Landing = "ForwardThrustButton_Landing"; + public static readonly string BackwardThrustButton_Landing = "BackwardThrustButton_Landing"; + public static readonly string ToggleFlightAssist = "ToggleFlightAssist"; + public static readonly string UseBoostJuice = "UseBoostJuice"; + public static readonly string HyperSuperCombination = "HyperSuperCombination"; + public static readonly string Supercruise = "Supercruise"; + public static readonly string Hyperspace = "Hyperspace"; + public static readonly string DisableRotationCorrectToggle = "DisableRotationCorrectToggle"; + public static readonly string OrbitLinesToggle = "OrbitLinesToggle"; + public static readonly string SelectTarget = "SelectTarget"; + public static readonly string CycleNextTarget = "CycleNextTarget"; + public static readonly string CyclePreviousTarget = "CyclePreviousTarget"; + public static readonly string SelectHighestThreat = "SelectHighestThreat"; + public static readonly string CycleNextHostileTarget = "CycleNextHostileTarget"; + public static readonly string CyclePreviousHostileTarget = "CyclePreviousHostileTarget"; + public static readonly string TargetWingman0 = "TargetWingman0"; + public static readonly string TargetWingman1 = "TargetWingman1"; + public static readonly string TargetWingman2 = "TargetWingman2"; + public static readonly string SelectTargetsTarget = "SelectTargetsTarget"; + public static readonly string WingNavLock = "WingNavLock"; + public static readonly string CycleNextSubsystem = "CycleNextSubsystem"; + public static readonly string CyclePreviousSubsystem = "CyclePreviousSubsystem"; + public static readonly string TargetNextRouteSystem = "TargetNextRouteSystem"; + public static readonly string PrimaryFire = "PrimaryFire"; + public static readonly string SecondaryFire = "SecondaryFire"; + public static readonly string CycleFireGroupNext = "CycleFireGroupNext"; + public static readonly string CycleFireGroupPrevious = "CycleFireGroupPrevious"; + public static readonly string DeployHardpointToggle = "DeployHardpointToggle"; + public static readonly string ToggleButtonUpInput = "ToggleButtonUpInput"; + public static readonly string DeployHeatSink = "DeployHeatSink"; + public static readonly string ShipSpotLightToggle = "ShipSpotLightToggle"; + public static readonly string RadarIncreaseRange = "RadarIncreaseRange"; + public static readonly string RadarDecreaseRange = "RadarDecreaseRange"; + public static readonly string IncreaseEnginesPower = "IncreaseEnginesPower"; + public static readonly string IncreaseWeaponsPower = "IncreaseWeaponsPower"; + public static readonly string IncreaseSystemsPower = "IncreaseSystemsPower"; + public static readonly string ResetPowerDistribution = "ResetPowerDistribution"; + public static readonly string HMDReset = "HMDReset"; + public static readonly string ToggleCargoScoop = "ToggleCargoScoop"; + public static readonly string EjectAllCargo = "EjectAllCargo"; + public static readonly string LandingGearToggle = "LandingGearToggle"; + public static readonly string MicrophoneMute = "MicrophoneMute"; + public static readonly string UseShieldCell = "UseShieldCell"; + public static readonly string FireChaffLauncher = "FireChaffLauncher"; + public static readonly string ChargeECM = "ChargeECM"; + public static readonly string WeaponColourToggle = "WeaponColourToggle"; + public static readonly string EngineColourToggle = "EngineColourToggle"; + public static readonly string NightVisionToggle = "NightVisionToggle"; + public static readonly string UIFocus = "UIFocus"; + public static readonly string FocusLeftPanel = "FocusLeftPanel"; + public static readonly string FocusCommsPanel = "FocusCommsPanel"; + public static readonly string QuickCommsPanel = "QuickCommsPanel"; + public static readonly string FocusRadarPanel = "FocusRadarPanel"; + public static readonly string FocusRightPanel = "FocusRightPanel"; + public static readonly string GalaxyMapOpen = "GalaxyMapOpen"; + public static readonly string SystemMapOpen = "SystemMapOpen"; + public static readonly string ShowPGScoreSummaryInput = "ShowPGScoreSummaryInput"; + public static readonly string HeadLookToggle = "HeadLookToggle"; + public static readonly string Pause = "Pause"; + public static readonly string FriendsMenu = "FriendsMenu"; + public static readonly string OpenCodexGoToDiscovery = "OpenCodexGoToDiscovery"; + public static readonly string PlayerHUDModeToggle = "PlayerHUDModeToggle"; + public static readonly string UI_Up = "UI_Up"; + public static readonly string UI_Down = "UI_Down"; + public static readonly string UI_Left = "UI_Left"; + public static readonly string UI_Right = "UI_Right"; + public static readonly string UI_Select = "UI_Select"; + public static readonly string UI_Back = "UI_Back"; + public static readonly string UI_Toggle = "UI_Toggle"; + public static readonly string CycleNextPanel = "CycleNextPanel"; + public static readonly string CyclePreviousPanel = "CyclePreviousPanel"; + public static readonly string CycleNextPage = "CycleNextPage"; + public static readonly string CyclePreviousPage = "CyclePreviousPage"; + public static readonly string HeadLookReset = "HeadLookReset"; + public static readonly string HeadLookPitchUp = "HeadLookPitchUp"; + public static readonly string HeadLookPitchDown = "HeadLookPitchDown"; + public static readonly string HeadLookYawLeft = "HeadLookYawLeft"; + public static readonly string HeadLookYawRight = "HeadLookYawRight"; + public static readonly string CamPitchUp = "CamPitchUp"; + public static readonly string CamPitchDown = "CamPitchDown"; + public static readonly string CamYawLeft = "CamYawLeft"; + public static readonly string CamYawRight = "CamYawRight"; + public static readonly string CamTranslateForward = "CamTranslateForward"; + public static readonly string CamTranslateBackward = "CamTranslateBackward"; + public static readonly string CamTranslateLeft = "CamTranslateLeft"; + public static readonly string CamTranslateRight = "CamTranslateRight"; + public static readonly string CamTranslateUp = "CamTranslateUp"; + public static readonly string CamTranslateDown = "CamTranslateDown"; + public static readonly string CamZoomIn = "CamZoomIn"; + public static readonly string CamZoomOut = "CamZoomOut"; + public static readonly string CamTranslateZHold = "CamTranslateZHold"; + public static readonly string ToggleDriveAssist = "ToggleDriveAssist"; + public static readonly string SteerLeftButton = "SteerLeftButton"; + public static readonly string SteerRightButton = "SteerRightButton"; + public static readonly string BuggyRollLeftButton = "BuggyRollLeftButton"; + public static readonly string BuggyRollRightButton = "BuggyRollRightButton"; + public static readonly string BuggyPitchUpButton = "BuggyPitchUpButton"; + public static readonly string BuggyPitchDownButton = "BuggyPitchDownButton"; + public static readonly string VerticalThrustersButton = "VerticalThrustersButton"; + public static readonly string BuggyPrimaryFireButton = "BuggyPrimaryFireButton"; + public static readonly string BuggySecondaryFireButton = "BuggySecondaryFireButton"; + public static readonly string AutoBreakBuggyButton = "AutoBreakBuggyButton"; + public static readonly string HeadlightsBuggyButton = "HeadlightsBuggyButton"; + public static readonly string ToggleBuggyTurretButton = "ToggleBuggyTurretButton"; + public static readonly string SelectTarget_Buggy = "SelectTarget_Buggy"; + public static readonly string BuggyTurretYawLeftButton = "BuggyTurretYawLeftButton"; + public static readonly string BuggyTurretYawRightButton = "BuggyTurretYawRightButton"; + public static readonly string BuggyTurretPitchUpButton = "BuggyTurretPitchUpButton"; + public static readonly string BuggyTurretPitchDownButton = "BuggyTurretPitchDownButton"; + public static readonly string BuggyToggleReverseThrottleInput = "BuggyToggleReverseThrottleInput"; + public static readonly string IncreaseSpeedButtonMax = "IncreaseSpeedButtonMax"; + public static readonly string DecreaseSpeedButtonMax = "DecreaseSpeedButtonMax"; + public static readonly string IncreaseEnginesPower_Buggy = "IncreaseEnginesPower_Buggy"; + public static readonly string IncreaseWeaponsPower_Buggy = "IncreaseWeaponsPower_Buggy"; + public static readonly string IncreaseSystemsPower_Buggy = "IncreaseSystemsPower_Buggy"; + public static readonly string ResetPowerDistribution_Buggy = "ResetPowerDistribution_Buggy"; + public static readonly string ToggleCargoScoop_Buggy = "ToggleCargoScoop_Buggy"; + public static readonly string EjectAllCargo_Buggy = "EjectAllCargo_Buggy"; + public static readonly string RecallDismissShip = "RecallDismissShip"; + public static readonly string UIFocus_Buggy = "UIFocus_Buggy"; + public static readonly string FocusLeftPanel_Buggy = "FocusLeftPanel_Buggy"; + public static readonly string FocusCommsPanel_Buggy = "FocusCommsPanel_Buggy"; + public static readonly string QuickCommsPanel_Buggy = "QuickCommsPanel_Buggy"; + public static readonly string FocusRadarPanel_Buggy = "FocusRadarPanel_Buggy"; + public static readonly string FocusRightPanel_Buggy = "FocusRightPanel_Buggy"; + public static readonly string GalaxyMapOpen_Buggy = "GalaxyMapOpen_Buggy"; + public static readonly string SystemMapOpen_Buggy = "SystemMapOpen_Buggy"; + public static readonly string HeadLookToggle_Buggy = "HeadLookToggle_Buggy"; + public static readonly string MultiCrewToggleMode = "MultiCrewToggleMode"; + public static readonly string MultiCrewPrimaryFire = "MultiCrewPrimaryFire"; + public static readonly string MultiCrewSecondaryFire = "MultiCrewSecondaryFire"; + public static readonly string MultiCrewPrimaryUtilityFire = "MultiCrewPrimaryUtilityFire"; + public static readonly string MultiCrewSecondaryUtilityFire = "MultiCrewSecondaryUtilityFire"; + public static readonly string MultiCrewThirdPersonYawLeftButton = "MultiCrewThirdPersonYawLeftButton"; + public static readonly string MultiCrewThirdPersonYawRightButton = "MultiCrewThirdPersonYawRightButton"; + public static readonly string MultiCrewThirdPersonPitchUpButton = "MultiCrewThirdPersonPitchUpButton"; + public static readonly string MultiCrewThirdPersonPitchDownButton = "MultiCrewThirdPersonPitchDownButton"; + public static readonly string MultiCrewThirdPersonFovOutButton = "MultiCrewThirdPersonFovOutButton"; + public static readonly string MultiCrewThirdPersonFovInButton = "MultiCrewThirdPersonFovInButton"; + public static readonly string MultiCrewCockpitUICycleForward = "MultiCrewCockpitUICycleForward"; + public static readonly string MultiCrewCockpitUICycleBackward = "MultiCrewCockpitUICycleBackward"; + public static readonly string OrderRequestDock = "OrderRequestDock"; + public static readonly string OrderDefensiveBehaviour = "OrderDefensiveBehaviour"; + public static readonly string OrderAggressiveBehaviour = "OrderAggressiveBehaviour"; + public static readonly string OrderFocusTarget = "OrderFocusTarget"; + public static readonly string OrderHoldFire = "OrderHoldFire"; + public static readonly string OrderHoldPosition = "OrderHoldPosition"; + public static readonly string OrderFollow = "OrderFollow"; + public static readonly string OpenOrders = "OpenOrders"; + public static readonly string PhotoCameraToggle = "PhotoCameraToggle"; + public static readonly string PhotoCameraToggle_Buggy = "PhotoCameraToggle_Buggy"; + public static readonly string VanityCameraScrollLeft = "VanityCameraScrollLeft"; + public static readonly string VanityCameraScrollRight = "VanityCameraScrollRight"; + public static readonly string ToggleFreeCam = "ToggleFreeCam"; + public static readonly string VanityCameraOne = "VanityCameraOne"; + public static readonly string VanityCameraTwo = "VanityCameraTwo"; + public static readonly string VanityCameraThree = "VanityCameraThree"; + public static readonly string VanityCameraFour = "VanityCameraFour"; + public static readonly string VanityCameraFive = "VanityCameraFive"; + public static readonly string VanityCameraSix = "VanityCameraSix"; + public static readonly string VanityCameraSeven = "VanityCameraSeven"; + public static readonly string VanityCameraEight = "VanityCameraEight"; + public static readonly string VanityCameraNine = "VanityCameraNine"; + public static readonly string FreeCamToggleHUD = "FreeCamToggleHUD"; + public static readonly string FreeCamSpeedInc = "FreeCamSpeedInc"; + public static readonly string FreeCamSpeedDec = "FreeCamSpeedDec"; + public static readonly string ToggleReverseThrottleInputFreeCam = "ToggleReverseThrottleInputFreeCam"; + public static readonly string MoveFreeCamForward = "MoveFreeCamForward"; + public static readonly string MoveFreeCamBackwards = "MoveFreeCamBackwards"; + public static readonly string MoveFreeCamRight = "MoveFreeCamRight"; + public static readonly string MoveFreeCamLeft = "MoveFreeCamLeft"; + public static readonly string MoveFreeCamUp = "MoveFreeCamUp"; + public static readonly string MoveFreeCamDown = "MoveFreeCamDown"; + public static readonly string PitchCameraUp = "PitchCameraUp"; + public static readonly string PitchCameraDown = "PitchCameraDown"; + public static readonly string YawCameraLeft = "YawCameraLeft"; + public static readonly string YawCameraRight = "YawCameraRight"; + public static readonly string RollCameraLeft = "RollCameraLeft"; + public static readonly string RollCameraRight = "RollCameraRight"; + public static readonly string ToggleRotationLock = "ToggleRotationLock"; + public static readonly string FixCameraRelativeToggle = "FixCameraRelativeToggle"; + public static readonly string FixCameraWorldToggle = "FixCameraWorldToggle"; + public static readonly string QuitCamera = "QuitCamera"; + public static readonly string ToggleAdvanceMode = "ToggleAdvanceMode"; + public static readonly string FreeCamZoomIn = "FreeCamZoomIn"; + public static readonly string FreeCamZoomOut = "FreeCamZoomOut"; + public static readonly string FStopDec = "FStopDec"; + public static readonly string FStopInc = "FStopInc"; + public static readonly string CommanderCreator_Undo = "CommanderCreator_Undo"; + public static readonly string CommanderCreator_Redo = "CommanderCreator_Redo"; + public static readonly string CommanderCreator_Rotation_MouseToggle = "CommanderCreator_Rotation_MouseToggle"; + public static readonly string GalnetAudio_Play_Pause = "GalnetAudio_Play_Pause"; + public static readonly string GalnetAudio_SkipForward = "GalnetAudio_SkipForward"; + public static readonly string GalnetAudio_SkipBackward = "GalnetAudio_SkipBackward"; + public static readonly string GalnetAudio_ClearQueue = "GalnetAudio_ClearQueue"; + public static readonly string ExplorationFSSEnter = "ExplorationFSSEnter"; + public static readonly string ExplorationFSSCameraPitchIncreaseButton = "ExplorationFSSCameraPitchIncreaseButton"; + public static readonly string ExplorationFSSCameraPitchDecreaseButton = "ExplorationFSSCameraPitchDecreaseButton"; + public static readonly string ExplorationFSSCameraYawIncreaseButton = "ExplorationFSSCameraYawIncreaseButton"; + public static readonly string ExplorationFSSCameraYawDecreaseButton = "ExplorationFSSCameraYawDecreaseButton"; + public static readonly string ExplorationFSSZoomIn = "ExplorationFSSZoomIn"; + public static readonly string ExplorationFSSZoomOut = "ExplorationFSSZoomOut"; + public static readonly string ExplorationFSSMiniZoomIn = "ExplorationFSSMiniZoomIn"; + public static readonly string ExplorationFSSMiniZoomOut = "ExplorationFSSMiniZoomOut"; + public static readonly string ExplorationFSSRadioTuningX_Increase = "ExplorationFSSRadioTuningX_Increase"; + public static readonly string ExplorationFSSRadioTuningX_Decrease = "ExplorationFSSRadioTuningX_Decrease"; + public static readonly string ExplorationFSSDiscoveryScan = "ExplorationFSSDiscoveryScan"; + public static readonly string ExplorationFSSQuit = "ExplorationFSSQuit"; + public static readonly string ExplorationFSSTarget = "ExplorationFSSTarget"; + public static readonly string ExplorationFSSShowHelp = "ExplorationFSSShowHelp"; + public static readonly string ExplorationSAAChangeScannedAreaViewToggle = "ExplorationSAAChangeScannedAreaViewToggle"; + public static readonly string ExplorationSAAExitThirdPerson = "ExplorationSAAExitThirdPerson"; + public static readonly string SAAThirdPersonYawLeftButton = "SAAThirdPersonYawLeftButton"; + public static readonly string SAAThirdPersonYawRightButton = "SAAThirdPersonYawRightButton"; + public static readonly string SAAThirdPersonPitchUpButton = "SAAThirdPersonPitchUpButton"; + public static readonly string SAAThirdPersonPitchDownButton = "SAAThirdPersonPitchDownButton"; + public static readonly string SAAThirdPersonFovOutButton = "SAAThirdPersonFovOutButton"; + public static readonly string SAAThirdPersonFovInButton = "SAAThirdPersonFovInButton"; + } + + public static Dictionary eliteKeyToDeviceKey = new Dictionary() + { + {"Key_Escape", DeviceKeys.ESC}, + {"Key_F1", DeviceKeys.F1}, + {"Key_F2", DeviceKeys.F2}, + {"Key_F3", DeviceKeys.F3}, + {"Key_F4", DeviceKeys.F4}, + {"Key_F5", DeviceKeys.F5}, + {"Key_F6", DeviceKeys.F6}, + {"Key_F7", DeviceKeys.F7}, + {"Key_F8", DeviceKeys.F8}, + {"Key_F9", DeviceKeys.F9}, + {"Key_F10", DeviceKeys.F10}, + {"Key_F11", DeviceKeys.F11}, + {"Key_F12", DeviceKeys.F12}, + {"Key_PrintScreen", DeviceKeys.PRINT_SCREEN}, + {"Key_ScrollLock", DeviceKeys.SCROLL_LOCK}, + {"Key_PauseBreak", DeviceKeys.PAUSE_BREAK}, + {"Key_Grave", DeviceKeys.TILDE}, + {"Key_1", DeviceKeys.ONE}, + {"Key_2", DeviceKeys.TWO}, + {"Key_3", DeviceKeys.THREE}, + {"Key_4", DeviceKeys.FOUR}, + {"Key_5", DeviceKeys.FIVE}, + {"Key_6", DeviceKeys.SIX}, + {"Key_7", DeviceKeys.SEVEN}, + {"Key_8", DeviceKeys.EIGHT}, + {"Key_9", DeviceKeys.NINE}, + {"Key_0", DeviceKeys.ZERO}, + {"Key_Minus", DeviceKeys.MINUS}, + {"Key_Equals", DeviceKeys.EQUALS}, + {"Key_Backspace", DeviceKeys.BACKSPACE}, + {"Key_Insert", DeviceKeys.INSERT}, + {"Key_Home", DeviceKeys.HOME}, + {"Key_PageUp", DeviceKeys.PAGE_UP}, + {"Key_Numpad_Lock", DeviceKeys.NUM_LOCK}, + {"Key_Numpad_Divide", DeviceKeys.NUM_SLASH}, + {"Key_Numpad_Multiply", DeviceKeys.NUM_ASTERISK}, + {"Key_Numpad_Subtract", DeviceKeys.NUM_MINUS}, + {"Key_Tab", DeviceKeys.TAB}, + {"Key_Q", DeviceKeys.Q}, + {"Key_W", DeviceKeys.W}, + {"Key_E", DeviceKeys.E}, + {"Key_R", DeviceKeys.R}, + {"Key_T", DeviceKeys.T}, + {"Key_Y", DeviceKeys.Y}, + {"Key_U", DeviceKeys.U}, + {"Key_I", DeviceKeys.I}, + {"Key_O", DeviceKeys.O}, + {"Key_P", DeviceKeys.P}, + {"Key_LeftBracket", DeviceKeys.OPEN_BRACKET}, + {"Key_RightBracket", DeviceKeys.CLOSE_BRACKET}, + {"Key_BackSlash", DeviceKeys.BACKSLASH}, + {"Key_Delete", DeviceKeys.DELETE}, + {"Key_End", DeviceKeys.END}, + {"Key_PageDown", DeviceKeys.PAGE_DOWN}, + {"Key_Numpad_7", DeviceKeys.NUM_SEVEN}, + {"Key_Numpad_8", DeviceKeys.NUM_EIGHT}, + {"Key_Numpad_9", DeviceKeys.NUM_NINE}, + {"Key_Numpad_Add", DeviceKeys.NUM_PLUS}, + {"Key_CapsLock", DeviceKeys.CAPS_LOCK}, + {"Key_A", DeviceKeys.A}, + {"Key_S", DeviceKeys.S}, + {"Key_D", DeviceKeys.D}, + {"Key_F", DeviceKeys.F}, + {"Key_G", DeviceKeys.G}, + {"Key_H", DeviceKeys.H}, + {"Key_J", DeviceKeys.J}, + {"Key_K", DeviceKeys.K}, + {"Key_L", DeviceKeys.L}, + {"Key_SemiColon", DeviceKeys.SEMICOLON}, + {"Key_Apostrophe", DeviceKeys.APOSTROPHE}, + {"Key_Enter", DeviceKeys.ENTER}, + {"Key_Numpad_4", DeviceKeys.NUM_FOUR}, + {"Key_Numpad_5", DeviceKeys.NUM_FIVE}, + {"Key_Numpad_6", DeviceKeys.NUM_SIX}, + {"Key_LeftShift", DeviceKeys.LEFT_SHIFT}, + {"Key_Z", DeviceKeys.Z}, + {"Key_X", DeviceKeys.X}, + {"Key_C", DeviceKeys.C}, + {"Key_V", DeviceKeys.V}, + {"Key_B", DeviceKeys.B}, + {"Key_N", DeviceKeys.N}, + {"Key_M", DeviceKeys.M}, + {"Key_Comma", DeviceKeys.COMMA}, + {"Key_Period", DeviceKeys.PERIOD}, + {"Key_Slash", DeviceKeys.FORWARD_SLASH}, + {"Key_RightShift", DeviceKeys.RIGHT_SHIFT}, + {"Key_UpArrow", DeviceKeys.ARROW_UP}, + {"Key_Numpad_1", DeviceKeys.NUM_ONE}, + {"Key_Numpad_2", DeviceKeys.NUM_TWO}, + {"Key_Numpad_3", DeviceKeys.NUM_THREE}, + {"Key_Numpad_Enter", DeviceKeys.NUM_ENTER}, + {"Key_LeftControl", DeviceKeys.LEFT_CONTROL}, + {"Key_LeftWindows", DeviceKeys.LEFT_WINDOWS}, + {"Key_LeftAlt", DeviceKeys.LEFT_ALT}, + {"Key_Space", DeviceKeys.SPACE}, + {"Key_RightAlt", DeviceKeys.RIGHT_ALT}, + {"Key_RightWindows", DeviceKeys.RIGHT_WINDOWS}, + {"Key_Application_select", DeviceKeys.APPLICATION_SELECT}, + {"Key_RightControl", DeviceKeys.RIGHT_CONTROL}, + {"Key_LeftArrow", DeviceKeys.ARROW_LEFT}, + {"Key_DownArrow", DeviceKeys.ARROW_DOWN}, + {"Key_RightArrow", DeviceKeys.ARROW_RIGHT}, + {"Key_Numpad_0", DeviceKeys.NUM_ZERO}, + {"Key_Numpad_Decimal", DeviceKeys.NUM_PERIOD} + }; + + public class Mapping + { + public DeviceKeys key = DeviceKeys.NONE; + public List modifiers = new List(); + + public void SetKey(string eliteKey) + { + if (Bind.eliteKeyToDeviceKey.ContainsKey(eliteKey)) + { + key = Bind.eliteKeyToDeviceKey[eliteKey]; + } + } + public void AddModifier(string eliteKey) + { + if (Bind.eliteKeyToDeviceKey.ContainsKey(eliteKey)) + { + modifiers.Add(Bind.eliteKeyToDeviceKey[eliteKey]); + } + } + + public bool HasKey() + { + return key != null; + } + } + + private string command; + public HashSet mappings = new HashSet(); + + public Bind(string command) + { + this.command = command; + } + + public void AddMapping(Mapping mapping) + { + mappings.Add(mapping); + } + } + + public class ControlGroup + { + public Color color; + public List commands; + public StatusState neededStatus; + + public ControlGroup(string[] commands) + { + this.commands = commands.ToList(); + } } /// @@ -266,13 +433,32 @@ public class EliteBind /// public class Controls : Node { - public string timestamp; - public string @event; - public long Flags; - public int[] Pips; - public int FireGroup; - public int GuiFocus; - public double Fuel; - public double Cargo; + public HashSet modifierKeys; + public Dictionary commandToBind; + public Dictionary bindToCommand; + +// public static Dictionary groups = new Dictionary() +// { +// {"camera", new ControlGroup(new string[] +// { +// Bind.EliteBindName.PhotoCameraToggle, Bind.EliteBindName.PhotoCameraToggle_Buggy, Bind.EliteBindName.VanityCameraScrollLeft, +// Bind.EliteBindName.VanityCameraScrollRight, Bind.EliteBindName.ToggleFreeCam, Bind.EliteBindName.FreeCamToggleHUD, +// Bind.EliteBindName.FixCameraRelativeToggle, Bind.EliteBindName.FixCameraWorldToggle +// })}, +// {"movement_speed", new ControlGroup(new string[] +// { +// Bind.EliteBindName.ForwardKey, Bind.EliteBindName.BackwardKey, Bind.EliteBindName.IncreaseEnginesPower, Bind.EliteBindName.SetSpeedZero, +// Bind.EliteBindName.SetSpeed25, Bind.EliteBindName.SetSpeed50, Bind.EliteBindName.SetSpeed75, Bind.EliteBindName.SetSpeed100 +// })}, +// {"movement_speed2", new ControlGroup(new string[] +// { +// Bind.EliteBindName.SetSpeedMinus100, Bind.EliteBindName.SetSpeedMinus75, Bind.EliteBindName.SetSpeedMinus50, +// Bind.EliteBindName.SetSpeedMinus25, Bind.EliteBindName.AutoBreakBuggyButton +// })}, +// {"movement_speed3", new ControlGroup(new string[] +// { +// Bind.EliteBindName.OrderHoldPosition +// })}, +// }; } } \ No newline at end of file diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs index a141f4614..08c2b46d7 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs @@ -1,6 +1,10 @@ using System; +using System.Collections.Generic; using System.IO; +using System.Linq; using System.Xml; +using Aurora.Profiles.EliteDangerous.GSI; +using Aurora.Profiles.EliteDangerous.GSI.Nodes; namespace Aurora.Profiles.EliteDangerous { @@ -82,27 +86,64 @@ private void ParseBindFile() { //TODO: Parse configuration XML Global.logger.Error("Current bind file: " + currentBindFile); + + HashSet modifierKeys = new HashSet(); + + Dictionary commandToBind = new Dictionary(); + Dictionary bindToCommand = new Dictionary(); + XmlDocument doc = new XmlDocument(); try { doc.Load(currentBindFile); - XmlNodeList binds = doc.DocumentElement.ChildNodes; - foreach(XmlNode bind in binds) + XmlNodeList commands = doc.DocumentElement.ChildNodes; + foreach(XmlNode command in commands) { - foreach (XmlNode mapping in bind.ChildNodes) + Bind bind = new Bind(command.Name); + foreach (XmlNode xmlMapping in command.ChildNodes) { - if(mapping.Name == "Primary" || mapping.Name == "Secondary") { - // This is a bind - Global.logger.Error(bind.Name + " " + mapping.Name + ": " + mapping.Attributes["Device"].Value + " " + mapping.Attributes["Key"].Value); + if (xmlMapping.Name != "Primary" && xmlMapping.Name != "Secondary") continue; + + Bind.Mapping mapping = new Bind.Mapping(); + + if (xmlMapping.Attributes["Device"].Value == "Keyboard") + { + mapping.SetKey(xmlMapping.Attributes["Key"].Value); + } + + foreach (XmlNode property in xmlMapping.ChildNodes) + { + if (property.Name != "Modifier") continue; + + if (property.Attributes["Device"].Value == "Keyboard" && !string.IsNullOrEmpty(property.Attributes["Key"].Value)) + { + modifierKeys.Add(property.Attributes["Key"].Value); + mapping.AddModifier(property.Attributes["Key"].Value); + } + } + + if (mapping.HasKey()) + { + bind.AddMapping(mapping); } } - } + if (bind.mappings.Any()) + { + commandToBind.Add(command.Name, bind); + bindToCommand.Add(bind, command.Name); + } + } } catch (System.IO.FileNotFoundException) { Global.logger.Error("Error loading binds file: " + currentBindFile); } + + GSI.Nodes.Controls controls = (_game_state as GameState_EliteDangerous).Controls; + controls.modifierKeys = modifierKeys; + controls.commandToBind = commandToBind; + controls.bindToCommand = bindToCommand; } public override void OnStart() diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs index fc9153aaa..7dec88f57 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs @@ -1,9 +1,12 @@ using System; +using System.Collections.Generic; using Aurora.EffectsEngine; using Aurora.Settings.Layers; using System.Drawing; using System.Windows.Controls; using Aurora.Devices; +using Aurora.Profiles.EliteDangerous.GSI; +using Aurora.Profiles.EliteDangerous.GSI.Nodes; using CSScriptLibrary; namespace Aurora.Profiles.EliteDangerous.Layers @@ -133,10 +136,54 @@ public override EffectLayer Render(IGameState state) { EffectLayer keyBindsLayer = new EffectLayer("Elite: Dangerous - Key Binds"); - keyBindsLayer.Set(DeviceKeys.C, this.Properties.ShipStuffColor); - keyBindsLayer.Set(DeviceKeys.V, this.Properties.DefenceColor); - keyBindsLayer.Set(DeviceKeys.B, this.Properties.DefenceDimmedColor); - keyBindsLayer.Set(DeviceKeys.A, GetBlinkingColor(Properties.ShipStuffColor)); + Dictionary groups = new Dictionary() + { + {"camera", new ControlGroup(new string[] + { + Bind.EliteBindName.PhotoCameraToggle, Bind.EliteBindName.PhotoCameraToggle_Buggy, Bind.EliteBindName.VanityCameraScrollLeft, + Bind.EliteBindName.VanityCameraScrollRight, Bind.EliteBindName.ToggleFreeCam, Bind.EliteBindName.FreeCamToggleHUD, + Bind.EliteBindName.FixCameraRelativeToggle, Bind.EliteBindName.FixCameraWorldToggle + })}, + {"movement_speed", new ControlGroup(new string[] + { + Bind.EliteBindName.ForwardKey, Bind.EliteBindName.BackwardKey, Bind.EliteBindName.IncreaseEnginesPower, Bind.EliteBindName.SetSpeedZero, + Bind.EliteBindName.SetSpeed25, Bind.EliteBindName.SetSpeed50, Bind.EliteBindName.SetSpeed75, Bind.EliteBindName.SetSpeed100 + })}, + {"movement_speed2", new ControlGroup(new string[] + { + Bind.EliteBindName.SetSpeedMinus100, Bind.EliteBindName.SetSpeedMinus75, Bind.EliteBindName.SetSpeedMinus50, + Bind.EliteBindName.SetSpeedMinus25, Bind.EliteBindName.AutoBreakBuggyButton + })}, + {"movement_speed3", new ControlGroup(new string[] + { + Bind.EliteBindName.OrderHoldPosition + })}, + }; + + groups["camera"].color = this.Properties.CameraColor; + groups["movement_speed"].color = this.Properties.MovementSpeedColor; + groups["movement_speed2"].color = this.Properties.MovementSpeedColor; + groups["movement_speed3"].color = this.Properties.MovementSpeedColor; + + GSI.Nodes.Controls controls = (state as GameState_EliteDangerous).Controls; + foreach(KeyValuePair entry in controls.commandToBind) + { + foreach (KeyValuePair group in groups) + { + if (group.Value.commands.Contains(entry.Key)) + { + foreach (Bind.Mapping mapping in entry.Value.mappings) + { + keyBindsLayer.Set(mapping.key, group.Value.color); + } + } + } + } + +// keyBindsLayer.Set(DeviceKeys.C, this.Properties.ShipStuffColor); +// keyBindsLayer.Set(DeviceKeys.V, this.Properties.DefenceColor); +// keyBindsLayer.Set(DeviceKeys.B, this.Properties.DefenceDimmedColor); +// keyBindsLayer.Set(DeviceKeys.A, GetBlinkingColor(Properties.ShipStuffColor)); return keyBindsLayer; } From 954272d6f1c00d212c6d0f2daf79fe7251bca62a Mon Sep 17 00:00:00 2001 From: Arturs Ziborovs Date: Mon, 26 Aug 2019 00:46:32 +0300 Subject: [PATCH 12/67] Fixed a crash when reading file after it was changed --- .../GameEvent_EliteDangerous.cs | 43 +++++++++++++++++-- 1 file changed, 39 insertions(+), 4 deletions(-) diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs index 08c2b46d7..6cce39675 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs @@ -2,6 +2,7 @@ using System.Collections.Generic; using System.IO; using System.Linq; +using System.Timers; using System.Xml; using Aurora.Profiles.EliteDangerous.GSI; using Aurora.Profiles.EliteDangerous.GSI.Nodes; @@ -10,6 +11,7 @@ namespace Aurora.Profiles.EliteDangerous { public class GameEvent_EliteDangerous : GameEvent_Generic { + readonly DelayedMethodCaller delayedFileRead = new DelayedMethodCaller(1); private static readonly string journalFolder = Path.Combine( Environment.GetFolderPath(Environment.SpecialFolder.UserProfile), @@ -57,12 +59,45 @@ public void StopWatchingBindFiles() } } + public class DelayedMethodCaller + { + int _delay; + Timer _timer = new Timer(); + + public DelayedMethodCaller(int delay) + { + _delay = delay; + } + + public void CallMethod(Action action) + { + if (!_timer.Enabled) + { + _timer = new Timer(_delay) + { + AutoReset = false + }; + _timer.Elapsed += (object sender, ElapsedEventArgs e) => + { + action(); + }; + _timer.Start(); + } + else + { + _timer.Stop(); + _timer.Start(); + } + } + } + private void OnBindsFileChanged(object sender, FileSystemEventArgs e) { - // This is a fix for multiple change events being triggered - if (bindWatcher != null) bindWatcher.EnableRaisingEvents = false; - ReadBindFiles(); - if (bindWatcher != null) bindWatcher.EnableRaisingEvents = true; + /* + * This event can fire multiple times in a row. We need to make sure to read the file only after + * the last event is fired to avoid running into a locked file + */ + delayedFileRead.CallMethod(() => ReadBindFiles()); } private void ReadBindFiles() From 5cd7dd4425b104b1d425a5a2efe099aa476cf94b Mon Sep 17 00:00:00 2001 From: Arturs Ziborovs Date: Mon, 26 Aug 2019 19:25:38 +0300 Subject: [PATCH 13/67] Improved color groups - working on making color groups depend on the game status --- .../GSI/GameState_EliteDangerous.cs | 14 ++- .../EliteDangerous/GSI/Nodes/Controls.cs | 47 +++++----- .../EliteDangerous/GSI/Nodes/Journal.cs | 15 +++ .../EliteDangerous/GSI/Nodes/Status.cs | 23 ++++- .../EliteDangerousKeyBindsLayerHandler.cs | 92 ++++++++++++------- .../Project-Aurora/Project-Aurora.csproj | 1 + 6 files changed, 131 insertions(+), 61 deletions(-) create mode 100644 Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Journal.cs diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/GameState_EliteDangerous.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/GameState_EliteDangerous.cs index 00e50557c..b68b0da8b 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/GameState_EliteDangerous.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/GameState_EliteDangerous.cs @@ -2,11 +2,23 @@ namespace Aurora.Profiles.EliteDangerous.GSI { - class GameState_EliteDangerous : GameState + public class GameState_EliteDangerous : GameState { private Status status; + private Journal journal; private Nodes.Controls controls; + public Journal Journal + { + get + { + if (journal == null) + journal = new Journal(); + + return journal; + } + } + public Status Status { get diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Controls.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Controls.cs index 182a06ca4..9038ddaac 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Controls.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Controls.cs @@ -418,13 +418,32 @@ public void AddMapping(Mapping mapping) public class ControlGroup { + public string colorGroupName; public Color color; public List commands; - public StatusState neededStatus; + public StatusState neededStatusState; - public ControlGroup(string[] commands) + public ControlGroup(string colorGroupName, string[] commands) : this(colorGroupName, commands, null) { } + + public ControlGroup(string colorGroupName, string[] commands, StatusState neededStatusState) { + this.colorGroupName = colorGroupName; this.commands = commands.ToList(); + this.neededStatusState = neededStatusState; + } + + public bool ConditionSatisfied(Status status) + { + return ConditionSatisfied(status.Flags, status.GuiFocus); + } + public bool ConditionSatisfied(long flags, int guiFocus) + { + if (neededStatusState != null) + { + return neededStatusState.ConditionSatisfied(flags, guiFocus); + } + + return true; } } @@ -436,29 +455,5 @@ public class Controls : Node public HashSet modifierKeys; public Dictionary commandToBind; public Dictionary bindToCommand; - -// public static Dictionary groups = new Dictionary() -// { -// {"camera", new ControlGroup(new string[] -// { -// Bind.EliteBindName.PhotoCameraToggle, Bind.EliteBindName.PhotoCameraToggle_Buggy, Bind.EliteBindName.VanityCameraScrollLeft, -// Bind.EliteBindName.VanityCameraScrollRight, Bind.EliteBindName.ToggleFreeCam, Bind.EliteBindName.FreeCamToggleHUD, -// Bind.EliteBindName.FixCameraRelativeToggle, Bind.EliteBindName.FixCameraWorldToggle -// })}, -// {"movement_speed", new ControlGroup(new string[] -// { -// Bind.EliteBindName.ForwardKey, Bind.EliteBindName.BackwardKey, Bind.EliteBindName.IncreaseEnginesPower, Bind.EliteBindName.SetSpeedZero, -// Bind.EliteBindName.SetSpeed25, Bind.EliteBindName.SetSpeed50, Bind.EliteBindName.SetSpeed75, Bind.EliteBindName.SetSpeed100 -// })}, -// {"movement_speed2", new ControlGroup(new string[] -// { -// Bind.EliteBindName.SetSpeedMinus100, Bind.EliteBindName.SetSpeedMinus75, Bind.EliteBindName.SetSpeedMinus50, -// Bind.EliteBindName.SetSpeedMinus25, Bind.EliteBindName.AutoBreakBuggyButton -// })}, -// {"movement_speed3", new ControlGroup(new string[] -// { -// Bind.EliteBindName.OrderHoldPosition -// })}, -// }; } } \ No newline at end of file diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Journal.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Journal.cs new file mode 100644 index 000000000..2ddd4a13e --- /dev/null +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Journal.cs @@ -0,0 +1,15 @@ +namespace Aurora.Profiles.EliteDangerous.GSI.Nodes +{ + public enum FighterStatus + { + None, Launched, Unmanned + } + + public class Journal : Node + { + public FighterStatus fighterStatus = FighterStatus.None; + public bool hasChaff = false; + public bool hasHeatSink = false; + public bool hasShieldCellBank = false; + } +} \ No newline at end of file diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Status.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Status.cs index 8af14a720..48c154df5 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Status.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Status.cs @@ -1,4 +1,6 @@ -namespace Aurora.Profiles.EliteDangerous.GSI.Nodes +using System; + +namespace Aurora.Profiles.EliteDangerous.GSI.Nodes { public class StatusState @@ -6,15 +8,29 @@ public class StatusState long flagsSet = -1; long flagsNotSet = -1; int guiFocus = -1; - - public StatusState(long flagsSet, int guiFocus, long flagsNotSet) + private Func conditionCallback = null; + + public StatusState(long flagsSet, long flagsNotSet) : this(flagsSet, -1, flagsNotSet, null) {} + public StatusState(long flagsSet, int guiFocus, long flagsNotSet, Func conditionCallback) { this.flagsSet = flagsSet; this.guiFocus = guiFocus; this.flagsNotSet = flagsNotSet; + this.conditionCallback = conditionCallback; + } + public StatusState(Func conditionCallback) + { + this.conditionCallback = conditionCallback; } + public bool ConditionSatisfied(Status status) + { + return ConditionSatisfied(status.Flags, status.GuiFocus); + } public bool ConditionSatisfied(long flags, int guiFocus) { + if(conditionCallback != null && !conditionCallback()) { + return false; + } if(this.guiFocus != -1 && this.guiFocus != guiFocus) { return false; } @@ -31,6 +47,7 @@ public bool ConditionSatisfied(long flags, int guiFocus) { public static class Flag { + public static readonly int NONE = -1; public static readonly int DOCKED = 1; public static readonly int LANDED_PLANET = 1 << 1; public static readonly int LANDING_GEAR = 1 << 2; diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs index 7dec88f57..228d7bd0c 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs @@ -69,7 +69,7 @@ public class EliteDangerousKeyBindsHandlerProperties : LayerHandlerProperties2Co public Color? _ModeDisableColor { get; set; } public Color ModeDisableColor { get { return Logic._ModeDisableColor ?? _ModeDisableColor ?? Color.Empty; } } - + public EliteDangerousKeyBindsHandlerProperties() : base() { } public EliteDangerousKeyBindsHandlerProperties(bool assign_default = false) : base(assign_default) { } @@ -97,10 +97,63 @@ public override void Default() this._ModeEnableColor = Color.FromArgb(153, 167, 255); this._ModeDisableColor = Color.FromArgb(61, 88, 156); } + + public Color GetColorByVariableName(string colorVariableName) { + switch (@colorVariableName) + { + case "HudModeCombatColor": return HudModeCombatColor; + case "HudModeDiscoveryColor": return HudModeDiscoveryColor; + case "NoneColor": return NoneColor; + case "OtherColor": return OtherColor; + case "UiColor": return UiColor; + case "UiAltColor": return UiAltColor; + case "ShipStuffColor": return ShipStuffColor; + case "CameraColor": return CameraColor; + case "DefenceColor": return DefenceColor; + case "DefenceDimmedColor": return DefenceDimmedColor; + case "OffenceColor": return OffenceColor; + case "OffenceDimmedColor": return OffenceDimmedColor; + case "MovementSpeedColor": return MovementSpeedColor; + case "MovementSpeedDimmedColor": return MovementSpeedDimmedColor; + case "MovementSecondaryColor": return MovementSecondaryColor; + case "WingColor": return WingColor; + case "NavigationColor": return NavigationColor; + case "ModeEnableColor": return ModeEnableColor; + case "ModeDisableColor": return ModeDisableColor; + } + + return NoneColor; + } } + public class EliteDangerousKeyBindsLayerHandler : LayerHandler { private int blinkSpeed = 20; + public static GameState_EliteDangerous gameState = null; + + private ControlGroup[] commandGroups = { + new ControlGroup("CameraColor", new [] { + Bind.EliteBindName.PhotoCameraToggle, Bind.EliteBindName.PhotoCameraToggle_Buggy, Bind.EliteBindName.VanityCameraScrollLeft, + Bind.EliteBindName.VanityCameraScrollRight, Bind.EliteBindName.ToggleFreeCam, Bind.EliteBindName.FreeCamToggleHUD, + Bind.EliteBindName.FixCameraRelativeToggle, Bind.EliteBindName.FixCameraWorldToggle + }), + new ControlGroup("MovementSpeedColor", new [] { + Bind.EliteBindName.ForwardKey, Bind.EliteBindName.BackwardKey, Bind.EliteBindName.IncreaseEnginesPower, Bind.EliteBindName.SetSpeedZero, + Bind.EliteBindName.SetSpeed25, Bind.EliteBindName.SetSpeed50, Bind.EliteBindName.SetSpeed75, Bind.EliteBindName.SetSpeed100 + }, new StatusState(Flag.NONE, Flag.DOCKED | Flag.LANDED_PLANET)), + new ControlGroup("MovementSpeedColor", new [] { + Bind.EliteBindName.SetSpeedMinus100, Bind.EliteBindName.SetSpeedMinus75, Bind.EliteBindName.SetSpeedMinus50, + Bind.EliteBindName.SetSpeedMinus25, Bind.EliteBindName.AutoBreakBuggyButton + }, new StatusState(Flag.NONE, Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE)), + new ControlGroup("MovementSpeedColor", new [] { + Bind.EliteBindName.OrderHoldPosition + }, new StatusState(() => + { + if(gameState != null) return gameState.Journal.fighterStatus != FighterStatus.None; + return false; + })) + }; + public EliteDangerousKeyBindsLayerHandler() : base() { _ID = "EliteDangerousKeyBinds"; @@ -134,47 +187,24 @@ private Color GetBlinkingColor(Color baseColor) public override EffectLayer Render(IGameState state) { + gameState = state as GameState_EliteDangerous; EffectLayer keyBindsLayer = new EffectLayer("Elite: Dangerous - Key Binds"); - Dictionary groups = new Dictionary() + foreach (ControlGroup group in commandGroups) { - {"camera", new ControlGroup(new string[] - { - Bind.EliteBindName.PhotoCameraToggle, Bind.EliteBindName.PhotoCameraToggle_Buggy, Bind.EliteBindName.VanityCameraScrollLeft, - Bind.EliteBindName.VanityCameraScrollRight, Bind.EliteBindName.ToggleFreeCam, Bind.EliteBindName.FreeCamToggleHUD, - Bind.EliteBindName.FixCameraRelativeToggle, Bind.EliteBindName.FixCameraWorldToggle - })}, - {"movement_speed", new ControlGroup(new string[] - { - Bind.EliteBindName.ForwardKey, Bind.EliteBindName.BackwardKey, Bind.EliteBindName.IncreaseEnginesPower, Bind.EliteBindName.SetSpeedZero, - Bind.EliteBindName.SetSpeed25, Bind.EliteBindName.SetSpeed50, Bind.EliteBindName.SetSpeed75, Bind.EliteBindName.SetSpeed100 - })}, - {"movement_speed2", new ControlGroup(new string[] - { - Bind.EliteBindName.SetSpeedMinus100, Bind.EliteBindName.SetSpeedMinus75, Bind.EliteBindName.SetSpeedMinus50, - Bind.EliteBindName.SetSpeedMinus25, Bind.EliteBindName.AutoBreakBuggyButton - })}, - {"movement_speed3", new ControlGroup(new string[] - { - Bind.EliteBindName.OrderHoldPosition - })}, - }; - - groups["camera"].color = this.Properties.CameraColor; - groups["movement_speed"].color = this.Properties.MovementSpeedColor; - groups["movement_speed2"].color = this.Properties.MovementSpeedColor; - groups["movement_speed3"].color = this.Properties.MovementSpeedColor; + group.color = Properties.GetColorByVariableName(group.colorGroupName); + } GSI.Nodes.Controls controls = (state as GameState_EliteDangerous).Controls; foreach(KeyValuePair entry in controls.commandToBind) { - foreach (KeyValuePair group in groups) + foreach (ControlGroup group in commandGroups) { - if (group.Value.commands.Contains(entry.Key)) + if (group.ConditionSatisfied(gameState.Status) && group.commands.Contains(entry.Key)) { foreach (Bind.Mapping mapping in entry.Value.mappings) { - keyBindsLayer.Set(mapping.key, group.Value.color); + keyBindsLayer.Set(mapping.key, group.color); } } } diff --git a/Project-Aurora/Project-Aurora/Project-Aurora.csproj b/Project-Aurora/Project-Aurora/Project-Aurora.csproj index d71ddd7af..30412bbe9 100755 --- a/Project-Aurora/Project-Aurora/Project-Aurora.csproj +++ b/Project-Aurora/Project-Aurora/Project-Aurora.csproj @@ -459,6 +459,7 @@ + Control_EliteDangerousBackgroundLayer.xaml From 6ccdbbf3fb93f53f15f215f297c66b32388037bc Mon Sep 17 00:00:00 2001 From: Arturs Ziborovs Date: Mon, 26 Aug 2019 23:18:06 +0300 Subject: [PATCH 14/67] Implemented game status parsing - implemented a file reader - implemented more color groups - implemented blinking keys --- .../EliteDangerousApplication.cs | 2 +- .../EliteDangerous/GSI/Nodes/Controls.cs | 543 +++++++++--------- .../EliteDangerous/GSI/Nodes/Status.cs | 112 ++-- .../GameEvent_EliteDangerous.cs | 75 +-- .../EliteDangerous/Helpers/FileWatcher.cs | 101 ++++ .../EliteDangerous/Helpers/TimerHelpers.cs | 37 ++ .../EliteDangerousKeyBindsLayerHandler.cs | 471 +++++++++++---- .../Project-Aurora/Project-Aurora.csproj | 2 + 8 files changed, 902 insertions(+), 441 deletions(-) create mode 100644 Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Helpers/FileWatcher.cs create mode 100644 Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Helpers/TimerHelpers.cs diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/EliteDangerousApplication.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/EliteDangerousApplication.cs index c772ae41f..b0d2258b2 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/EliteDangerousApplication.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/EliteDangerousApplication.cs @@ -11,7 +11,7 @@ public EliteDangerous() { Name = "Elite: Dangerous", ID = "EliteDangerous", - ProcessNames = new[] { "EliteDangerous64.exe" }, + ProcessNames = new[] { "EliteDangerous64.exe", "sublime_text.exe" }, SettingsType = typeof(FirstTimeApplicationSettings), ProfileType = typeof(EliteDangerousProfile), OverviewControlType = typeof(Control_EliteDangerous), diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Controls.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Controls.cs index 9038ddaac..c2760dadc 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Controls.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Controls.cs @@ -6,268 +6,275 @@ namespace Aurora.Profiles.EliteDangerous.GSI.Nodes { + public static class Command + { + public static readonly string MouseReset = "MouseReset"; + public static readonly string YawLeftButton = "YawLeftButton"; + public static readonly string YawRightButton = "YawRightButton"; + public static readonly string YawToRollButton = "YawToRollButton"; + public static readonly string RollLeftButton = "RollLeftButton"; + public static readonly string RollRightButton = "RollRightButton"; + public static readonly string PitchUpButton = "PitchUpButton"; + public static readonly string PitchDownButton = "PitchDownButton"; + public static readonly string LeftThrustButton = "LeftThrustButton"; + public static readonly string RightThrustButton = "RightThrustButton"; + public static readonly string UpThrustButton = "UpThrustButton"; + public static readonly string DownThrustButton = "DownThrustButton"; + public static readonly string ForwardThrustButton = "ForwardThrustButton"; + public static readonly string BackwardThrustButton = "BackwardThrustButton"; + public static readonly string UseAlternateFlightValuesToggle = "UseAlternateFlightValuesToggle"; + public static readonly string ToggleReverseThrottleInput = "ToggleReverseThrottleInput"; + public static readonly string ForwardKey = "ForwardKey"; + public static readonly string BackwardKey = "BackwardKey"; + public static readonly string SetSpeedMinus100 = "SetSpeedMinus100"; + public static readonly string SetSpeedMinus75 = "SetSpeedMinus75"; + public static readonly string SetSpeedMinus50 = "SetSpeedMinus50"; + public static readonly string SetSpeedMinus25 = "SetSpeedMinus25"; + public static readonly string SetSpeedZero = "SetSpeedZero"; + public static readonly string SetSpeed25 = "SetSpeed25"; + public static readonly string SetSpeed50 = "SetSpeed50"; + public static readonly string SetSpeed75 = "SetSpeed75"; + public static readonly string SetSpeed100 = "SetSpeed100"; + public static readonly string YawLeftButton_Landing = "YawLeftButton_Landing"; + public static readonly string YawRightButton_Landing = "YawRightButton_Landing"; + public static readonly string PitchUpButton_Landing = "PitchUpButton_Landing"; + public static readonly string PitchDownButton_Landing = "PitchDownButton_Landing"; + public static readonly string RollLeftButton_Landing = "RollLeftButton_Landing"; + public static readonly string RollRightButton_Landing = "RollRightButton_Landing"; + public static readonly string LeftThrustButton_Landing = "LeftThrustButton_Landing"; + public static readonly string RightThrustButton_Landing = "RightThrustButton_Landing"; + public static readonly string UpThrustButton_Landing = "UpThrustButton_Landing"; + public static readonly string DownThrustButton_Landing = "DownThrustButton_Landing"; + public static readonly string ForwardThrustButton_Landing = "ForwardThrustButton_Landing"; + public static readonly string BackwardThrustButton_Landing = "BackwardThrustButton_Landing"; + public static readonly string ToggleFlightAssist = "ToggleFlightAssist"; + public static readonly string UseBoostJuice = "UseBoostJuice"; + public static readonly string HyperSuperCombination = "HyperSuperCombination"; + public static readonly string Supercruise = "Supercruise"; + public static readonly string Hyperspace = "Hyperspace"; + public static readonly string DisableRotationCorrectToggle = "DisableRotationCorrectToggle"; + public static readonly string OrbitLinesToggle = "OrbitLinesToggle"; + public static readonly string SelectTarget = "SelectTarget"; + public static readonly string CycleNextTarget = "CycleNextTarget"; + public static readonly string CyclePreviousTarget = "CyclePreviousTarget"; + public static readonly string SelectHighestThreat = "SelectHighestThreat"; + public static readonly string CycleNextHostileTarget = "CycleNextHostileTarget"; + public static readonly string CyclePreviousHostileTarget = "CyclePreviousHostileTarget"; + public static readonly string TargetWingman0 = "TargetWingman0"; + public static readonly string TargetWingman1 = "TargetWingman1"; + public static readonly string TargetWingman2 = "TargetWingman2"; + public static readonly string SelectTargetsTarget = "SelectTargetsTarget"; + public static readonly string WingNavLock = "WingNavLock"; + public static readonly string CycleNextSubsystem = "CycleNextSubsystem"; + public static readonly string CyclePreviousSubsystem = "CyclePreviousSubsystem"; + public static readonly string TargetNextRouteSystem = "TargetNextRouteSystem"; + public static readonly string PrimaryFire = "PrimaryFire"; + public static readonly string SecondaryFire = "SecondaryFire"; + public static readonly string CycleFireGroupNext = "CycleFireGroupNext"; + public static readonly string CycleFireGroupPrevious = "CycleFireGroupPrevious"; + public static readonly string DeployHardpointToggle = "DeployHardpointToggle"; + public static readonly string ToggleButtonUpInput = "ToggleButtonUpInput"; + public static readonly string DeployHeatSink = "DeployHeatSink"; + public static readonly string ShipSpotLightToggle = "ShipSpotLightToggle"; + public static readonly string RadarIncreaseRange = "RadarIncreaseRange"; + public static readonly string RadarDecreaseRange = "RadarDecreaseRange"; + public static readonly string IncreaseEnginesPower = "IncreaseEnginesPower"; + public static readonly string IncreaseWeaponsPower = "IncreaseWeaponsPower"; + public static readonly string IncreaseSystemsPower = "IncreaseSystemsPower"; + public static readonly string ResetPowerDistribution = "ResetPowerDistribution"; + public static readonly string HMDReset = "HMDReset"; + public static readonly string ToggleCargoScoop = "ToggleCargoScoop"; + public static readonly string EjectAllCargo = "EjectAllCargo"; + public static readonly string LandingGearToggle = "LandingGearToggle"; + public static readonly string MicrophoneMute = "MicrophoneMute"; + public static readonly string UseShieldCell = "UseShieldCell"; + public static readonly string FireChaffLauncher = "FireChaffLauncher"; + public static readonly string ChargeECM = "ChargeECM"; + public static readonly string WeaponColourToggle = "WeaponColourToggle"; + public static readonly string EngineColourToggle = "EngineColourToggle"; + public static readonly string NightVisionToggle = "NightVisionToggle"; + public static readonly string UIFocus = "UIFocus"; + public static readonly string FocusLeftPanel = "FocusLeftPanel"; + public static readonly string FocusCommsPanel = "FocusCommsPanel"; + public static readonly string QuickCommsPanel = "QuickCommsPanel"; + public static readonly string FocusRadarPanel = "FocusRadarPanel"; + public static readonly string FocusRightPanel = "FocusRightPanel"; + public static readonly string GalaxyMapOpen = "GalaxyMapOpen"; + public static readonly string SystemMapOpen = "SystemMapOpen"; + public static readonly string ShowPGScoreSummaryInput = "ShowPGScoreSummaryInput"; + public static readonly string HeadLookToggle = "HeadLookToggle"; + public static readonly string Pause = "Pause"; + public static readonly string FriendsMenu = "FriendsMenu"; + public static readonly string OpenCodexGoToDiscovery = "OpenCodexGoToDiscovery"; + public static readonly string PlayerHUDModeToggle = "PlayerHUDModeToggle"; + public static readonly string UI_Up = "UI_Up"; + public static readonly string UI_Down = "UI_Down"; + public static readonly string UI_Left = "UI_Left"; + public static readonly string UI_Right = "UI_Right"; + public static readonly string UI_Select = "UI_Select"; + public static readonly string UI_Back = "UI_Back"; + public static readonly string UI_Toggle = "UI_Toggle"; + public static readonly string CycleNextPanel = "CycleNextPanel"; + public static readonly string CyclePreviousPanel = "CyclePreviousPanel"; + public static readonly string CycleNextPage = "CycleNextPage"; + public static readonly string CyclePreviousPage = "CyclePreviousPage"; + public static readonly string HeadLookReset = "HeadLookReset"; + public static readonly string HeadLookPitchUp = "HeadLookPitchUp"; + public static readonly string HeadLookPitchDown = "HeadLookPitchDown"; + public static readonly string HeadLookYawLeft = "HeadLookYawLeft"; + public static readonly string HeadLookYawRight = "HeadLookYawRight"; + public static readonly string CamPitchUp = "CamPitchUp"; + public static readonly string CamPitchDown = "CamPitchDown"; + public static readonly string CamYawLeft = "CamYawLeft"; + public static readonly string CamYawRight = "CamYawRight"; + public static readonly string CamTranslateForward = "CamTranslateForward"; + public static readonly string CamTranslateBackward = "CamTranslateBackward"; + public static readonly string CamTranslateLeft = "CamTranslateLeft"; + public static readonly string CamTranslateRight = "CamTranslateRight"; + public static readonly string CamTranslateUp = "CamTranslateUp"; + public static readonly string CamTranslateDown = "CamTranslateDown"; + public static readonly string CamZoomIn = "CamZoomIn"; + public static readonly string CamZoomOut = "CamZoomOut"; + public static readonly string CamTranslateZHold = "CamTranslateZHold"; + public static readonly string ToggleDriveAssist = "ToggleDriveAssist"; + public static readonly string SteerLeftButton = "SteerLeftButton"; + public static readonly string SteerRightButton = "SteerRightButton"; + public static readonly string BuggyRollLeftButton = "BuggyRollLeftButton"; + public static readonly string BuggyRollRightButton = "BuggyRollRightButton"; + public static readonly string BuggyPitchUpButton = "BuggyPitchUpButton"; + public static readonly string BuggyPitchDownButton = "BuggyPitchDownButton"; + public static readonly string VerticalThrustersButton = "VerticalThrustersButton"; + public static readonly string BuggyPrimaryFireButton = "BuggyPrimaryFireButton"; + public static readonly string BuggySecondaryFireButton = "BuggySecondaryFireButton"; + public static readonly string AutoBreakBuggyButton = "AutoBreakBuggyButton"; + public static readonly string HeadlightsBuggyButton = "HeadlightsBuggyButton"; + public static readonly string ToggleBuggyTurretButton = "ToggleBuggyTurretButton"; + public static readonly string SelectTarget_Buggy = "SelectTarget_Buggy"; + public static readonly string BuggyTurretYawLeftButton = "BuggyTurretYawLeftButton"; + public static readonly string BuggyTurretYawRightButton = "BuggyTurretYawRightButton"; + public static readonly string BuggyTurretPitchUpButton = "BuggyTurretPitchUpButton"; + public static readonly string BuggyTurretPitchDownButton = "BuggyTurretPitchDownButton"; + public static readonly string BuggyToggleReverseThrottleInput = "BuggyToggleReverseThrottleInput"; + public static readonly string IncreaseSpeedButtonMax = "IncreaseSpeedButtonMax"; + public static readonly string DecreaseSpeedButtonMax = "DecreaseSpeedButtonMax"; + public static readonly string IncreaseEnginesPower_Buggy = "IncreaseEnginesPower_Buggy"; + public static readonly string IncreaseWeaponsPower_Buggy = "IncreaseWeaponsPower_Buggy"; + public static readonly string IncreaseSystemsPower_Buggy = "IncreaseSystemsPower_Buggy"; + public static readonly string ResetPowerDistribution_Buggy = "ResetPowerDistribution_Buggy"; + public static readonly string ToggleCargoScoop_Buggy = "ToggleCargoScoop_Buggy"; + public static readonly string EjectAllCargo_Buggy = "EjectAllCargo_Buggy"; + public static readonly string RecallDismissShip = "RecallDismissShip"; + public static readonly string UIFocus_Buggy = "UIFocus_Buggy"; + public static readonly string FocusLeftPanel_Buggy = "FocusLeftPanel_Buggy"; + public static readonly string FocusCommsPanel_Buggy = "FocusCommsPanel_Buggy"; + public static readonly string QuickCommsPanel_Buggy = "QuickCommsPanel_Buggy"; + public static readonly string FocusRadarPanel_Buggy = "FocusRadarPanel_Buggy"; + public static readonly string FocusRightPanel_Buggy = "FocusRightPanel_Buggy"; + public static readonly string GalaxyMapOpen_Buggy = "GalaxyMapOpen_Buggy"; + public static readonly string SystemMapOpen_Buggy = "SystemMapOpen_Buggy"; + public static readonly string HeadLookToggle_Buggy = "HeadLookToggle_Buggy"; + public static readonly string MultiCrewToggleMode = "MultiCrewToggleMode"; + public static readonly string MultiCrewPrimaryFire = "MultiCrewPrimaryFire"; + public static readonly string MultiCrewSecondaryFire = "MultiCrewSecondaryFire"; + public static readonly string MultiCrewPrimaryUtilityFire = "MultiCrewPrimaryUtilityFire"; + public static readonly string MultiCrewSecondaryUtilityFire = "MultiCrewSecondaryUtilityFire"; + public static readonly string MultiCrewThirdPersonYawLeftButton = "MultiCrewThirdPersonYawLeftButton"; + public static readonly string MultiCrewThirdPersonYawRightButton = "MultiCrewThirdPersonYawRightButton"; + public static readonly string MultiCrewThirdPersonPitchUpButton = "MultiCrewThirdPersonPitchUpButton"; + public static readonly string MultiCrewThirdPersonPitchDownButton = "MultiCrewThirdPersonPitchDownButton"; + public static readonly string MultiCrewThirdPersonFovOutButton = "MultiCrewThirdPersonFovOutButton"; + public static readonly string MultiCrewThirdPersonFovInButton = "MultiCrewThirdPersonFovInButton"; + public static readonly string MultiCrewCockpitUICycleForward = "MultiCrewCockpitUICycleForward"; + public static readonly string MultiCrewCockpitUICycleBackward = "MultiCrewCockpitUICycleBackward"; + public static readonly string OrderRequestDock = "OrderRequestDock"; + public static readonly string OrderDefensiveBehaviour = "OrderDefensiveBehaviour"; + public static readonly string OrderAggressiveBehaviour = "OrderAggressiveBehaviour"; + public static readonly string OrderFocusTarget = "OrderFocusTarget"; + public static readonly string OrderHoldFire = "OrderHoldFire"; + public static readonly string OrderHoldPosition = "OrderHoldPosition"; + public static readonly string OrderFollow = "OrderFollow"; + public static readonly string OpenOrders = "OpenOrders"; + public static readonly string PhotoCameraToggle = "PhotoCameraToggle"; + public static readonly string PhotoCameraToggle_Buggy = "PhotoCameraToggle_Buggy"; + public static readonly string VanityCameraScrollLeft = "VanityCameraScrollLeft"; + public static readonly string VanityCameraScrollRight = "VanityCameraScrollRight"; + public static readonly string ToggleFreeCam = "ToggleFreeCam"; + public static readonly string VanityCameraOne = "VanityCameraOne"; + public static readonly string VanityCameraTwo = "VanityCameraTwo"; + public static readonly string VanityCameraThree = "VanityCameraThree"; + public static readonly string VanityCameraFour = "VanityCameraFour"; + public static readonly string VanityCameraFive = "VanityCameraFive"; + public static readonly string VanityCameraSix = "VanityCameraSix"; + public static readonly string VanityCameraSeven = "VanityCameraSeven"; + public static readonly string VanityCameraEight = "VanityCameraEight"; + public static readonly string VanityCameraNine = "VanityCameraNine"; + public static readonly string FreeCamToggleHUD = "FreeCamToggleHUD"; + public static readonly string FreeCamSpeedInc = "FreeCamSpeedInc"; + public static readonly string FreeCamSpeedDec = "FreeCamSpeedDec"; + public static readonly string ToggleReverseThrottleInputFreeCam = "ToggleReverseThrottleInputFreeCam"; + public static readonly string MoveFreeCamForward = "MoveFreeCamForward"; + public static readonly string MoveFreeCamBackwards = "MoveFreeCamBackwards"; + public static readonly string MoveFreeCamRight = "MoveFreeCamRight"; + public static readonly string MoveFreeCamLeft = "MoveFreeCamLeft"; + public static readonly string MoveFreeCamUp = "MoveFreeCamUp"; + public static readonly string MoveFreeCamDown = "MoveFreeCamDown"; + public static readonly string PitchCameraUp = "PitchCameraUp"; + public static readonly string PitchCameraDown = "PitchCameraDown"; + public static readonly string YawCameraLeft = "YawCameraLeft"; + public static readonly string YawCameraRight = "YawCameraRight"; + public static readonly string RollCameraLeft = "RollCameraLeft"; + public static readonly string RollCameraRight = "RollCameraRight"; + public static readonly string ToggleRotationLock = "ToggleRotationLock"; + public static readonly string FixCameraRelativeToggle = "FixCameraRelativeToggle"; + public static readonly string FixCameraWorldToggle = "FixCameraWorldToggle"; + public static readonly string QuitCamera = "QuitCamera"; + public static readonly string ToggleAdvanceMode = "ToggleAdvanceMode"; + public static readonly string FreeCamZoomIn = "FreeCamZoomIn"; + public static readonly string FreeCamZoomOut = "FreeCamZoomOut"; + public static readonly string FStopDec = "FStopDec"; + public static readonly string FStopInc = "FStopInc"; + public static readonly string CommanderCreator_Undo = "CommanderCreator_Undo"; + public static readonly string CommanderCreator_Redo = "CommanderCreator_Redo"; + public static readonly string CommanderCreator_Rotation_MouseToggle = "CommanderCreator_Rotation_MouseToggle"; + public static readonly string GalnetAudio_Play_Pause = "GalnetAudio_Play_Pause"; + public static readonly string GalnetAudio_SkipForward = "GalnetAudio_SkipForward"; + public static readonly string GalnetAudio_SkipBackward = "GalnetAudio_SkipBackward"; + public static readonly string GalnetAudio_ClearQueue = "GalnetAudio_ClearQueue"; + public static readonly string ExplorationFSSEnter = "ExplorationFSSEnter"; + + public static readonly string ExplorationFSSCameraPitchIncreaseButton = + "ExplorationFSSCameraPitchIncreaseButton"; + + public static readonly string ExplorationFSSCameraPitchDecreaseButton = + "ExplorationFSSCameraPitchDecreaseButton"; + + public static readonly string ExplorationFSSCameraYawIncreaseButton = "ExplorationFSSCameraYawIncreaseButton"; + public static readonly string ExplorationFSSCameraYawDecreaseButton = "ExplorationFSSCameraYawDecreaseButton"; + public static readonly string ExplorationFSSZoomIn = "ExplorationFSSZoomIn"; + public static readonly string ExplorationFSSZoomOut = "ExplorationFSSZoomOut"; + public static readonly string ExplorationFSSMiniZoomIn = "ExplorationFSSMiniZoomIn"; + public static readonly string ExplorationFSSMiniZoomOut = "ExplorationFSSMiniZoomOut"; + public static readonly string ExplorationFSSRadioTuningX_Increase = "ExplorationFSSRadioTuningX_Increase"; + public static readonly string ExplorationFSSRadioTuningX_Decrease = "ExplorationFSSRadioTuningX_Decrease"; + public static readonly string ExplorationFSSDiscoveryScan = "ExplorationFSSDiscoveryScan"; + public static readonly string ExplorationFSSQuit = "ExplorationFSSQuit"; + public static readonly string ExplorationFSSTarget = "ExplorationFSSTarget"; + public static readonly string ExplorationFSSShowHelp = "ExplorationFSSShowHelp"; + + public static readonly string ExplorationSAAChangeScannedAreaViewToggle = + "ExplorationSAAChangeScannedAreaViewToggle"; + + public static readonly string ExplorationSAAExitThirdPerson = "ExplorationSAAExitThirdPerson"; + public static readonly string SAAThirdPersonYawLeftButton = "SAAThirdPersonYawLeftButton"; + public static readonly string SAAThirdPersonYawRightButton = "SAAThirdPersonYawRightButton"; + public static readonly string SAAThirdPersonPitchUpButton = "SAAThirdPersonPitchUpButton"; + public static readonly string SAAThirdPersonPitchDownButton = "SAAThirdPersonPitchDownButton"; + public static readonly string SAAThirdPersonFovOutButton = "SAAThirdPersonFovOutButton"; + public static readonly string SAAThirdPersonFovInButton = "SAAThirdPersonFovInButton"; + } public class Bind { - public static class EliteBindName - { - public static readonly string MouseReset = "MouseReset"; - public static readonly string YawLeftButton = "YawLeftButton"; - public static readonly string YawRightButton = "YawRightButton"; - public static readonly string YawToRollButton = "YawToRollButton"; - public static readonly string RollLeftButton = "RollLeftButton"; - public static readonly string RollRightButton = "RollRightButton"; - public static readonly string PitchUpButton = "PitchUpButton"; - public static readonly string PitchDownButton = "PitchDownButton"; - public static readonly string LeftThrustButton = "LeftThrustButton"; - public static readonly string RightThrustButton = "RightThrustButton"; - public static readonly string UpThrustButton = "UpThrustButton"; - public static readonly string DownThrustButton = "DownThrustButton"; - public static readonly string ForwardThrustButton = "ForwardThrustButton"; - public static readonly string BackwardThrustButton = "BackwardThrustButton"; - public static readonly string UseAlternateFlightValuesToggle = "UseAlternateFlightValuesToggle"; - public static readonly string ToggleReverseThrottleInput = "ToggleReverseThrottleInput"; - public static readonly string ForwardKey = "ForwardKey"; - public static readonly string BackwardKey = "BackwardKey"; - public static readonly string SetSpeedMinus100 = "SetSpeedMinus100"; - public static readonly string SetSpeedMinus75 = "SetSpeedMinus75"; - public static readonly string SetSpeedMinus50 = "SetSpeedMinus50"; - public static readonly string SetSpeedMinus25 = "SetSpeedMinus25"; - public static readonly string SetSpeedZero = "SetSpeedZero"; - public static readonly string SetSpeed25 = "SetSpeed25"; - public static readonly string SetSpeed50 = "SetSpeed50"; - public static readonly string SetSpeed75 = "SetSpeed75"; - public static readonly string SetSpeed100 = "SetSpeed100"; - public static readonly string YawLeftButton_Landing = "YawLeftButton_Landing"; - public static readonly string YawRightButton_Landing = "YawRightButton_Landing"; - public static readonly string PitchUpButton_Landing = "PitchUpButton_Landing"; - public static readonly string PitchDownButton_Landing = "PitchDownButton_Landing"; - public static readonly string RollLeftButton_Landing = "RollLeftButton_Landing"; - public static readonly string RollRightButton_Landing = "RollRightButton_Landing"; - public static readonly string LeftThrustButton_Landing = "LeftThrustButton_Landing"; - public static readonly string RightThrustButton_Landing = "RightThrustButton_Landing"; - public static readonly string UpThrustButton_Landing = "UpThrustButton_Landing"; - public static readonly string DownThrustButton_Landing = "DownThrustButton_Landing"; - public static readonly string ForwardThrustButton_Landing = "ForwardThrustButton_Landing"; - public static readonly string BackwardThrustButton_Landing = "BackwardThrustButton_Landing"; - public static readonly string ToggleFlightAssist = "ToggleFlightAssist"; - public static readonly string UseBoostJuice = "UseBoostJuice"; - public static readonly string HyperSuperCombination = "HyperSuperCombination"; - public static readonly string Supercruise = "Supercruise"; - public static readonly string Hyperspace = "Hyperspace"; - public static readonly string DisableRotationCorrectToggle = "DisableRotationCorrectToggle"; - public static readonly string OrbitLinesToggle = "OrbitLinesToggle"; - public static readonly string SelectTarget = "SelectTarget"; - public static readonly string CycleNextTarget = "CycleNextTarget"; - public static readonly string CyclePreviousTarget = "CyclePreviousTarget"; - public static readonly string SelectHighestThreat = "SelectHighestThreat"; - public static readonly string CycleNextHostileTarget = "CycleNextHostileTarget"; - public static readonly string CyclePreviousHostileTarget = "CyclePreviousHostileTarget"; - public static readonly string TargetWingman0 = "TargetWingman0"; - public static readonly string TargetWingman1 = "TargetWingman1"; - public static readonly string TargetWingman2 = "TargetWingman2"; - public static readonly string SelectTargetsTarget = "SelectTargetsTarget"; - public static readonly string WingNavLock = "WingNavLock"; - public static readonly string CycleNextSubsystem = "CycleNextSubsystem"; - public static readonly string CyclePreviousSubsystem = "CyclePreviousSubsystem"; - public static readonly string TargetNextRouteSystem = "TargetNextRouteSystem"; - public static readonly string PrimaryFire = "PrimaryFire"; - public static readonly string SecondaryFire = "SecondaryFire"; - public static readonly string CycleFireGroupNext = "CycleFireGroupNext"; - public static readonly string CycleFireGroupPrevious = "CycleFireGroupPrevious"; - public static readonly string DeployHardpointToggle = "DeployHardpointToggle"; - public static readonly string ToggleButtonUpInput = "ToggleButtonUpInput"; - public static readonly string DeployHeatSink = "DeployHeatSink"; - public static readonly string ShipSpotLightToggle = "ShipSpotLightToggle"; - public static readonly string RadarIncreaseRange = "RadarIncreaseRange"; - public static readonly string RadarDecreaseRange = "RadarDecreaseRange"; - public static readonly string IncreaseEnginesPower = "IncreaseEnginesPower"; - public static readonly string IncreaseWeaponsPower = "IncreaseWeaponsPower"; - public static readonly string IncreaseSystemsPower = "IncreaseSystemsPower"; - public static readonly string ResetPowerDistribution = "ResetPowerDistribution"; - public static readonly string HMDReset = "HMDReset"; - public static readonly string ToggleCargoScoop = "ToggleCargoScoop"; - public static readonly string EjectAllCargo = "EjectAllCargo"; - public static readonly string LandingGearToggle = "LandingGearToggle"; - public static readonly string MicrophoneMute = "MicrophoneMute"; - public static readonly string UseShieldCell = "UseShieldCell"; - public static readonly string FireChaffLauncher = "FireChaffLauncher"; - public static readonly string ChargeECM = "ChargeECM"; - public static readonly string WeaponColourToggle = "WeaponColourToggle"; - public static readonly string EngineColourToggle = "EngineColourToggle"; - public static readonly string NightVisionToggle = "NightVisionToggle"; - public static readonly string UIFocus = "UIFocus"; - public static readonly string FocusLeftPanel = "FocusLeftPanel"; - public static readonly string FocusCommsPanel = "FocusCommsPanel"; - public static readonly string QuickCommsPanel = "QuickCommsPanel"; - public static readonly string FocusRadarPanel = "FocusRadarPanel"; - public static readonly string FocusRightPanel = "FocusRightPanel"; - public static readonly string GalaxyMapOpen = "GalaxyMapOpen"; - public static readonly string SystemMapOpen = "SystemMapOpen"; - public static readonly string ShowPGScoreSummaryInput = "ShowPGScoreSummaryInput"; - public static readonly string HeadLookToggle = "HeadLookToggle"; - public static readonly string Pause = "Pause"; - public static readonly string FriendsMenu = "FriendsMenu"; - public static readonly string OpenCodexGoToDiscovery = "OpenCodexGoToDiscovery"; - public static readonly string PlayerHUDModeToggle = "PlayerHUDModeToggle"; - public static readonly string UI_Up = "UI_Up"; - public static readonly string UI_Down = "UI_Down"; - public static readonly string UI_Left = "UI_Left"; - public static readonly string UI_Right = "UI_Right"; - public static readonly string UI_Select = "UI_Select"; - public static readonly string UI_Back = "UI_Back"; - public static readonly string UI_Toggle = "UI_Toggle"; - public static readonly string CycleNextPanel = "CycleNextPanel"; - public static readonly string CyclePreviousPanel = "CyclePreviousPanel"; - public static readonly string CycleNextPage = "CycleNextPage"; - public static readonly string CyclePreviousPage = "CyclePreviousPage"; - public static readonly string HeadLookReset = "HeadLookReset"; - public static readonly string HeadLookPitchUp = "HeadLookPitchUp"; - public static readonly string HeadLookPitchDown = "HeadLookPitchDown"; - public static readonly string HeadLookYawLeft = "HeadLookYawLeft"; - public static readonly string HeadLookYawRight = "HeadLookYawRight"; - public static readonly string CamPitchUp = "CamPitchUp"; - public static readonly string CamPitchDown = "CamPitchDown"; - public static readonly string CamYawLeft = "CamYawLeft"; - public static readonly string CamYawRight = "CamYawRight"; - public static readonly string CamTranslateForward = "CamTranslateForward"; - public static readonly string CamTranslateBackward = "CamTranslateBackward"; - public static readonly string CamTranslateLeft = "CamTranslateLeft"; - public static readonly string CamTranslateRight = "CamTranslateRight"; - public static readonly string CamTranslateUp = "CamTranslateUp"; - public static readonly string CamTranslateDown = "CamTranslateDown"; - public static readonly string CamZoomIn = "CamZoomIn"; - public static readonly string CamZoomOut = "CamZoomOut"; - public static readonly string CamTranslateZHold = "CamTranslateZHold"; - public static readonly string ToggleDriveAssist = "ToggleDriveAssist"; - public static readonly string SteerLeftButton = "SteerLeftButton"; - public static readonly string SteerRightButton = "SteerRightButton"; - public static readonly string BuggyRollLeftButton = "BuggyRollLeftButton"; - public static readonly string BuggyRollRightButton = "BuggyRollRightButton"; - public static readonly string BuggyPitchUpButton = "BuggyPitchUpButton"; - public static readonly string BuggyPitchDownButton = "BuggyPitchDownButton"; - public static readonly string VerticalThrustersButton = "VerticalThrustersButton"; - public static readonly string BuggyPrimaryFireButton = "BuggyPrimaryFireButton"; - public static readonly string BuggySecondaryFireButton = "BuggySecondaryFireButton"; - public static readonly string AutoBreakBuggyButton = "AutoBreakBuggyButton"; - public static readonly string HeadlightsBuggyButton = "HeadlightsBuggyButton"; - public static readonly string ToggleBuggyTurretButton = "ToggleBuggyTurretButton"; - public static readonly string SelectTarget_Buggy = "SelectTarget_Buggy"; - public static readonly string BuggyTurretYawLeftButton = "BuggyTurretYawLeftButton"; - public static readonly string BuggyTurretYawRightButton = "BuggyTurretYawRightButton"; - public static readonly string BuggyTurretPitchUpButton = "BuggyTurretPitchUpButton"; - public static readonly string BuggyTurretPitchDownButton = "BuggyTurretPitchDownButton"; - public static readonly string BuggyToggleReverseThrottleInput = "BuggyToggleReverseThrottleInput"; - public static readonly string IncreaseSpeedButtonMax = "IncreaseSpeedButtonMax"; - public static readonly string DecreaseSpeedButtonMax = "DecreaseSpeedButtonMax"; - public static readonly string IncreaseEnginesPower_Buggy = "IncreaseEnginesPower_Buggy"; - public static readonly string IncreaseWeaponsPower_Buggy = "IncreaseWeaponsPower_Buggy"; - public static readonly string IncreaseSystemsPower_Buggy = "IncreaseSystemsPower_Buggy"; - public static readonly string ResetPowerDistribution_Buggy = "ResetPowerDistribution_Buggy"; - public static readonly string ToggleCargoScoop_Buggy = "ToggleCargoScoop_Buggy"; - public static readonly string EjectAllCargo_Buggy = "EjectAllCargo_Buggy"; - public static readonly string RecallDismissShip = "RecallDismissShip"; - public static readonly string UIFocus_Buggy = "UIFocus_Buggy"; - public static readonly string FocusLeftPanel_Buggy = "FocusLeftPanel_Buggy"; - public static readonly string FocusCommsPanel_Buggy = "FocusCommsPanel_Buggy"; - public static readonly string QuickCommsPanel_Buggy = "QuickCommsPanel_Buggy"; - public static readonly string FocusRadarPanel_Buggy = "FocusRadarPanel_Buggy"; - public static readonly string FocusRightPanel_Buggy = "FocusRightPanel_Buggy"; - public static readonly string GalaxyMapOpen_Buggy = "GalaxyMapOpen_Buggy"; - public static readonly string SystemMapOpen_Buggy = "SystemMapOpen_Buggy"; - public static readonly string HeadLookToggle_Buggy = "HeadLookToggle_Buggy"; - public static readonly string MultiCrewToggleMode = "MultiCrewToggleMode"; - public static readonly string MultiCrewPrimaryFire = "MultiCrewPrimaryFire"; - public static readonly string MultiCrewSecondaryFire = "MultiCrewSecondaryFire"; - public static readonly string MultiCrewPrimaryUtilityFire = "MultiCrewPrimaryUtilityFire"; - public static readonly string MultiCrewSecondaryUtilityFire = "MultiCrewSecondaryUtilityFire"; - public static readonly string MultiCrewThirdPersonYawLeftButton = "MultiCrewThirdPersonYawLeftButton"; - public static readonly string MultiCrewThirdPersonYawRightButton = "MultiCrewThirdPersonYawRightButton"; - public static readonly string MultiCrewThirdPersonPitchUpButton = "MultiCrewThirdPersonPitchUpButton"; - public static readonly string MultiCrewThirdPersonPitchDownButton = "MultiCrewThirdPersonPitchDownButton"; - public static readonly string MultiCrewThirdPersonFovOutButton = "MultiCrewThirdPersonFovOutButton"; - public static readonly string MultiCrewThirdPersonFovInButton = "MultiCrewThirdPersonFovInButton"; - public static readonly string MultiCrewCockpitUICycleForward = "MultiCrewCockpitUICycleForward"; - public static readonly string MultiCrewCockpitUICycleBackward = "MultiCrewCockpitUICycleBackward"; - public static readonly string OrderRequestDock = "OrderRequestDock"; - public static readonly string OrderDefensiveBehaviour = "OrderDefensiveBehaviour"; - public static readonly string OrderAggressiveBehaviour = "OrderAggressiveBehaviour"; - public static readonly string OrderFocusTarget = "OrderFocusTarget"; - public static readonly string OrderHoldFire = "OrderHoldFire"; - public static readonly string OrderHoldPosition = "OrderHoldPosition"; - public static readonly string OrderFollow = "OrderFollow"; - public static readonly string OpenOrders = "OpenOrders"; - public static readonly string PhotoCameraToggle = "PhotoCameraToggle"; - public static readonly string PhotoCameraToggle_Buggy = "PhotoCameraToggle_Buggy"; - public static readonly string VanityCameraScrollLeft = "VanityCameraScrollLeft"; - public static readonly string VanityCameraScrollRight = "VanityCameraScrollRight"; - public static readonly string ToggleFreeCam = "ToggleFreeCam"; - public static readonly string VanityCameraOne = "VanityCameraOne"; - public static readonly string VanityCameraTwo = "VanityCameraTwo"; - public static readonly string VanityCameraThree = "VanityCameraThree"; - public static readonly string VanityCameraFour = "VanityCameraFour"; - public static readonly string VanityCameraFive = "VanityCameraFive"; - public static readonly string VanityCameraSix = "VanityCameraSix"; - public static readonly string VanityCameraSeven = "VanityCameraSeven"; - public static readonly string VanityCameraEight = "VanityCameraEight"; - public static readonly string VanityCameraNine = "VanityCameraNine"; - public static readonly string FreeCamToggleHUD = "FreeCamToggleHUD"; - public static readonly string FreeCamSpeedInc = "FreeCamSpeedInc"; - public static readonly string FreeCamSpeedDec = "FreeCamSpeedDec"; - public static readonly string ToggleReverseThrottleInputFreeCam = "ToggleReverseThrottleInputFreeCam"; - public static readonly string MoveFreeCamForward = "MoveFreeCamForward"; - public static readonly string MoveFreeCamBackwards = "MoveFreeCamBackwards"; - public static readonly string MoveFreeCamRight = "MoveFreeCamRight"; - public static readonly string MoveFreeCamLeft = "MoveFreeCamLeft"; - public static readonly string MoveFreeCamUp = "MoveFreeCamUp"; - public static readonly string MoveFreeCamDown = "MoveFreeCamDown"; - public static readonly string PitchCameraUp = "PitchCameraUp"; - public static readonly string PitchCameraDown = "PitchCameraDown"; - public static readonly string YawCameraLeft = "YawCameraLeft"; - public static readonly string YawCameraRight = "YawCameraRight"; - public static readonly string RollCameraLeft = "RollCameraLeft"; - public static readonly string RollCameraRight = "RollCameraRight"; - public static readonly string ToggleRotationLock = "ToggleRotationLock"; - public static readonly string FixCameraRelativeToggle = "FixCameraRelativeToggle"; - public static readonly string FixCameraWorldToggle = "FixCameraWorldToggle"; - public static readonly string QuitCamera = "QuitCamera"; - public static readonly string ToggleAdvanceMode = "ToggleAdvanceMode"; - public static readonly string FreeCamZoomIn = "FreeCamZoomIn"; - public static readonly string FreeCamZoomOut = "FreeCamZoomOut"; - public static readonly string FStopDec = "FStopDec"; - public static readonly string FStopInc = "FStopInc"; - public static readonly string CommanderCreator_Undo = "CommanderCreator_Undo"; - public static readonly string CommanderCreator_Redo = "CommanderCreator_Redo"; - public static readonly string CommanderCreator_Rotation_MouseToggle = "CommanderCreator_Rotation_MouseToggle"; - public static readonly string GalnetAudio_Play_Pause = "GalnetAudio_Play_Pause"; - public static readonly string GalnetAudio_SkipForward = "GalnetAudio_SkipForward"; - public static readonly string GalnetAudio_SkipBackward = "GalnetAudio_SkipBackward"; - public static readonly string GalnetAudio_ClearQueue = "GalnetAudio_ClearQueue"; - public static readonly string ExplorationFSSEnter = "ExplorationFSSEnter"; - public static readonly string ExplorationFSSCameraPitchIncreaseButton = "ExplorationFSSCameraPitchIncreaseButton"; - public static readonly string ExplorationFSSCameraPitchDecreaseButton = "ExplorationFSSCameraPitchDecreaseButton"; - public static readonly string ExplorationFSSCameraYawIncreaseButton = "ExplorationFSSCameraYawIncreaseButton"; - public static readonly string ExplorationFSSCameraYawDecreaseButton = "ExplorationFSSCameraYawDecreaseButton"; - public static readonly string ExplorationFSSZoomIn = "ExplorationFSSZoomIn"; - public static readonly string ExplorationFSSZoomOut = "ExplorationFSSZoomOut"; - public static readonly string ExplorationFSSMiniZoomIn = "ExplorationFSSMiniZoomIn"; - public static readonly string ExplorationFSSMiniZoomOut = "ExplorationFSSMiniZoomOut"; - public static readonly string ExplorationFSSRadioTuningX_Increase = "ExplorationFSSRadioTuningX_Increase"; - public static readonly string ExplorationFSSRadioTuningX_Decrease = "ExplorationFSSRadioTuningX_Decrease"; - public static readonly string ExplorationFSSDiscoveryScan = "ExplorationFSSDiscoveryScan"; - public static readonly string ExplorationFSSQuit = "ExplorationFSSQuit"; - public static readonly string ExplorationFSSTarget = "ExplorationFSSTarget"; - public static readonly string ExplorationFSSShowHelp = "ExplorationFSSShowHelp"; - public static readonly string ExplorationSAAChangeScannedAreaViewToggle = "ExplorationSAAChangeScannedAreaViewToggle"; - public static readonly string ExplorationSAAExitThirdPerson = "ExplorationSAAExitThirdPerson"; - public static readonly string SAAThirdPersonYawLeftButton = "SAAThirdPersonYawLeftButton"; - public static readonly string SAAThirdPersonYawRightButton = "SAAThirdPersonYawRightButton"; - public static readonly string SAAThirdPersonPitchUpButton = "SAAThirdPersonPitchUpButton"; - public static readonly string SAAThirdPersonPitchDownButton = "SAAThirdPersonPitchDownButton"; - public static readonly string SAAThirdPersonFovOutButton = "SAAThirdPersonFovOutButton"; - public static readonly string SAAThirdPersonFovInButton = "SAAThirdPersonFovInButton"; - } - public static Dictionary eliteKeyToDeviceKey = new Dictionary() { {"Key_Escape", DeviceKeys.ESC}, @@ -380,7 +387,7 @@ public class Mapping { public DeviceKeys key = DeviceKeys.NONE; public List modifiers = new List(); - + public void SetKey(string eliteKey) { if (Bind.eliteKeyToDeviceKey.ContainsKey(eliteKey)) @@ -388,6 +395,7 @@ public void SetKey(string eliteKey) key = Bind.eliteKeyToDeviceKey[eliteKey]; } } + public void AddModifier(string eliteKey) { if (Bind.eliteKeyToDeviceKey.ContainsKey(eliteKey)) @@ -395,16 +403,16 @@ public void AddModifier(string eliteKey) modifiers.Add(Bind.eliteKeyToDeviceKey[eliteKey]); } } - + public bool HasKey() { return key != null; } } - + private string command; public HashSet mappings = new HashSet(); - + public Bind(string command) { this.command = command; @@ -423,8 +431,10 @@ public class ControlGroup public List commands; public StatusState neededStatusState; - public ControlGroup(string colorGroupName, string[] commands) : this(colorGroupName, commands, null) { } - + public ControlGroup(string colorGroupName, string[] commands) : this(colorGroupName, commands, null) + { + } + public ControlGroup(string colorGroupName, string[] commands, StatusState neededStatusState) { this.colorGroupName = colorGroupName; @@ -436,6 +446,7 @@ public bool ConditionSatisfied(Status status) { return ConditionSatisfied(status.Flags, status.GuiFocus); } + public bool ConditionSatisfied(long flags, int guiFocus) { if (neededStatusState != null) @@ -446,7 +457,7 @@ public bool ConditionSatisfied(long flags, int guiFocus) return true; } } - + /// /// Class representing current controls configuration /// diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Status.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Status.cs index 48c154df5..74b12d625 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Status.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Status.cs @@ -2,15 +2,22 @@ namespace Aurora.Profiles.EliteDangerous.GSI.Nodes { - public class StatusState { long flagsSet = -1; long flagsNotSet = -1; int guiFocus = -1; private Func conditionCallback = null; - - public StatusState(long flagsSet, long flagsNotSet) : this(flagsSet, -1, flagsNotSet, null) {} + + public StatusState(long flagsSet, long flagsNotSet = -1) : this(flagsSet, -1, flagsNotSet, null) + { + } + + public StatusState(long flagsSet, long flagsNotSet, Func conditionCallback) : this(flagsSet, -1, + flagsNotSet, conditionCallback) + { + } + public StatusState(long flagsSet, int guiFocus, long flagsNotSet, Func conditionCallback) { this.flagsSet = flagsSet; @@ -18,26 +25,36 @@ public StatusState(long flagsSet, int guiFocus, long flagsNotSet, Func con this.flagsNotSet = flagsNotSet; this.conditionCallback = conditionCallback; } + public StatusState(Func conditionCallback) { this.conditionCallback = conditionCallback; } - + public bool ConditionSatisfied(Status status) { return ConditionSatisfied(status.Flags, status.GuiFocus); } - public bool ConditionSatisfied(long flags, int guiFocus) { - if(conditionCallback != null && !conditionCallback()) { + + public bool ConditionSatisfied(long flags, int guiFocus) + { + if (conditionCallback != null && !conditionCallback()) + { return false; } - if(this.guiFocus != -1 && this.guiFocus != guiFocus) { + + if (this.guiFocus != -1 && this.guiFocus != guiFocus) + { return false; } - if(this.flagsSet != -1 && !Flag.IsFlagSet(flags, this.flagsSet)) { + + if (this.flagsSet != -1 && !Flag.IsFlagSet(flags, this.flagsSet)) + { return false; } - if(this.flagsNotSet != -1 && Flag.IsFlagSet(flags, this.flagsNotSet)) { + + if (this.flagsNotSet != -1 && Flag.IsFlagSet(flags, this.flagsNotSet)) + { return false; } @@ -47,54 +64,61 @@ public bool ConditionSatisfied(long flags, int guiFocus) { public static class Flag { - public static readonly int NONE = -1; - public static readonly int DOCKED = 1; - public static readonly int LANDED_PLANET = 1 << 1; - public static readonly int LANDING_GEAR = 1 << 2; - public static readonly int SHIELDS_UP = 1 << 3; - public static readonly int SUPERCRUISE = 1 << 4; - public static readonly int FA_OFF = 1 << 5; - public static readonly int HARDPOINTS = 1 << 6; - public static readonly int IN_WING = 1 << 7; - public static readonly int SHIP_LIGHTS = 1 << 8; - public static readonly int CARGO_SCOOP = 1 << 9; - public static readonly int SILENT_RUNNING = 1 << 10; - public static readonly int SCOOPING = 1 << 11; - public static readonly int SRV_HANDBRAKE = 1 << 12; - public static readonly int SRV_TURRET = 1 << 13; - public static readonly int SRV_UNDER_SHIP = 1 << 14; - public static readonly int SRV_DRIVE_ASSIST = 1 << 15; - public static readonly int MASS_LOCK = 1 << 16; - public static readonly int FSD_CHARGING = 1 << 17; - public static readonly int FSD_COOLDOWN = 1 << 18; - public static readonly int LOW_FUEL = 1 << 19; // Less than 25% - public static readonly int OVERHEATING = 1 << 20; // More than 100% - public static readonly int HAS_LAT_LONG = 1 << 21; - public static readonly int IN_DANGER = 1 << 22; - public static readonly int INTERDICTION = 1 << 23; - public static readonly int IN_SHIP = 1 << 24; - public static readonly int IN_FIGHTER = 1 << 25; - public static readonly int IN_SRV = 1 << 26; - public static readonly int HUD_DISCOVERY_MODE = 1 << 27; - public static readonly int NIGHT_VISION = 1 << 28; - - public static bool IsFlagSet(long bitmask, long flag) { + public static readonly int NONE = -1; + public static readonly int DOCKED = 1; + public static readonly int LANDED_PLANET = 1 << 1; + public static readonly int LANDING_GEAR = 1 << 2; + public static readonly int SHIELDS_UP = 1 << 3; + public static readonly int SUPERCRUISE = 1 << 4; + public static readonly int FA_OFF = 1 << 5; + public static readonly int HARDPOINTS = 1 << 6; + public static readonly int IN_WING = 1 << 7; + public static readonly int SHIP_LIGHTS = 1 << 8; + public static readonly int CARGO_SCOOP = 1 << 9; + public static readonly int SILENT_RUNNING = 1 << 10; + public static readonly int SCOOPING = 1 << 11; + public static readonly int SRV_HANDBRAKE = 1 << 12; + public static readonly int SRV_TURRET = 1 << 13; + public static readonly int SRV_UNDER_SHIP = 1 << 14; + public static readonly int SRV_DRIVE_ASSIST = 1 << 15; + public static readonly int MASS_LOCK = 1 << 16; + public static readonly int FSD_CHARGING = 1 << 17; + public static readonly int FSD_COOLDOWN = 1 << 18; + public static readonly int LOW_FUEL = 1 << 19; // Less than 25% + public static readonly int OVERHEATING = 1 << 20; // More than 100% + public static readonly int HAS_LAT_LONG = 1 << 21; + public static readonly int IN_DANGER = 1 << 22; + public static readonly int INTERDICTION = 1 << 23; + public static readonly int IN_SHIP = 1 << 24; + public static readonly int IN_FIGHTER = 1 << 25; + public static readonly int IN_SRV = 1 << 26; + public static readonly int HUD_DISCOVERY_MODE = 1 << 27; + public static readonly int NIGHT_VISION = 1 << 28; + + public static bool IsFlagSet(long bitmask, long flag) + { return (bitmask & flag) == flag; } } - + /// /// Class representing player status /// public class Status : Node { - public string timestamp; + public DateTime timestamp; public string @event; public long Flags; public int[] Pips; public int FireGroup; public int GuiFocus; - public double Fuel; + public FuelClass Fuel; public double Cargo; + + public class FuelClass + { + public double FuelMain; + public double FuelReservoir; + } } } \ No newline at end of file diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs index 6cce39675..b25d7def9 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GameEvent_EliteDangerous.cs @@ -6,6 +6,8 @@ using System.Xml; using Aurora.Profiles.EliteDangerous.GSI; using Aurora.Profiles.EliteDangerous.GSI.Nodes; +using Aurora.Profiles.EliteDangerous.Helpers; +using Newtonsoft.Json; namespace Aurora.Profiles.EliteDangerous { @@ -20,6 +22,7 @@ public class GameEvent_EliteDangerous : GameEvent_Generic "Elite Dangerous" ); private static readonly string statusFile = Path.Combine(journalFolder, "Status.json"); + private FileWatcher statusFileWatcher; private static readonly string bindingsFolder = Path.Combine( Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData), @@ -32,8 +35,11 @@ public class GameEvent_EliteDangerous : GameEvent_Generic private string currentBindFile = null; private FileSystemWatcher bindWatcher = null; - - public GameEvent_EliteDangerous() : base() {} + + public GameEvent_EliteDangerous() : base() + { + statusFileWatcher = new FileWatcher(statusFile, FileWatcher.ReadMode.FULL, new StatusReadCallback(this)); + } public void WatchBindFiles() { @@ -59,38 +65,6 @@ public void StopWatchingBindFiles() } } - public class DelayedMethodCaller - { - int _delay; - Timer _timer = new Timer(); - - public DelayedMethodCaller(int delay) - { - _delay = delay; - } - - public void CallMethod(Action action) - { - if (!_timer.Enabled) - { - _timer = new Timer(_delay) - { - AutoReset = false - }; - _timer.Elapsed += (object sender, ElapsedEventArgs e) => - { - action(); - }; - _timer.Start(); - } - else - { - _timer.Stop(); - _timer.Start(); - } - } - } - private void OnBindsFileChanged(object sender, FileSystemEventArgs e) { /* @@ -181,16 +155,49 @@ private void ParseBindFile() controls.bindToCommand = bindToCommand; } + public void UpdateStatus(Status newStatus) + { + Status status = (_game_state as GameState_EliteDangerous).Status; + + status.timestamp = newStatus.timestamp; + status.@event = newStatus.@event; + status.Flags = newStatus.Flags; + status.Pips = newStatus.Pips; + status.FireGroup = newStatus.FireGroup; + status.GuiFocus = newStatus.GuiFocus; + status.Fuel = newStatus.Fuel; + status.Cargo = newStatus.Cargo; + } + + private class StatusReadCallback : FileWatcher.FileReadCallback + { + private GameEvent_EliteDangerous @event; + public StatusReadCallback(GameEvent_EliteDangerous @event) + { + this.@event = @event; + } + public void OnRead(int lineNumber, string lineValue) + { + if (string.IsNullOrEmpty(lineValue)) return; + + Status newStatus = JsonConvert.DeserializeObject(lineValue); + + @event.UpdateStatus(newStatus); + } + } + public override void OnStart() { ReadBindFiles(); WatchBindFiles(); + statusFileWatcher.Start(); //TODO: Enable Journal API reading } public override void OnStop() { StopWatchingBindFiles(); + statusFileWatcher.Stop(); //TODO: Disable Journal API reading } } diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Helpers/FileWatcher.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Helpers/FileWatcher.cs new file mode 100644 index 000000000..35d5f45ff --- /dev/null +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Helpers/FileWatcher.cs @@ -0,0 +1,101 @@ +using System; +using System.IO; +using System.Text; +using System.Threading; +using IronPython.Modules; + +namespace Aurora.Profiles.EliteDangerous.Helpers +{ + public class FileWatcher + { + public enum ReadMode { + TAIL, TAIL_END, FULL + }; + + public interface FileReadCallback { + void OnRead(int lineNumber, string lineValue); + } + + private readonly int READ_DELAY = 3; + private Thread watcherThread; + private string filename; + private ReadMode readMode; + private FileReadCallback readCallback; + private long lastFileWrite = 0; + + public FileWatcher(string filename, ReadMode readMode, FileReadCallback readCallback) + { + this.filename = filename; + this.readMode = readMode; + this.readCallback = readCallback; + } + + private void ReadFile() + { + FileStream stream = new FileStream(filename, FileMode.Open, FileAccess.Read, FileShare.ReadWrite); + StreamReader reader = new StreamReader(stream, Encoding.UTF8); + try + { + if (readMode == ReadMode.TAIL_END) + { + reader.ReadToEnd(); + } + while (true) + { + if(readMode == ReadMode.FULL) { + long writeTime = File.GetLastWriteTime(filename).Ticks; + if (lastFileWrite != writeTime) + { + stream.Position = 0; + reader.DiscardBufferedData(); + lastFileWrite = writeTime; + + readCallback.OnRead(0, reader.ReadToEnd()); + } + } + else + { + string line; + while ((line = reader.ReadLine()) != null) + { + readCallback.OnRead(0, line); + } + } + + Thread.Sleep(READ_DELAY); + } + } + finally + { + reader.Close(); + } + } + + public bool Start() + { + if (watcherThread == null) + { + watcherThread = new Thread(ReadFile); + watcherThread.Start(); + return true; + } + + return false; + } + + public bool Stop() + { + if (watcherThread != null) + { + watcherThread.Abort(); + watcherThread.Join(); + watcherThread = null; + + return true; + } + + return false; + } + } + +} \ No newline at end of file diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Helpers/TimerHelpers.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Helpers/TimerHelpers.cs new file mode 100644 index 000000000..a18acb4eb --- /dev/null +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Helpers/TimerHelpers.cs @@ -0,0 +1,37 @@ +using System; +using System.Timers; + +namespace Aurora.Profiles.EliteDangerous.Helpers +{ + public class DelayedMethodCaller + { + int _delay; + Timer _timer = new Timer(); + + public DelayedMethodCaller(int delay) + { + _delay = delay; + } + + public void CallMethod(Action action) + { + if (!_timer.Enabled) + { + _timer = new Timer(_delay) + { + AutoReset = false + }; + _timer.Elapsed += (object sender, ElapsedEventArgs e) => + { + action(); + }; + _timer.Start(); + } + else + { + _timer.Stop(); + _timer.Start(); + } + } + } +} \ No newline at end of file diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs index 228d7bd0c..83f277e3d 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs @@ -11,68 +11,149 @@ namespace Aurora.Profiles.EliteDangerous.Layers { - public class EliteDangerousKeyBindsHandlerProperties : LayerHandlerProperties2Color + public class + EliteDangerousKeyBindsHandlerProperties : LayerHandlerProperties2Color { public Color? _HudModeCombatColor { get; set; } - public Color HudModeCombatColor { get { return Logic._HudModeCombatColor ?? _HudModeCombatColor ?? Color.Empty; } } - + + public Color HudModeCombatColor + { + get { return Logic._HudModeCombatColor ?? _HudModeCombatColor ?? Color.Empty; } + } + public Color? _HudModeDiscoveryColor { get; set; } - public Color HudModeDiscoveryColor { get { return Logic._HudModeDiscoveryColor ?? _HudModeDiscoveryColor ?? Color.Empty; } } - + + public Color HudModeDiscoveryColor + { + get { return Logic._HudModeDiscoveryColor ?? _HudModeDiscoveryColor ?? Color.Empty; } + } + public Color? _NoneColor { get; set; } - public Color NoneColor { get { return Logic._NoneColor ?? _NoneColor ?? Color.Empty; } } - + + public Color NoneColor + { + get { return Logic._NoneColor ?? _NoneColor ?? Color.Empty; } + } + public Color? _OtherColor { get; set; } - public Color OtherColor { get { return Logic._OtherColor ?? _OtherColor ?? Color.Empty; } } - + + public Color OtherColor + { + get { return Logic._OtherColor ?? _OtherColor ?? Color.Empty; } + } + public Color? _UiColor { get; set; } - public Color UiColor { get { return Logic._UiColor ?? _UiColor ?? Color.Empty; } } - + + public Color UiColor + { + get { return Logic._UiColor ?? _UiColor ?? Color.Empty; } + } + public Color? _UiAltColor { get; set; } - public Color UiAltColor { get { return Logic._UiAltColor ?? _UiAltColor ?? Color.Empty; } } - + + public Color UiAltColor + { + get { return Logic._UiAltColor ?? _UiAltColor ?? Color.Empty; } + } + public Color? _ShipStuffColor { get; set; } - public Color ShipStuffColor { get { return Logic._ShipStuffColor ?? _ShipStuffColor ?? Color.Empty; } } - + + public Color ShipStuffColor + { + get { return Logic._ShipStuffColor ?? _ShipStuffColor ?? Color.Empty; } + } + public Color? _CameraColor { get; set; } - public Color CameraColor { get { return Logic._CameraColor ?? _CameraColor ?? Color.Empty; } } - + + public Color CameraColor + { + get { return Logic._CameraColor ?? _CameraColor ?? Color.Empty; } + } + public Color? _DefenceColor { get; set; } - public Color DefenceColor { get { return Logic._DefenceColor ?? _DefenceColor ?? Color.Empty; } } - + + public Color DefenceColor + { + get { return Logic._DefenceColor ?? _DefenceColor ?? Color.Empty; } + } + public Color? _DefenceDimmedColor { get; set; } - public Color DefenceDimmedColor { get { return Logic._DefenceDimmedColor ?? _DefenceDimmedColor ?? Color.Empty; } } - + + public Color DefenceDimmedColor + { + get { return Logic._DefenceDimmedColor ?? _DefenceDimmedColor ?? Color.Empty; } + } + public Color? _OffenceColor { get; set; } - public Color OffenceColor { get { return Logic._OffenceColor ?? _OffenceColor ?? Color.Empty; } } - + + public Color OffenceColor + { + get { return Logic._OffenceColor ?? _OffenceColor ?? Color.Empty; } + } + public Color? _OffenceDimmedColor { get; set; } - public Color OffenceDimmedColor { get { return Logic._OffenceDimmedColor ?? _OffenceDimmedColor ?? Color.Empty; } } - + + public Color OffenceDimmedColor + { + get { return Logic._OffenceDimmedColor ?? _OffenceDimmedColor ?? Color.Empty; } + } + public Color? _MovementSpeedColor { get; set; } - public Color MovementSpeedColor { get { return Logic._MovementSpeedColor ?? _MovementSpeedColor ?? Color.Empty; } } - + + public Color MovementSpeedColor + { + get { return Logic._MovementSpeedColor ?? _MovementSpeedColor ?? Color.Empty; } + } + public Color? _MovementSpeedDimmedColor { get; set; } - public Color MovementSpeedDimmedColor { get { return Logic._MovementSpeedDimmedColor ?? _MovementSpeedDimmedColor ?? Color.Empty; } } - + + public Color MovementSpeedDimmedColor + { + get { return Logic._MovementSpeedDimmedColor ?? _MovementSpeedDimmedColor ?? Color.Empty; } + } + public Color? _MovementSecondaryColor { get; set; } - public Color MovementSecondaryColor { get { return Logic._MovementSecondaryColor ?? _MovementSecondaryColor ?? Color.Empty; } } - + + public Color MovementSecondaryColor + { + get { return Logic._MovementSecondaryColor ?? _MovementSecondaryColor ?? Color.Empty; } + } + public Color? _WingColor { get; set; } - public Color WingColor { get { return Logic._WingColor ?? _WingColor ?? Color.Empty; } } - + + public Color WingColor + { + get { return Logic._WingColor ?? _WingColor ?? Color.Empty; } + } + public Color? _NavigationColor { get; set; } - public Color NavigationColor { get { return Logic._NavigationColor ?? _NavigationColor ?? Color.Empty; } } - + + public Color NavigationColor + { + get { return Logic._NavigationColor ?? _NavigationColor ?? Color.Empty; } + } + public Color? _ModeEnableColor { get; set; } - public Color ModeEnableColor { get { return Logic._ModeEnableColor ?? _ModeEnableColor ?? Color.Empty; } } - + + public Color ModeEnableColor + { + get { return Logic._ModeEnableColor ?? _ModeEnableColor ?? Color.Empty; } + } + public Color? _ModeDisableColor { get; set; } - public Color ModeDisableColor { get { return Logic._ModeDisableColor ?? _ModeDisableColor ?? Color.Empty; } } - - public EliteDangerousKeyBindsHandlerProperties() : base() { } - public EliteDangerousKeyBindsHandlerProperties(bool assign_default = false) : base(assign_default) { } + public Color ModeDisableColor + { + get { return Logic._ModeDisableColor ?? _ModeDisableColor ?? Color.Empty; } + } + + public EliteDangerousKeyBindsHandlerProperties() : base() + { + } + + public EliteDangerousKeyBindsHandlerProperties(bool assign_default = false) : base(assign_default) + { + } public override void Default() { @@ -97,29 +178,30 @@ public override void Default() this._ModeEnableColor = Color.FromArgb(153, 167, 255); this._ModeDisableColor = Color.FromArgb(61, 88, 156); } - - public Color GetColorByVariableName(string colorVariableName) { + + public Color GetColorByVariableName(string colorVariableName) + { switch (@colorVariableName) { - case "HudModeCombatColor": return HudModeCombatColor; - case "HudModeDiscoveryColor": return HudModeDiscoveryColor; - case "NoneColor": return NoneColor; - case "OtherColor": return OtherColor; - case "UiColor": return UiColor; - case "UiAltColor": return UiAltColor; - case "ShipStuffColor": return ShipStuffColor; - case "CameraColor": return CameraColor; - case "DefenceColor": return DefenceColor; - case "DefenceDimmedColor": return DefenceDimmedColor; - case "OffenceColor": return OffenceColor; - case "OffenceDimmedColor": return OffenceDimmedColor; - case "MovementSpeedColor": return MovementSpeedColor; - case "MovementSpeedDimmedColor": return MovementSpeedDimmedColor; - case "MovementSecondaryColor": return MovementSecondaryColor; - case "WingColor": return WingColor; - case "NavigationColor": return NavigationColor; - case "ModeEnableColor": return ModeEnableColor; - case "ModeDisableColor": return ModeDisableColor; + case "HudModeCombatColor": return HudModeCombatColor; + case "HudModeDiscoveryColor": return HudModeDiscoveryColor; + case "NoneColor": return NoneColor; + case "OtherColor": return OtherColor; + case "UiColor": return UiColor; + case "UiAltColor": return UiAltColor; + case "ShipStuffColor": return ShipStuffColor; + case "CameraColor": return CameraColor; + case "DefenceColor": return DefenceColor; + case "DefenceDimmedColor": return DefenceDimmedColor; + case "OffenceColor": return OffenceColor; + case "OffenceDimmedColor": return OffenceDimmedColor; + case "MovementSpeedColor": return MovementSpeedColor; + case "MovementSpeedDimmedColor": return MovementSpeedDimmedColor; + case "MovementSecondaryColor": return MovementSecondaryColor; + case "WingColor": return WingColor; + case "NavigationColor": return NavigationColor; + case "ModeEnableColor": return ModeEnableColor; + case "ModeDisableColor": return ModeDisableColor; } return NoneColor; @@ -131,29 +213,227 @@ public class EliteDangerousKeyBindsLayerHandler : LayerHandler gameState.Journal.fighterStatus != FighterStatus.None)), + + new ControlGroup("MovementSpeedColor", new[] + { + Command.UseBoostJuice + }, new StatusState(Flag.NONE, + Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE | Flag.LANDING_GEAR | Flag.CARGO_SCOOP + )), + new ControlGroup("MovementSecondaryColor", new[] + { + Command.RollLeftButton, Command.RollRightButton, Command.PitchUpButton, Command.PitchDownButton + }, new StatusState(Flag.NONE, + Flag.DOCKED | Flag.LANDED_PLANET + )), + new ControlGroup("MovementSecondaryColor", new[] + { + Command.LeftThrustButton, Command.RightThrustButton, Command.UpThrustButton, Command.DownThrustButton, + Command.ForwardThrustButton, Command.BackwardThrustButton + }, new StatusState(Flag.NONE, + Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE + )), + new ControlGroup("MovementSecondaryColor", new[] + { + Command.OrderFollow + }, new StatusState(() => gameState.Journal.fighterStatus != FighterStatus.None)), + new ControlGroup("UiColor", new[] + { + Command.FocusLeftPanel, Command.FocusCommsPanel, Command.QuickCommsPanel, + Command.FocusRadarPanel, Command.FocusRightPanel, Command.UI_Select, Command.PlayerHUDModeToggle + }), + new ControlGroup("UiColor", new[] + { + Command.UI_Left, Command.UI_Right, Command.UI_Up, Command.UI_Down + }, new StatusState( + Flag.DOCKED + )), + new ControlGroup("UiColor", new[] + { + Command.UI_Left, Command.UI_Right, Command.UI_Up, Command.UI_Down + }, new StatusState( + Flag.LANDED_PLANET + )), + new ControlGroup("UiColor", new[] + { + Command.OrderAggressiveBehaviour + }, new StatusState(() => gameState.Journal.fighterStatus != FighterStatus.None)), + + new ControlGroup("NavigationColor", new[] + { + Command.GalaxyMapOpen, Command.SystemMapOpen, Command.TargetNextRouteSystem + }), + new ControlGroup("NavigationColor", new[] + { + Command.HyperSuperCombination, Command.Supercruise, Command.Hyperspace + }, new StatusState(Flag.NONE, + Flag.DOCKED | Flag.LANDED_PLANET | Flag.MASS_LOCK | Flag.LANDING_GEAR | Flag.HARDPOINTS | + Flag.CARGO_SCOOP + )), + new ControlGroup("NavigationColor", new[] + { + Command.OrderRequestDock + }, new StatusState(() => gameState.Journal.fighterStatus != FighterStatus.None)), + new ControlGroup("ShipStuffColor", new[] + { + Command.ShipSpotLightToggle, Command.HeadlightsBuggyButton, Command.NightVisionToggle + }), + new ControlGroup("ShipStuffColor", new[] + { + Command.ToggleFlightAssist + }, new StatusState(Flag.NONE, + Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE + )), + + new ControlGroup("ShipStuffColor", new[] + { + Command.ToggleCargoScoop, Command.LandingGearToggle + }, new StatusState(Flag.NONE, Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE | Flag.IN_FIGHTER)), + + new ControlGroup("ShipStuffColor", new[] + { + Command.ToggleCargoScoop_Buggy + }, new StatusState(Flag.IN_SRV, Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE | Flag.IN_FIGHTER)), + + new ControlGroup("DefenceColor", new[] + { + Command.IncreaseSystemsPower, Command.ChargeECM + }, new StatusState(Flag.NONE, + Flag.DOCKED | Flag.LANDED_PLANET + )), + new ControlGroup("DefenceColor", new[] + { + Command.FireChaffLauncher + }, + new StatusState(Flag.NONE, Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE, + () => gameState.Journal.hasChaff)), + new ControlGroup("DefenceColor", new[] + { + Command.DeployHeatSink + }, new StatusState(Flag.NONE, Flag.DOCKED | Flag.LANDED_PLANET, () => gameState.Journal.hasHeatSink)), + new ControlGroup("DefenceColor", new[] + { + Command.UseShieldCell + }, new StatusState(Flag.NONE, Flag.DOCKED | Flag.LANDED_PLANET, () => gameState.Journal.hasShieldCellBank)), + new ControlGroup("DefenceColor", new[] + { + Command.OrderDefensiveBehaviour + }, new StatusState(() => gameState.Journal.fighterStatus != FighterStatus.None)), + + new ControlGroup("OffenceColor", new[] + { + Command.CycleFireGroupPrevious }), - new ControlGroup("MovementSpeedColor", new [] { - Bind.EliteBindName.ForwardKey, Bind.EliteBindName.BackwardKey, Bind.EliteBindName.IncreaseEnginesPower, Bind.EliteBindName.SetSpeedZero, - Bind.EliteBindName.SetSpeed25, Bind.EliteBindName.SetSpeed50, Bind.EliteBindName.SetSpeed75, Bind.EliteBindName.SetSpeed100 - }, new StatusState(Flag.NONE, Flag.DOCKED | Flag.LANDED_PLANET)), - new ControlGroup("MovementSpeedColor", new [] { - Bind.EliteBindName.SetSpeedMinus100, Bind.EliteBindName.SetSpeedMinus75, Bind.EliteBindName.SetSpeedMinus50, - Bind.EliteBindName.SetSpeedMinus25, Bind.EliteBindName.AutoBreakBuggyButton - }, new StatusState(Flag.NONE, Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE)), - new ControlGroup("MovementSpeedColor", new [] { - Bind.EliteBindName.OrderHoldPosition - }, new StatusState(() => - { - if(gameState != null) return gameState.Journal.fighterStatus != FighterStatus.None; - return false; - })) + new ControlGroup("OffenceColor", new[] + { + Command.IncreaseWeaponsPower, Command.CycleFireGroupNext, Command.SelectHighestThreat, + Command.CycleNextSubsystem, Command.CyclePreviousSubsystem, Command.CycleNextHostileTarget, + Command.CyclePreviousHostileTarget + }, new StatusState(Flag.NONE, + Flag.DOCKED | Flag.LANDED_PLANET + )), + new ControlGroup("OffenceColor", new[] + { + Command.DeployHardpointToggle + }, new StatusState(Flag.NONE, + Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE + )), + new ControlGroup("OffenceColor", new[] + { + Command.OrderFocusTarget + }, new StatusState(() => gameState.Journal.fighterStatus != FighterStatus.None)), + + new ControlGroup("WingColor", new[] + { + Command.TargetWingman0, Command.TargetWingman1, + Command.TargetWingman2, Command.SelectTargetsTarget, Command.WingNavLock + }, new StatusState(Flag.IN_WING + )), + new ControlGroup("WingColor", new[] + { + Command.OrderHoldFire + }, new StatusState(() => gameState.Journal.fighterStatus != FighterStatus.None)), + + new ControlGroup("ModeEnableColor", new[] + { + Command.ExplorationFSSEnter + }, new StatusState(Flag.SUPERCRUISE | Flag.HUD_DISCOVERY_MODE, Flag.DOCKED | Flag.LANDED_PLANET)) }; - + + private Dictionary blinkingKeys = new Dictionary() + { + { + Command.LandingGearToggle, new StatusState( + Flag.LANDING_GEAR, + Flag.DOCKED | Flag.LANDED_PLANET + ) + }, + { + Command.DeployHardpointToggle, new StatusState( + Flag.HARDPOINTS, + Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE | Flag.IN_FIGHTER | Flag.IN_SRV + ) + }, + { + Command.ToggleCargoScoop, new StatusState( + Flag.CARGO_SCOOP, + Flag.DOCKED | Flag.LANDED_PLANET + ) + }, + { + Command.ToggleCargoScoop_Buggy, new StatusState( + Flag.CARGO_SCOOP, + Flag.DOCKED | Flag.LANDED_PLANET + ) + }, + { + Command.ShipSpotLightToggle, new StatusState( + Flag.SHIP_LIGHTS + ) + }, + { + Command.HeadlightsBuggyButton, new StatusState( + Flag.SHIP_LIGHTS + ) + }, + { + Command.NightVisionToggle, new StatusState( + Flag.NIGHT_VISION + ) + }, + { + Command.AutoBreakBuggyButton, new StatusState( + Flag.IN_SRV | Flag.SRV_HANDBRAKE + ) + } + }; + public EliteDangerousKeyBindsLayerHandler() : base() { _ID = "EliteDangerousKeyBinds"; @@ -166,7 +446,8 @@ protected override UserControl CreateControl() private float GetBlinkStep() { - float animationPosition = Utils.Time.GetMillisecondsSinceEpoch() % (10000L / blinkSpeed) / (10000.0f / blinkSpeed); + float animationPosition = + Utils.Time.GetMillisecondsSinceEpoch() % (10000L / blinkSpeed) / (10000.0f / blinkSpeed); float animationStep = animationPosition * 2; return animationStep > 1 ? 1F + (1F - animationStep) : animationStep; } @@ -174,12 +455,12 @@ private float GetBlinkStep() private Color GetBlinkingColor(Color baseColor) { return Utils.ColorUtils.BlendColors( - this.Properties.ShipStuffColor, + baseColor, Color.FromArgb( 0, - this.Properties.ShipStuffColor.R, - this.Properties.ShipStuffColor.G, - this.Properties.ShipStuffColor.B + baseColor.R, + baseColor.G, + baseColor.B ), GetBlinkStep() ); @@ -196,25 +477,23 @@ public override EffectLayer Render(IGameState state) } GSI.Nodes.Controls controls = (state as GameState_EliteDangerous).Controls; - foreach(KeyValuePair entry in controls.commandToBind) + foreach (KeyValuePair entry in controls.commandToBind) { foreach (ControlGroup group in commandGroups) { if (group.ConditionSatisfied(gameState.Status) && group.commands.Contains(entry.Key)) { + bool blinkingKey = blinkingKeys.ContainsKey(entry.Key) && + blinkingKeys[entry.Key].ConditionSatisfied(gameState.Status); + foreach (Bind.Mapping mapping in entry.Value.mappings) { - keyBindsLayer.Set(mapping.key, group.color); + keyBindsLayer.Set(mapping.key, blinkingKey ? GetBlinkingColor(group.color) : group.color); } } } } -// keyBindsLayer.Set(DeviceKeys.C, this.Properties.ShipStuffColor); -// keyBindsLayer.Set(DeviceKeys.V, this.Properties.DefenceColor); -// keyBindsLayer.Set(DeviceKeys.B, this.Properties.DefenceDimmedColor); -// keyBindsLayer.Set(DeviceKeys.A, GetBlinkingColor(Properties.ShipStuffColor)); - return keyBindsLayer; } @@ -224,4 +503,4 @@ public override void SetApplication(Application profile) base.SetApplication(profile); } } -} +} \ No newline at end of file diff --git a/Project-Aurora/Project-Aurora/Project-Aurora.csproj b/Project-Aurora/Project-Aurora/Project-Aurora.csproj index 30412bbe9..7cbe9c185 100755 --- a/Project-Aurora/Project-Aurora/Project-Aurora.csproj +++ b/Project-Aurora/Project-Aurora/Project-Aurora.csproj @@ -461,6 +461,8 @@ + + Control_EliteDangerousBackgroundLayer.xaml From c7d8c014c61f98932c76739ec42813ab5fc35565 Mon Sep 17 00:00:00 2001 From: Arturs Ziborovs Date: Tue, 27 Aug 2019 00:23:48 +0300 Subject: [PATCH 15/67] Better storage and handling of control groups - added control groups for the galaxy and system maps --- .../EliteDangerous/GSI/Nodes/Controls.cs | 53 +++++++----- .../EliteDangerous/GSI/Nodes/Status.cs | 50 +++++++++++- .../EliteDangerousKeyBindsLayerHandler.cs | 80 +++++++++++++++---- 3 files changed, 146 insertions(+), 37 deletions(-) diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Controls.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Controls.cs index c2760dadc..210fa8750 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Controls.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Controls.cs @@ -3,6 +3,7 @@ using System.Linq; using Aurora.Devices; using CSScriptLibrary; +using Microsoft.Scripting.Utils; namespace Aurora.Profiles.EliteDangerous.GSI.Nodes { @@ -424,37 +425,51 @@ public void AddMapping(Mapping mapping) } } - public class ControlGroup + public class ControlGroupSet : NeedsStatusState { - public string colorGroupName; - public Color color; - public List commands; - public StatusState neededStatusState; + public ControlGroup[] controlGroups; - public ControlGroup(string colorGroupName, string[] commands) : this(colorGroupName, commands, null) + public ControlGroupSet(ControlGroupSet copyFromSet, ControlGroup[] controlGroups, + StatusState neededStatusState = null) { + List controlGroupList = new List(); + controlGroupList.AddRange(copyFromSet.controlGroups); + controlGroupList.AddRange(controlGroups); + + this.controlGroups = controlGroupList.ToArray(); + + if (neededStatusState != null) + { + this.neededStatusState = neededStatusState; + } + else if (copyFromSet.neededStatusState != null) + { + this.neededStatusState = copyFromSet.neededStatusState; + } } - public ControlGroup(string colorGroupName, string[] commands, StatusState neededStatusState) + public ControlGroupSet(ControlGroup[] controlGroups, StatusState neededStatusState = null) : base( + neededStatusState) { - this.colorGroupName = colorGroupName; - this.commands = commands.ToList(); - this.neededStatusState = neededStatusState; + this.controlGroups = controlGroups; } + } - public bool ConditionSatisfied(Status status) + public class ControlGroup : NeedsStatusState + { + public string colorGroupName; + public Color color; + public List commands; + + public ControlGroup(string colorGroupName, string[] commands) : this(colorGroupName, commands, null) { - return ConditionSatisfied(status.Flags, status.GuiFocus); } - public bool ConditionSatisfied(long flags, int guiFocus) + public ControlGroup(string colorGroupName, string[] commands, StatusState neededStatusState) : base( + neededStatusState) { - if (neededStatusState != null) - { - return neededStatusState.ConditionSatisfied(flags, guiFocus); - } - - return true; + this.colorGroupName = colorGroupName; + this.commands = commands.ToList(); } } diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Status.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Status.cs index 74b12d625..4b67f07be 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Status.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Status.cs @@ -2,6 +2,36 @@ namespace Aurora.Profiles.EliteDangerous.GSI.Nodes { + + public class NeedsStatusState + { + public StatusState neededStatusState; + + public NeedsStatusState() + { + } + + public NeedsStatusState(StatusState neededStatusState) + { + this.neededStatusState = neededStatusState; + } + + public bool ConditionSatisfied(Status status) + { + return ConditionSatisfied(status.Flags, status.GuiFocus); + } + + public bool ConditionSatisfied(long flags, int guiFocus) + { + if (neededStatusState != null) + { + return neededStatusState.ConditionSatisfied(flags, guiFocus); + } + + return true; + } + } + public class StatusState { long flagsSet = -1; @@ -17,8 +47,11 @@ public StatusState(long flagsSet, long flagsNotSet, Func conditionCallback flagsNotSet, conditionCallback) { } + public StatusState(int guiFocus) : this(Flag.NONE, guiFocus, Flag.NONE) + { + } - public StatusState(long flagsSet, int guiFocus, long flagsNotSet, Func conditionCallback) + public StatusState(long flagsSet, int guiFocus, long flagsNotSet, Func conditionCallback = null) { this.flagsSet = flagsSet; this.guiFocus = guiFocus; @@ -101,6 +134,21 @@ public static bool IsFlagSet(long bitmask, long flag) } } + public static class GuiFocus { + public static readonly int NONE = 0; + public static readonly int PANEL_SYSTEMS = 1; + public static readonly int PANEL_NAV = 2; + public static readonly int PANEL_COMS = 3; + public static readonly int PANEL_ROLE = 4; + public static readonly int STATION_SERVICES = 5; + + public static readonly int MAP_GALAXY = 6; + public static readonly int MAP_SYSTEM = 7; + public static readonly int MAP_ORRERY = 8; + public static readonly int MODE_FSS = 9; + public static readonly int MODE_ADS = 10; + } + /// /// Class representing player status /// diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs index 83f277e3d..23e4b16f3 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs @@ -1,5 +1,6 @@ using System; using System.Collections.Generic; +using System.Diagnostics; using Aurora.EffectsEngine; using Aurora.Settings.Layers; using System.Drawing; @@ -213,7 +214,7 @@ public class EliteDangerousKeyBindsLayerHandler : LayerHandler gameState.Journal.hasHeatSink)), new ControlGroup("DefenceColor", new[] - { - Command.UseShieldCell - }, new StatusState(Flag.NONE, Flag.DOCKED | Flag.LANDED_PLANET, () => gameState.Journal.hasShieldCellBank)), + { + Command.UseShieldCell + }, + new StatusState(Flag.NONE, Flag.DOCKED | Flag.LANDED_PLANET, + () => gameState.Journal.hasShieldCellBank)), new ControlGroup("DefenceColor", new[] { Command.OrderDefensiveBehaviour @@ -384,6 +388,43 @@ public class EliteDangerousKeyBindsLayerHandler : LayerHandler blinkingKeys = new Dictionary() @@ -469,26 +510,31 @@ private Color GetBlinkingColor(Color baseColor) public override EffectLayer Render(IGameState state) { gameState = state as GameState_EliteDangerous; + GSI.Nodes.Controls controls = (state as GameState_EliteDangerous).Controls; + EffectLayer keyBindsLayer = new EffectLayer("Elite: Dangerous - Key Binds"); - foreach (ControlGroup group in commandGroups) + foreach (ControlGroupSet controlGroupSet in controlGroupSets) { - group.color = Properties.GetColorByVariableName(group.colorGroupName); - } + if (!controlGroupSet.ConditionSatisfied(gameState.Status)) continue; - GSI.Nodes.Controls controls = (state as GameState_EliteDangerous).Controls; - foreach (KeyValuePair entry in controls.commandToBind) - { - foreach (ControlGroup group in commandGroups) + foreach (ControlGroup controlGroup in controlGroupSet.controlGroups) { - if (group.ConditionSatisfied(gameState.Status) && group.commands.Contains(entry.Key)) + controlGroup.color = Properties.GetColorByVariableName(controlGroup.colorGroupName); + + if (!controlGroup.ConditionSatisfied(gameState.Status)) continue; + + foreach (string command in controlGroup.commands) { - bool blinkingKey = blinkingKeys.ContainsKey(entry.Key) && - blinkingKeys[entry.Key].ConditionSatisfied(gameState.Status); + if (!controls.commandToBind.ContainsKey(command)) continue; + + bool blinkingKey = blinkingKeys.ContainsKey(command) && + blinkingKeys[command].ConditionSatisfied(gameState.Status); - foreach (Bind.Mapping mapping in entry.Value.mappings) + foreach (Bind.Mapping mapping in controls.commandToBind[command].mappings) { - keyBindsLayer.Set(mapping.key, blinkingKey ? GetBlinkingColor(group.color) : group.color); + keyBindsLayer.Set(mapping.key, + blinkingKey ? GetBlinkingColor(controlGroup.color) : controlGroup.color); } } } From 0208093c2c2c8cafc6e7723fb4d7a3ed83c6612e Mon Sep 17 00:00:00 2001 From: Arturs Ziborovs Date: Tue, 27 Aug 2019 00:49:02 +0300 Subject: [PATCH 16/67] Highlight modifier keys --- .../Layers/EliteDangerousKeyBindsLayerHandler.cs | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs index 23e4b16f3..b649aa197 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs @@ -4,6 +4,7 @@ using Aurora.EffectsEngine; using Aurora.Settings.Layers; using System.Drawing; +using System.Linq; using System.Windows.Controls; using Aurora.Devices; using Aurora.Profiles.EliteDangerous.GSI; @@ -533,6 +534,20 @@ public override EffectLayer Render(IGameState state) foreach (Bind.Mapping mapping in controls.commandToBind[command].mappings) { + bool allModifiersPressed = true; + foreach (DeviceKeys modifierKey in mapping.modifiers) + { + keyBindsLayer.Set(modifierKey, Properties.ShipStuffColor); + //TODO: A correct check if a modifier key is pressed + if (Array.IndexOf(Global.InputEvents.PressedKeys, modifierKey) == -1) + { + allModifiersPressed = false; + break; + } + } + + if (!allModifiersPressed) continue; + keyBindsLayer.Set(mapping.key, blinkingKey ? GetBlinkingColor(controlGroup.color) : controlGroup.color); } From 858808011e7940c46155a470cd64dc1974ab7411 Mon Sep 17 00:00:00 2001 From: Arturs Ziborovs Date: Tue, 27 Aug 2019 00:54:47 +0300 Subject: [PATCH 17/67] Properly detect if all modifier keys are pressed before highlighting --- .../Layers/EliteDangerousKeyBindsLayerHandler.cs | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs index b649aa197..c6f388f36 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs @@ -6,9 +6,11 @@ using System.Drawing; using System.Linq; using System.Windows.Controls; +using System.Windows.Input; using Aurora.Devices; using Aurora.Profiles.EliteDangerous.GSI; using Aurora.Profiles.EliteDangerous.GSI.Nodes; +using Aurora.Utils; using CSScriptLibrary; namespace Aurora.Profiles.EliteDangerous.Layers @@ -538,8 +540,7 @@ public override EffectLayer Render(IGameState state) foreach (DeviceKeys modifierKey in mapping.modifiers) { keyBindsLayer.Set(modifierKey, Properties.ShipStuffColor); - //TODO: A correct check if a modifier key is pressed - if (Array.IndexOf(Global.InputEvents.PressedKeys, modifierKey) == -1) + if (Array.IndexOf(Global.InputEvents.PressedKeys, KeyUtils.GetFormsKey(modifierKey)) == -1) { allModifiersPressed = false; break; From 015d42af327cd57e49f6dcb97efc2113fc0077a3 Mon Sep 17 00:00:00 2001 From: Arturs Ziborovs Date: Wed, 28 Aug 2019 19:49:18 +0300 Subject: [PATCH 18/67] Refactored where key and control group presets are stored - changed how game state is checked --- .../GSI/GameState_EliteDangerous.cs | 83 +++++- .../EliteDangerous/GSI/Nodes/Controls.cs | 22 +- .../EliteDangerous/GSI/Nodes/Status.cs | 139 ++------- .../EliteDangerousKeyBindsLayerHandler.cs | 272 +---------------- .../Profiles/EliteDangerous/Presets.cs | 276 ++++++++++++++++++ .../Project-Aurora/Project-Aurora.csproj | 1 + 6 files changed, 399 insertions(+), 394 deletions(-) create mode 100644 Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Presets.cs diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/GameState_EliteDangerous.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/GameState_EliteDangerous.cs index b68b0da8b..cb7bdc136 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/GameState_EliteDangerous.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/GameState_EliteDangerous.cs @@ -1,13 +1,85 @@ -using Aurora.Profiles.EliteDangerous.GSI.Nodes; +using System; +using Aurora.Profiles.EliteDangerous.GSI.Nodes; namespace Aurora.Profiles.EliteDangerous.GSI { + public class GameStateCondition + { + long flagsSet; + long flagsNotSet; + GuiFocus guiFocus; + private Func callback = null; + + public GameStateCondition(long flagsSet = -1, long flagsNotSet = -1, GuiFocus guiFocus = GuiFocus.UNSPECIFIED, + Func callback = null) + { + this.flagsSet = flagsSet; + this.guiFocus = guiFocus; + this.flagsNotSet = flagsNotSet; + this.callback = callback; + } + + public GameStateCondition(Func callback) + { + this.callback = callback; + } + + public bool IsSatisfied(GameState_EliteDangerous gameState) + { + if (callback != null && !callback(gameState)) + { + return false; + } + + if (guiFocus != GuiFocus.UNSPECIFIED && guiFocus != gameState.Status.GuiFocus) + { + return false; + } + + if (flagsSet != -1 && !Flag.IsFlagSet(gameState.Status.Flags, flagsSet)) + { + return false; + } + + if (flagsNotSet != -1 && Flag.IsFlagSet(gameState.Status.Flags, flagsNotSet)) + { + return false; + } + + return true; + } + } + + public class NeedsGameState + { + public GameStateCondition NeededGameStateCondition; + + public NeedsGameState() + { + } + + public NeedsGameState(GameStateCondition neededGameStateCondition) + { + this.NeededGameStateCondition = neededGameStateCondition; + } + + public bool IsSatisfied(GameState_EliteDangerous gameState) + { + if (NeededGameStateCondition != null) + { + return NeededGameStateCondition.IsSatisfied(gameState); + } + + return true; + } + } + public class GameState_EliteDangerous : GameState { private Status status; private Journal journal; private Nodes.Controls controls; - + public Journal Journal { get @@ -18,7 +90,7 @@ public Journal Journal return journal; } } - + public Status Status { get @@ -29,7 +101,7 @@ public Status Status return status; } } - + public Nodes.Controls Controls { get @@ -40,6 +112,7 @@ public Nodes.Controls Controls return controls; } } + /// /// Creates a default GameState_EliteDangerous instance. /// @@ -47,4 +120,4 @@ public GameState_EliteDangerous() : base() { } } -} +} \ No newline at end of file diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Controls.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Controls.cs index 210fa8750..ad098fb4d 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Controls.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Controls.cs @@ -425,12 +425,12 @@ public void AddMapping(Mapping mapping) } } - public class ControlGroupSet : NeedsStatusState + public class ControlGroupSet : NeedsGameState { public ControlGroup[] controlGroups; public ControlGroupSet(ControlGroupSet copyFromSet, ControlGroup[] controlGroups, - StatusState neededStatusState = null) + GameStateCondition neededGameStateCondition = null) { List controlGroupList = new List(); controlGroupList.AddRange(copyFromSet.controlGroups); @@ -438,24 +438,24 @@ public ControlGroupSet(ControlGroupSet copyFromSet, ControlGroup[] controlGroups this.controlGroups = controlGroupList.ToArray(); - if (neededStatusState != null) + if (neededGameStateCondition != null) { - this.neededStatusState = neededStatusState; + this.NeededGameStateCondition = neededGameStateCondition; } - else if (copyFromSet.neededStatusState != null) + else if (copyFromSet.NeededGameStateCondition != null) { - this.neededStatusState = copyFromSet.neededStatusState; + this.NeededGameStateCondition = copyFromSet.NeededGameStateCondition; } } - public ControlGroupSet(ControlGroup[] controlGroups, StatusState neededStatusState = null) : base( - neededStatusState) + public ControlGroupSet(ControlGroup[] controlGroups, GameStateCondition neededGameStateCondition = null) : base( + neededGameStateCondition) { this.controlGroups = controlGroups; } } - public class ControlGroup : NeedsStatusState + public class ControlGroup : NeedsGameState { public string colorGroupName; public Color color; @@ -465,8 +465,8 @@ public ControlGroup(string colorGroupName, string[] commands) : this(colorGroupN { } - public ControlGroup(string colorGroupName, string[] commands, StatusState neededStatusState) : base( - neededStatusState) + public ControlGroup(string colorGroupName, string[] commands, GameStateCondition neededGameStateCondition) : base( + neededGameStateCondition) { this.colorGroupName = colorGroupName; this.commands = commands.ToList(); diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Status.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Status.cs index 4b67f07be..0992417e0 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Status.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/GSI/Nodes/Status.cs @@ -2,102 +2,9 @@ namespace Aurora.Profiles.EliteDangerous.GSI.Nodes { - - public class NeedsStatusState - { - public StatusState neededStatusState; - - public NeedsStatusState() - { - } - - public NeedsStatusState(StatusState neededStatusState) - { - this.neededStatusState = neededStatusState; - } - - public bool ConditionSatisfied(Status status) - { - return ConditionSatisfied(status.Flags, status.GuiFocus); - } - - public bool ConditionSatisfied(long flags, int guiFocus) - { - if (neededStatusState != null) - { - return neededStatusState.ConditionSatisfied(flags, guiFocus); - } - - return true; - } - } - - public class StatusState - { - long flagsSet = -1; - long flagsNotSet = -1; - int guiFocus = -1; - private Func conditionCallback = null; - - public StatusState(long flagsSet, long flagsNotSet = -1) : this(flagsSet, -1, flagsNotSet, null) - { - } - - public StatusState(long flagsSet, long flagsNotSet, Func conditionCallback) : this(flagsSet, -1, - flagsNotSet, conditionCallback) - { - } - public StatusState(int guiFocus) : this(Flag.NONE, guiFocus, Flag.NONE) - { - } - - public StatusState(long flagsSet, int guiFocus, long flagsNotSet, Func conditionCallback = null) - { - this.flagsSet = flagsSet; - this.guiFocus = guiFocus; - this.flagsNotSet = flagsNotSet; - this.conditionCallback = conditionCallback; - } - - public StatusState(Func conditionCallback) - { - this.conditionCallback = conditionCallback; - } - - public bool ConditionSatisfied(Status status) - { - return ConditionSatisfied(status.Flags, status.GuiFocus); - } - - public bool ConditionSatisfied(long flags, int guiFocus) - { - if (conditionCallback != null && !conditionCallback()) - { - return false; - } - - if (this.guiFocus != -1 && this.guiFocus != guiFocus) - { - return false; - } - - if (this.flagsSet != -1 && !Flag.IsFlagSet(flags, this.flagsSet)) - { - return false; - } - - if (this.flagsNotSet != -1 && Flag.IsFlagSet(flags, this.flagsNotSet)) - { - return false; - } - - return true; - } - } - public static class Flag { - public static readonly int NONE = -1; + public static readonly int UNSPECIFIED = -1; public static readonly int DOCKED = 1; public static readonly int LANDED_PLANET = 1 << 1; public static readonly int LANDING_GEAR = 1 << 2; @@ -134,21 +41,29 @@ public static bool IsFlagSet(long bitmask, long flag) } } - public static class GuiFocus { - public static readonly int NONE = 0; - public static readonly int PANEL_SYSTEMS = 1; - public static readonly int PANEL_NAV = 2; - public static readonly int PANEL_COMS = 3; - public static readonly int PANEL_ROLE = 4; - public static readonly int STATION_SERVICES = 5; - - public static readonly int MAP_GALAXY = 6; - public static readonly int MAP_SYSTEM = 7; - public static readonly int MAP_ORRERY = 8; - public static readonly int MODE_FSS = 9; - public static readonly int MODE_ADS = 10; + public enum GuiFocus + { + UNSPECIFIED = -1, + NONE = 0, + PANEL_SYSTEMS = 1, + PANEL_NAV = 2, + PANEL_COMS = 3, + PANEL_ROLE = 4, + STATION_SERVICES = 5, + + MAP_GALAXY = 6, + MAP_SYSTEM = 7, + MAP_ORRERY = 8, + MODE_FSS = 9, + MODE_ADS = 10 } + public class Fuel + { + public double FuelMain; + public double FuelReservoir; + } + /// /// Class representing player status /// @@ -159,14 +74,8 @@ public class Status : Node public long Flags; public int[] Pips; public int FireGroup; - public int GuiFocus; - public FuelClass Fuel; + public GuiFocus GuiFocus; + public Fuel Fuel; public double Cargo; - - public class FuelClass - { - public double FuelMain; - public double FuelReservoir; - } } } \ No newline at end of file diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs index c6f388f36..7a2008eb7 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/EliteDangerousKeyBindsLayerHandler.cs @@ -215,267 +215,12 @@ public Color GetColorByVariableName(string colorVariableName) public class EliteDangerousKeyBindsLayerHandler : LayerHandler { private int blinkSpeed = 20; - public static GameState_EliteDangerous gameState = null; - - private static ControlGroupSet CONTROLS_MAIN = new ControlGroupSet(new ControlGroup[] - { - new ControlGroup("CameraColor", new[] - { - Command.PhotoCameraToggle, Command.PhotoCameraToggle_Buggy, Command.VanityCameraScrollLeft, - Command.VanityCameraScrollRight, Command.ToggleFreeCam, Command.FreeCamToggleHUD, - Command.FixCameraRelativeToggle, Command.FixCameraWorldToggle - }), - new ControlGroup("MovementSpeedColor", new[] - { - Command.ForwardKey, Command.BackwardKey, Command.IncreaseEnginesPower, Command.SetSpeedZero, - Command.SetSpeed25, Command.SetSpeed50, Command.SetSpeed75, Command.SetSpeed100 - }, new StatusState(Flag.NONE, - Flag.DOCKED | Flag.LANDED_PLANET - )), - new ControlGroup("MovementSpeedColor", new[] - { - Command.SetSpeedMinus100, Command.SetSpeedMinus75, Command.SetSpeedMinus50, - Command.SetSpeedMinus25, Command.AutoBreakBuggyButton - }, new StatusState(Flag.NONE, - Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE - )), - new ControlGroup("MovementSpeedColor", new[] - { - Command.OrderHoldPosition - }, new StatusState(() => gameState.Journal.fighterStatus != FighterStatus.None)), - - new ControlGroup("MovementSpeedColor", new[] - { - Command.UseBoostJuice - }, new StatusState(Flag.NONE, - Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE | Flag.LANDING_GEAR | Flag.CARGO_SCOOP - )), - new ControlGroup("MovementSecondaryColor", new[] - { - Command.RollLeftButton, Command.RollRightButton, Command.PitchUpButton, Command.PitchDownButton - }, new StatusState(Flag.NONE, - Flag.DOCKED | Flag.LANDED_PLANET - )), - new ControlGroup("MovementSecondaryColor", new[] - { - Command.LeftThrustButton, Command.RightThrustButton, Command.UpThrustButton, - Command.DownThrustButton, - Command.ForwardThrustButton, Command.BackwardThrustButton - }, new StatusState(Flag.NONE, - Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE - )), - new ControlGroup("MovementSecondaryColor", new[] - { - Command.OrderFollow - }, new StatusState(() => gameState.Journal.fighterStatus != FighterStatus.None)), - new ControlGroup("UiColor", new[] - { - Command.FocusLeftPanel, Command.FocusCommsPanel, Command.QuickCommsPanel, - Command.FocusRadarPanel, Command.FocusRightPanel, Command.UI_Select, Command.PlayerHUDModeToggle - }), - new ControlGroup("UiColor", new[] - { - Command.UI_Left, Command.UI_Right, Command.UI_Up, Command.UI_Down - }, new StatusState( - Flag.DOCKED - )), - new ControlGroup("UiColor", new[] - { - Command.UI_Left, Command.UI_Right, Command.UI_Up, Command.UI_Down - }, new StatusState( - Flag.LANDED_PLANET - )), - new ControlGroup("UiColor", new[] - { - Command.OrderAggressiveBehaviour - }, new StatusState(() => gameState.Journal.fighterStatus != FighterStatus.None)), - - new ControlGroup("NavigationColor", new[] - { - Command.GalaxyMapOpen, Command.SystemMapOpen, Command.TargetNextRouteSystem - }), - new ControlGroup("NavigationColor", new[] - { - Command.HyperSuperCombination, Command.Supercruise, Command.Hyperspace - }, new StatusState(Flag.NONE, - Flag.DOCKED | Flag.LANDED_PLANET | Flag.MASS_LOCK | Flag.LANDING_GEAR | Flag.HARDPOINTS | - Flag.CARGO_SCOOP - )), - new ControlGroup("NavigationColor", new[] - { - Command.OrderRequestDock - }, new StatusState(() => gameState.Journal.fighterStatus != FighterStatus.None)), - new ControlGroup("ShipStuffColor", new[] - { - Command.ShipSpotLightToggle, Command.HeadlightsBuggyButton, Command.NightVisionToggle - }), - new ControlGroup("ShipStuffColor", new[] - { - Command.ToggleFlightAssist - }, new StatusState(Flag.NONE, - Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE - )), - - new ControlGroup("ShipStuffColor", new[] - { - Command.ToggleCargoScoop, Command.LandingGearToggle - }, new StatusState(Flag.NONE, Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE | Flag.IN_FIGHTER)), - - new ControlGroup("ShipStuffColor", new[] - { - Command.ToggleCargoScoop_Buggy - }, new StatusState(Flag.IN_SRV, Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE | Flag.IN_FIGHTER)), - - new ControlGroup("DefenceColor", new[] - { - Command.IncreaseSystemsPower, Command.ChargeECM - }, new StatusState(Flag.NONE, - Flag.DOCKED | Flag.LANDED_PLANET - )), - new ControlGroup("DefenceColor", new[] - { - Command.FireChaffLauncher - }, - new StatusState(Flag.NONE, Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE, - () => gameState.Journal.hasChaff)), - new ControlGroup("DefenceColor", new[] - { - Command.DeployHeatSink - }, new StatusState(Flag.NONE, Flag.DOCKED | Flag.LANDED_PLANET, () => gameState.Journal.hasHeatSink)), - new ControlGroup("DefenceColor", new[] - { - Command.UseShieldCell - }, - new StatusState(Flag.NONE, Flag.DOCKED | Flag.LANDED_PLANET, - () => gameState.Journal.hasShieldCellBank)), - new ControlGroup("DefenceColor", new[] - { - Command.OrderDefensiveBehaviour - }, new StatusState(() => gameState.Journal.fighterStatus != FighterStatus.None)), - - new ControlGroup("OffenceColor", new[] - { - Command.CycleFireGroupPrevious - }), - new ControlGroup("OffenceColor", new[] - { - Command.IncreaseWeaponsPower, Command.CycleFireGroupNext, Command.SelectHighestThreat, - Command.CycleNextSubsystem, Command.CyclePreviousSubsystem, Command.CycleNextHostileTarget, - Command.CyclePreviousHostileTarget - }, new StatusState(Flag.NONE, - Flag.DOCKED | Flag.LANDED_PLANET - )), - new ControlGroup("OffenceColor", new[] - { - Command.DeployHardpointToggle - }, new StatusState(Flag.NONE, - Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE - )), - new ControlGroup("OffenceColor", new[] - { - Command.OrderFocusTarget - }, new StatusState(() => gameState.Journal.fighterStatus != FighterStatus.None)), - - new ControlGroup("WingColor", new[] - { - Command.TargetWingman0, Command.TargetWingman1, - Command.TargetWingman2, Command.SelectTargetsTarget, Command.WingNavLock - }, new StatusState(Flag.IN_WING - )), - new ControlGroup("WingColor", new[] - { - Command.OrderHoldFire - }, new StatusState(() => gameState.Journal.fighterStatus != FighterStatus.None)), - - new ControlGroup("ModeEnableColor", new[] - { - Command.ExplorationFSSEnter - }, new StatusState(Flag.SUPERCRUISE | Flag.HUD_DISCOVERY_MODE, Flag.DOCKED | Flag.LANDED_PLANET)) - }, new StatusState(GuiFocus.NONE)); - - private static ControlGroupSet CONTROLS_SYSTEM_MAP = new ControlGroupSet(new[] - { - new ControlGroup("MovementSpeedColor", new[] - { - Command.CamTranslateForward, Command.CamTranslateBackward, Command.CamTranslateLeft, - Command.CamTranslateRight - }), - new ControlGroup("MovementSecondaryColor", new[] - { - Command.CamZoomIn, Command.CamZoomOut - }), - new ControlGroup("UiColor", new[] - { - Command.UI_Back, Command.UI_Select - }), - new ControlGroup("NavigationColor", new[] - { - Command.GalaxyMapOpen, Command.SystemMapOpen - }) - }, new StatusState(GuiFocus.MAP_SYSTEM)); - - private static ControlGroupSet CONTROLS_GALAXY_MAP = new ControlGroupSet(CONTROLS_SYSTEM_MAP, new[] - { - new ControlGroup("MovementSecondaryColor", new[] - { - Command.CamPitchUp, Command.CamPitchDown, Command.CamTranslateUp, Command.CamTranslateDown, - Command.CamYawLeft, Command.CamYawRight - }) - }, new StatusState(GuiFocus.MAP_GALAXY)); private ControlGroupSet[] controlGroupSets = { - CONTROLS_MAIN, - CONTROLS_SYSTEM_MAP, - CONTROLS_GALAXY_MAP - }; - - private Dictionary blinkingKeys = new Dictionary() - { - { - Command.LandingGearToggle, new StatusState( - Flag.LANDING_GEAR, - Flag.DOCKED | Flag.LANDED_PLANET - ) - }, - { - Command.DeployHardpointToggle, new StatusState( - Flag.HARDPOINTS, - Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE | Flag.IN_FIGHTER | Flag.IN_SRV - ) - }, - { - Command.ToggleCargoScoop, new StatusState( - Flag.CARGO_SCOOP, - Flag.DOCKED | Flag.LANDED_PLANET - ) - }, - { - Command.ToggleCargoScoop_Buggy, new StatusState( - Flag.CARGO_SCOOP, - Flag.DOCKED | Flag.LANDED_PLANET - ) - }, - { - Command.ShipSpotLightToggle, new StatusState( - Flag.SHIP_LIGHTS - ) - }, - { - Command.HeadlightsBuggyButton, new StatusState( - Flag.SHIP_LIGHTS - ) - }, - { - Command.NightVisionToggle, new StatusState( - Flag.NIGHT_VISION - ) - }, - { - Command.AutoBreakBuggyButton, new StatusState( - Flag.IN_SRV | Flag.SRV_HANDBRAKE - ) - } + ControlGroupSets.CONTROLS_MAIN, + ControlGroupSets.CONTROLS_SYSTEM_MAP, + ControlGroupSets.CONTROLS_GALAXY_MAP }; public EliteDangerousKeyBindsLayerHandler() : base() @@ -512,27 +257,28 @@ private Color GetBlinkingColor(Color baseColor) public override EffectLayer Render(IGameState state) { - gameState = state as GameState_EliteDangerous; + GameState_EliteDangerous gameState = state as GameState_EliteDangerous; + GSI.Nodes.Controls controls = (state as GameState_EliteDangerous).Controls; EffectLayer keyBindsLayer = new EffectLayer("Elite: Dangerous - Key Binds"); foreach (ControlGroupSet controlGroupSet in controlGroupSets) { - if (!controlGroupSet.ConditionSatisfied(gameState.Status)) continue; + if (!controlGroupSet.IsSatisfied(gameState)) continue; foreach (ControlGroup controlGroup in controlGroupSet.controlGroups) { controlGroup.color = Properties.GetColorByVariableName(controlGroup.colorGroupName); - if (!controlGroup.ConditionSatisfied(gameState.Status)) continue; + if (!controlGroup.IsSatisfied(gameState)) continue; foreach (string command in controlGroup.commands) { if (!controls.commandToBind.ContainsKey(command)) continue; - bool blinkingKey = blinkingKeys.ContainsKey(command) && - blinkingKeys[command].ConditionSatisfied(gameState.Status); + bool blinkingKey = KeyPresets.BLINKING_KEYS.ContainsKey(command) && + KeyPresets.BLINKING_KEYS[command].IsSatisfied(gameState); foreach (Bind.Mapping mapping in controls.commandToBind[command].mappings) { diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Presets.cs b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Presets.cs new file mode 100644 index 000000000..b733600bd --- /dev/null +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Presets.cs @@ -0,0 +1,276 @@ +using System.Collections.Generic; +using Aurora.Profiles.EliteDangerous.GSI; +using Aurora.Profiles.EliteDangerous.GSI.Nodes; + +namespace Aurora.Profiles.EliteDangerous +{ + public class ControlGroupSets + { + public static ControlGroupSet CONTROLS_MAIN = new ControlGroupSet(new[] + { + new ControlGroup("CameraColor", new[] + { + Command.PhotoCameraToggle, Command.PhotoCameraToggle_Buggy, Command.VanityCameraScrollLeft, + Command.VanityCameraScrollRight, Command.ToggleFreeCam, Command.FreeCamToggleHUD, + Command.FixCameraRelativeToggle, Command.FixCameraWorldToggle + }), + new ControlGroup("MovementSpeedColor", new[] + { + Command.ForwardKey, Command.BackwardKey, Command.IncreaseEnginesPower, Command.SetSpeedZero, + Command.SetSpeed25, Command.SetSpeed50, Command.SetSpeed75, Command.SetSpeed100 + }, new GameStateCondition(flagsSet: Flag.UNSPECIFIED, + flagsNotSet: Flag.DOCKED | Flag.LANDED_PLANET + )), + new ControlGroup("MovementSpeedColor", new[] + { + Command.SetSpeedMinus100, Command.SetSpeedMinus75, Command.SetSpeedMinus50, + Command.SetSpeedMinus25, Command.AutoBreakBuggyButton + }, new GameStateCondition(flagsSet: Flag.UNSPECIFIED, + flagsNotSet: Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE + )), + new ControlGroup("MovementSpeedColor", new[] + { + Command.OrderHoldPosition + }, new GameStateCondition(callback: gameState => gameState.Journal.fighterStatus != FighterStatus.None)), + + new ControlGroup("MovementSpeedColor", new[] + { + Command.UseBoostJuice + }, new GameStateCondition(flagsSet: Flag.UNSPECIFIED, + flagsNotSet: Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE | Flag.LANDING_GEAR | Flag.CARGO_SCOOP + )), + new ControlGroup("MovementSecondaryColor", new[] + { + Command.RollLeftButton, Command.RollRightButton, Command.PitchUpButton, Command.PitchDownButton + }, new GameStateCondition(flagsSet: Flag.UNSPECIFIED, + flagsNotSet: Flag.DOCKED | Flag.LANDED_PLANET + )), + new ControlGroup("MovementSecondaryColor", new[] + { + Command.LeftThrustButton, Command.RightThrustButton, Command.UpThrustButton, + Command.DownThrustButton, + Command.ForwardThrustButton, Command.BackwardThrustButton + }, new GameStateCondition(flagsSet: Flag.UNSPECIFIED, + flagsNotSet: Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE + )), + new ControlGroup("MovementSecondaryColor", new[] + { + Command.OrderFollow + }, new GameStateCondition(callback: gameState => gameState.Journal.fighterStatus != FighterStatus.None)), + new ControlGroup("UiColor", new[] + { + Command.FocusLeftPanel, Command.FocusCommsPanel, Command.QuickCommsPanel, + Command.FocusRadarPanel, Command.FocusRightPanel, Command.UI_Select, Command.PlayerHUDModeToggle + }), + new ControlGroup("UiColor", new[] + { + Command.UI_Left, Command.UI_Right, Command.UI_Up, Command.UI_Down + }, new GameStateCondition(flagsSet: + Flag.DOCKED + )), + new ControlGroup("UiColor", new[] + { + Command.UI_Left, Command.UI_Right, Command.UI_Up, Command.UI_Down + }, new GameStateCondition(flagsSet: + Flag.LANDED_PLANET + )), + new ControlGroup("UiColor", new[] + { + Command.OrderAggressiveBehaviour + }, new GameStateCondition(callback: gameState => gameState.Journal.fighterStatus != FighterStatus.None)), + + new ControlGroup("NavigationColor", new[] + { + Command.GalaxyMapOpen, Command.SystemMapOpen, Command.TargetNextRouteSystem + }), + new ControlGroup("NavigationColor", new[] + { + Command.HyperSuperCombination, Command.Supercruise, Command.Hyperspace + }, new GameStateCondition(flagsSet: Flag.UNSPECIFIED, + flagsNotSet: Flag.DOCKED | Flag.LANDED_PLANET | Flag.MASS_LOCK | Flag.LANDING_GEAR | Flag.HARDPOINTS | + Flag.CARGO_SCOOP + )), + new ControlGroup("NavigationColor", new[] + { + Command.OrderRequestDock + }, new GameStateCondition(callback: gameState => gameState.Journal.fighterStatus != FighterStatus.None)), + new ControlGroup("ShipStuffColor", new[] + { + Command.ShipSpotLightToggle, Command.HeadlightsBuggyButton, Command.NightVisionToggle + }), + new ControlGroup("ShipStuffColor", new[] + { + Command.ToggleFlightAssist + }, new GameStateCondition(flagsSet: Flag.UNSPECIFIED, + flagsNotSet: Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE + )), + + new ControlGroup("ShipStuffColor", new[] + { + Command.ToggleCargoScoop, Command.LandingGearToggle + }, + new GameStateCondition(flagsSet: Flag.UNSPECIFIED, + flagsNotSet: Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE | Flag.IN_FIGHTER)), + + new ControlGroup("ShipStuffColor", new[] + { + Command.ToggleCargoScoop_Buggy + }, + new GameStateCondition(flagsSet: Flag.IN_SRV, + flagsNotSet: Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE | Flag.IN_FIGHTER)), + + new ControlGroup("DefenceColor", new[] + { + Command.IncreaseSystemsPower, Command.ChargeECM + }, new GameStateCondition(flagsSet: Flag.UNSPECIFIED, + flagsNotSet: Flag.DOCKED | Flag.LANDED_PLANET + )), + new ControlGroup("DefenceColor", new[] + { + Command.FireChaffLauncher + }, + new GameStateCondition(flagsSet: Flag.UNSPECIFIED, + flagsNotSet: Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE, + callback: gameState => gameState.Journal.hasChaff)), + new ControlGroup("DefenceColor", new[] + { + Command.DeployHeatSink + }, + new GameStateCondition(flagsSet: Flag.UNSPECIFIED, flagsNotSet: Flag.DOCKED | Flag.LANDED_PLANET, + callback: gameState => gameState.Journal.hasHeatSink)), + new ControlGroup("DefenceColor", new[] + { + Command.UseShieldCell + }, + new GameStateCondition(flagsSet: Flag.UNSPECIFIED, flagsNotSet: Flag.DOCKED | Flag.LANDED_PLANET, + callback: gameState => gameState.Journal.hasShieldCellBank)), + new ControlGroup("DefenceColor", new[] + { + Command.OrderDefensiveBehaviour + }, new GameStateCondition(callback: gameState => gameState.Journal.fighterStatus != FighterStatus.None)), + + new ControlGroup("OffenceColor", new[] + { + Command.CycleFireGroupPrevious + }), + new ControlGroup("OffenceColor", new[] + { + Command.IncreaseWeaponsPower, Command.CycleFireGroupNext, Command.SelectHighestThreat, + Command.CycleNextSubsystem, Command.CyclePreviousSubsystem, Command.CycleNextHostileTarget, + Command.CyclePreviousHostileTarget + }, new GameStateCondition(flagsSet: Flag.UNSPECIFIED, + flagsNotSet: Flag.DOCKED | Flag.LANDED_PLANET + )), + new ControlGroup("OffenceColor", new[] + { + Command.DeployHardpointToggle + }, new GameStateCondition(flagsSet: Flag.UNSPECIFIED, + flagsNotSet: Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE + )), + new ControlGroup("OffenceColor", new[] + { + Command.OrderFocusTarget + }, new GameStateCondition(callback: gameState => gameState.Journal.fighterStatus != FighterStatus.None)), + + new ControlGroup("WingColor", new[] + { + Command.TargetWingman0, Command.TargetWingman1, + Command.TargetWingman2, Command.SelectTargetsTarget, Command.WingNavLock + }, new GameStateCondition(flagsSet: Flag.IN_WING + )), + new ControlGroup("WingColor", new[] + { + Command.OrderHoldFire + }, new GameStateCondition(callback: gameState => gameState.Journal.fighterStatus != FighterStatus.None)), + + new ControlGroup("ModeEnableColor", new[] + { + Command.ExplorationFSSEnter + }, + new GameStateCondition(flagsSet: Flag.SUPERCRUISE | Flag.HUD_DISCOVERY_MODE, + flagsNotSet: Flag.DOCKED | Flag.LANDED_PLANET)) + }, new GameStateCondition(guiFocus: GuiFocus.NONE)); + + public static ControlGroupSet CONTROLS_SYSTEM_MAP = new ControlGroupSet(new[] + { + new ControlGroup("MovementSpeedColor", new[] + { + Command.CamTranslateForward, Command.CamTranslateBackward, Command.CamTranslateLeft, + Command.CamTranslateRight + }), + new ControlGroup("MovementSecondaryColor", new[] + { + Command.CamZoomIn, Command.CamZoomOut + }), + new ControlGroup("UiColor", new[] + { + Command.UI_Back, Command.UI_Select + }), + new ControlGroup("NavigationColor", new[] + { + Command.GalaxyMapOpen, Command.SystemMapOpen + }) + }, new GameStateCondition(guiFocus: GuiFocus.MAP_SYSTEM)); + + public static ControlGroupSet CONTROLS_GALAXY_MAP = new ControlGroupSet(CONTROLS_SYSTEM_MAP, new[] + { + new ControlGroup("MovementSecondaryColor", new[] + { + Command.CamPitchUp, Command.CamPitchDown, Command.CamTranslateUp, Command.CamTranslateDown, + Command.CamYawLeft, Command.CamYawRight + }) + }, new GameStateCondition(guiFocus: GuiFocus.MAP_GALAXY)); + } + + public class KeyPresets + { + public static Dictionary BLINKING_KEYS = + new Dictionary() + { + { + Command.LandingGearToggle, new GameStateCondition(flagsSet: + Flag.LANDING_GEAR, + flagsNotSet: Flag.DOCKED | Flag.LANDED_PLANET + ) + }, + { + Command.DeployHardpointToggle, new GameStateCondition(flagsSet: + Flag.HARDPOINTS, + flagsNotSet: Flag.DOCKED | Flag.LANDED_PLANET | Flag.SUPERCRUISE | Flag.IN_FIGHTER | Flag.IN_SRV + ) + }, + { + Command.ToggleCargoScoop, new GameStateCondition(flagsSet: + Flag.CARGO_SCOOP, + flagsNotSet: Flag.DOCKED | Flag.LANDED_PLANET + ) + }, + { + Command.ToggleCargoScoop_Buggy, new GameStateCondition(flagsSet: + Flag.CARGO_SCOOP, + flagsNotSet: Flag.DOCKED | Flag.LANDED_PLANET + ) + }, + { + Command.ShipSpotLightToggle, new GameStateCondition(flagsSet: + Flag.SHIP_LIGHTS + ) + }, + { + Command.HeadlightsBuggyButton, new GameStateCondition(flagsSet: + Flag.SHIP_LIGHTS + ) + }, + { + Command.NightVisionToggle, new GameStateCondition(flagsSet: + Flag.NIGHT_VISION + ) + }, + { + Command.AutoBreakBuggyButton, new GameStateCondition(flagsSet: + Flag.IN_SRV | Flag.SRV_HANDBRAKE + ) + } + }; + } +} \ No newline at end of file diff --git a/Project-Aurora/Project-Aurora/Project-Aurora.csproj b/Project-Aurora/Project-Aurora/Project-Aurora.csproj index 7cbe9c185..95405fc5e 100755 --- a/Project-Aurora/Project-Aurora/Project-Aurora.csproj +++ b/Project-Aurora/Project-Aurora/Project-Aurora.csproj @@ -451,6 +451,7 @@ + Control_EliteDangerous.xaml From de128be0efde17db6177162efee4c9a3e869cb28 Mon Sep 17 00:00:00 2001 From: Arturs Ziborovs Date: Wed, 28 Aug 2019 19:53:25 +0300 Subject: [PATCH 19/67] Fixed missed merge conflict notation --- Project-Aurora/Project-Aurora/Project-Aurora.csproj | 1 - 1 file changed, 1 deletion(-) diff --git a/Project-Aurora/Project-Aurora/Project-Aurora.csproj b/Project-Aurora/Project-Aurora/Project-Aurora.csproj index 78e3410cc..606c0b10a 100755 --- a/Project-Aurora/Project-Aurora/Project-Aurora.csproj +++ b/Project-Aurora/Project-Aurora/Project-Aurora.csproj @@ -472,7 +472,6 @@ -<<<<<<< HEAD Control_EliteDangerous.xaml From e49c185cff147214221c32102cf78f530d2933bf Mon Sep 17 00:00:00 2001 From: Arturs Ziborovs Date: Wed, 28 Aug 2019 20:12:07 +0300 Subject: [PATCH 20/67] Cleaned up color settings a bit --- .../Control_EliteDangerousKeyBindsLayer.xaml | 82 ++++++++----------- ...ontrol_EliteDangerousKeyBindsLayer.xaml.cs | 65 ++++----------- .../EliteDangerousKeyBindsLayerHandler.cs | 47 +---------- 3 files changed, 52 insertions(+), 142 deletions(-) diff --git a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/Control_EliteDangerousKeyBindsLayer.xaml b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/Control_EliteDangerousKeyBindsLayer.xaml index 3cc8c1b8b..40f985238 100644 --- a/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/Control_EliteDangerousKeyBindsLayer.xaml +++ b/Project-Aurora/Project-Aurora/Profiles/EliteDangerous/Layers/Control_EliteDangerousKeyBindsLayer.xaml @@ -18,6 +18,8 @@ + + @@ -25,52 +27,40 @@ - -