1
0
mirror of https://github.com/Artemis-RGB/Artemis synced 2025-12-13 05:48:35 +00:00

Made SurfaceService solely responsible for keeping the surface and the config in sync and saved

This commit is contained in:
Robert Beekman 2019-10-24 00:05:36 +02:00
parent 49e6dbf09b
commit 4add877156
5 changed files with 85 additions and 89 deletions

View File

@ -64,7 +64,7 @@ namespace Artemis.Core.Models.Surface
/// <summary>
/// Applies the configuration to the device
/// </summary>
public void ApplyToDevice()
internal void ApplyToDevice()
{
if (Device != null)
{

View File

@ -1,5 +1,4 @@
using System;
using System.Collections.Generic;
using System.Collections.ObjectModel;
using Artemis.Core.Events;
using Artemis.Core.Models.Surface;
@ -10,9 +9,9 @@ namespace Artemis.Core.Services.Storage
public interface ISurfaceService : IArtemisService
{
/// <summary>
/// Gets or sets the currently active surface configuration
/// Gets the currently active surface configuration, to change config use <see cref="SetActiveSurfaceConfiguration" />
/// </summary>
SurfaceConfiguration ActiveSurfaceConfiguration { get; set; }
SurfaceConfiguration ActiveSurfaceConfiguration { get; }
/// <summary>
/// Gets a read-only list of all surface configurations
@ -26,26 +25,25 @@ namespace Artemis.Core.Services.Storage
/// <returns></returns>
SurfaceConfiguration CreateSurfaceConfiguration(string name);
/// <summary>
/// Sets the provided configuration as active and applies it to the surface
/// </summary>
/// <param name="surfaceConfiguration">The configuration to activate and apply</param>
void SetActiveSurfaceConfiguration(SurfaceConfiguration surfaceConfiguration);
/// <summary>
/// Saves the provided surface configuration to permanent storage and if config is active, applies it to the surface
/// </summary>
/// <param name="surfaceConfiguration">The configuration to save (and apply if active)</param>
/// <param name="includeDevices">Whether to also save devices. If false, devices changes won't be applied either</param>
void UpdateSurfaceConfiguration(SurfaceConfiguration surfaceConfiguration, bool includeDevices);
/// <summary>
/// Deletes the supplied surface configuration, surface configuration may not be the active surface configuration
/// </summary>
/// <param name="surfaceConfiguration">The surface configuration to delete, may not be the active surface configuration</param>
void DeleteSurfaceConfiguration(SurfaceConfiguration surfaceConfiguration);
/// <summary>
/// Saves the provided surface configurations to permanent storage
/// </summary>
/// <param name="surfaceConfigurations">The configurations to save</param>
/// <param name="includeDevices">Whether to also save devices</param>
void SaveToRepository(List<SurfaceConfiguration> surfaceConfigurations, bool includeDevices);
/// <summary>
/// Saves the provided surface configuration to permanent storage
/// </summary>
/// <param name="surfaceConfiguration">The configuration to save</param>
/// <param name="includeDevices">Whether to also save devices</param>
void SaveToRepository(SurfaceConfiguration surfaceConfiguration, bool includeDevices);
/// <summary>
/// Occurs when the active device configuration has been changed
/// </summary>

View File

@ -18,7 +18,6 @@ namespace Artemis.Core.Services.Storage
private readonly IRgbService _rgbService;
private readonly List<SurfaceConfiguration> _surfaceConfigurations;
private readonly ISurfaceRepository _surfaceRepository;
private SurfaceConfiguration _activeSurfaceConfiguration;
public SurfaceService(ILogger logger, ISurfaceRepository surfaceRepository, IRgbService rgbService)
{
@ -32,37 +31,7 @@ namespace Artemis.Core.Services.Storage
_rgbService.DeviceLoaded += RgbServiceOnDeviceLoaded;
}
public SurfaceConfiguration ActiveSurfaceConfiguration
{
get => _activeSurfaceConfiguration;
set
{
if (_activeSurfaceConfiguration == value)
return;
_activeSurfaceConfiguration = value;
lock (_surfaceConfigurations)
{
// Mark only the new value as active
foreach (var surfaceConfiguration in _surfaceConfigurations)
surfaceConfiguration.IsActive = false;
_activeSurfaceConfiguration.IsActive = true;
SaveToRepository(_surfaceConfigurations, true);
}
// Apply the active surface configuration to the devices
if (ActiveSurfaceConfiguration != null)
{
foreach (var deviceConfiguration in ActiveSurfaceConfiguration.DeviceConfigurations)
deviceConfiguration.ApplyToDevice();
}
// Update the RGB service's graphics decorator to work with the new surface configuration
_rgbService.UpdateGraphicsDecorator();
OnActiveSurfaceConfigurationChanged(new SurfaceConfigurationEventArgs(_activeSurfaceConfiguration));
}
}
public SurfaceConfiguration ActiveSurfaceConfiguration { get; private set; }
public ReadOnlyCollection<SurfaceConfiguration> SurfaceConfigurations
{
@ -90,11 +59,62 @@ namespace Artemis.Core.Services.Storage
lock (_surfaceConfigurations)
{
_surfaceRepository.Add(configuration.SurfaceEntity);
SaveToRepository(configuration, true);
UpdateSurfaceConfiguration(configuration, true);
return configuration;
}
}
public void SetActiveSurfaceConfiguration(SurfaceConfiguration surfaceConfiguration)
{
if (ActiveSurfaceConfiguration == surfaceConfiguration)
return;
// Set the new configuration
ActiveSurfaceConfiguration = surfaceConfiguration;
// Ensure only the new configuration is marked as active
lock (_surfaceConfigurations)
{
// Mark only the new surfaceConfiguration as active
foreach (var configuration in _surfaceConfigurations)
{
configuration.IsActive = configuration == ActiveSurfaceConfiguration;
configuration.ApplyToEntity();
}
_surfaceRepository.Save();
}
// Apply the active surface configuration to the devices
if (ActiveSurfaceConfiguration != null)
{
foreach (var deviceConfiguration in ActiveSurfaceConfiguration.DeviceConfigurations)
deviceConfiguration.ApplyToDevice();
}
// Update the RGB service's graphics decorator to work with the new surface configuration
_rgbService.UpdateGraphicsDecorator();
OnActiveSurfaceConfigurationChanged(new SurfaceConfigurationEventArgs(ActiveSurfaceConfiguration));
}
public void UpdateSurfaceConfiguration(SurfaceConfiguration surfaceConfiguration, bool includeDevices)
{
surfaceConfiguration.ApplyToEntity();
if (includeDevices)
{
foreach (var deviceConfiguration in surfaceConfiguration.DeviceConfigurations)
{
deviceConfiguration.ApplyToEntity();
if (surfaceConfiguration.IsActive)
deviceConfiguration.ApplyToDevice();
}
}
_surfaceRepository.Save();
_rgbService.UpdateGraphicsDecorator();
OnSurfaceConfigurationUpdated(new SurfaceConfigurationEventArgs(surfaceConfiguration));
}
public void DeleteSurfaceConfiguration(SurfaceConfiguration surfaceConfiguration)
{
if (surfaceConfiguration == ActiveSurfaceConfiguration)
@ -120,7 +140,7 @@ namespace Artemis.Core.Services.Storage
MatchDeviceConfiguration(e.Device, surfaceConfiguration);
}
foreach (var deviceConfiguration in ActiveSurfaceConfiguration.DeviceConfigurations)
foreach (var deviceConfiguration in ActiveSurfaceConfiguration.DeviceConfigurations)
deviceConfiguration.ApplyToDevice();
}
@ -152,33 +172,6 @@ namespace Artemis.Core.Services.Storage
ActiveSurfaceConfiguration = active;
}
public void SaveToRepository(List<SurfaceConfiguration> surfaceConfigurations, bool includeDevices)
{
foreach (var surfaceConfiguration in surfaceConfigurations)
{
surfaceConfiguration.ApplyToEntity();
if (!includeDevices)
{
foreach (var deviceConfiguration in surfaceConfiguration.DeviceConfigurations)
deviceConfiguration.ApplyToEntity();
}
}
_surfaceRepository.Save();
}
public void SaveToRepository(SurfaceConfiguration surfaceConfiguration, bool includeDevices)
{
surfaceConfiguration.ApplyToEntity();
if (includeDevices)
{
foreach (var deviceConfiguration in surfaceConfiguration.DeviceConfigurations)
deviceConfiguration.ApplyToEntity();
}
_surfaceRepository.Save();
}
#endregion
#region Utilities
@ -217,12 +210,18 @@ namespace Artemis.Core.Services.Storage
#region Events
public event EventHandler<SurfaceConfigurationEventArgs> ActiveSurfaceConfigurationChanged;
public event EventHandler<SurfaceConfigurationEventArgs> SurfaceConfigurationUpdated;
protected virtual void OnActiveSurfaceConfigurationChanged(SurfaceConfigurationEventArgs e)
{
ActiveSurfaceConfigurationChanged?.Invoke(this, e);
}
protected virtual void OnSurfaceConfigurationUpdated(SurfaceConfigurationEventArgs e)
{
SurfaceConfigurationUpdated?.Invoke(this, e);
}
#endregion
}
}

View File

@ -152,6 +152,11 @@
<Compile Include="Extensions\RgbColorExtensions.cs" />
<Compile Include="Extensions\RgbRectangleExtensions.cs" />
<Compile Include="Ninject\UIModule.cs" />
<Compile Include="Properties\Resources.Designer.cs">
<AutoGen>True</AutoGen>
<DesignTime>True</DesignTime>
<DependentUpon>Resources.resx</DependentUpon>
</Compile>
<Compile Include="Services\Interfaces\IArtemisUIService.cs" />
<Compile Include="Stylet\ArtemisViewManager.cs" />
<Compile Include="Stylet\NinjectBootstrapper.cs" />
@ -214,11 +219,6 @@
<Compile Include="Properties\AssemblyInfo.cs">
<SubType>Code</SubType>
</Compile>
<Compile Include="Properties\Resources.Designer.cs">
<AutoGen>True</AutoGen>
<DesignTime>True</DesignTime>
<DependentUpon>Resources.resx</DependentUpon>
</Compile>
<Compile Include="Properties\Settings.Designer.cs">
<AutoGen>True</AutoGen>
<DependentUpon>Settings.settings</DependentUpon>
@ -226,6 +226,7 @@
</Compile>
<EmbeddedResource Include="Properties\Resources.resx">
<Generator>ResXFileCodeGenerator</Generator>
<SubType>Designer</SubType>
<LastGenOutput>Resources.Designer.cs</LastGenOutput>
</EmbeddedResource>
<None Include="packages.config" />

View File

@ -70,7 +70,7 @@ namespace Artemis.UI.ViewModels.Screens
if (activeConfig == null)
{
activeConfig = AddSurfaceConfiguration("Default");
_surfaceService.ActiveSurfaceConfiguration = activeConfig;
_surfaceService.SetActiveSurfaceConfiguration(activeConfig);
}
Execute.OnUIThread(() =>
@ -106,7 +106,7 @@ namespace Artemis.UI.ViewModels.Screens
});
});
_surfaceService.ActiveSurfaceConfiguration = SelectedSurfaceConfiguration;
_surfaceService.SetActiveSurfaceConfiguration(SelectedSurfaceConfiguration);
}
#region Overrides of Screen
@ -275,9 +275,7 @@ namespace Artemis.UI.ViewModels.Screens
}
else
{
foreach (var device in Devices)
device.DeviceConfiguration.ApplyToDevice();
_surfaceService.SaveToRepository(SelectedSurfaceConfiguration, true);
_surfaceService.UpdateSurfaceConfiguration(SelectedSurfaceConfiguration, true);
}
Mouse.OverrideCursor = null;