mirror of
https://github.com/Artemis-RGB/Artemis
synced 2025-12-13 05:48:35 +00:00
151 lines
5.7 KiB
C#
151 lines
5.7 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using Artemis.Core.SkiaSharp;
|
|
using RGB.NET.Core;
|
|
|
|
namespace Artemis.Core.Services
|
|
{
|
|
/// <summary>
|
|
/// A service that allows you to manage the <see cref="RGBSurface" /> and its contents
|
|
/// </summary>
|
|
public interface IRgbService : IArtemisService, IDisposable
|
|
{
|
|
/// <summary>
|
|
/// Gets a read-only collection containing all enabled devices
|
|
/// </summary>
|
|
IReadOnlyCollection<ArtemisDevice> EnabledDevices { get; }
|
|
|
|
/// <summary>
|
|
/// Gets a read-only collection containing all registered devices
|
|
/// </summary>
|
|
IReadOnlyCollection<ArtemisDevice> Devices { get; }
|
|
|
|
/// <summary>
|
|
/// Gets a dictionary containing all <see cref="ArtemisLed" />s on the surface with their corresponding RGB.NET
|
|
/// <see cref="Led" /> as key
|
|
/// </summary>
|
|
IReadOnlyDictionary<Led, ArtemisLed> LedMap { get; }
|
|
|
|
/// <summary>
|
|
/// Gets or sets the RGB surface rendering is performed on
|
|
/// </summary>
|
|
RGBSurface Surface { get; set; }
|
|
|
|
/// <summary>
|
|
/// Gets or sets whether rendering should be paused
|
|
/// </summary>
|
|
bool IsRenderPaused { get; set; }
|
|
|
|
/// <summary>
|
|
/// Gets a boolean indicating whether the render pipeline is open
|
|
/// </summary>
|
|
bool RenderOpen { get; }
|
|
|
|
/// <summary>
|
|
/// Opens the render pipeline
|
|
/// </summary>
|
|
SKTexture OpenRender();
|
|
|
|
/// <summary>
|
|
/// Closes the render pipeline
|
|
/// </summary>
|
|
void CloseRender();
|
|
|
|
/// <summary>
|
|
/// Updates the graphics context to the provided <paramref name="managedGraphicsContext"></paramref>.
|
|
/// <para>Note: The old graphics context will be used until the next frame starts rendering and is disposed afterwards.</para>
|
|
/// </summary>
|
|
/// <param name="managedGraphicsContext">
|
|
/// The new managed graphics context. If <see langword="null" />, software rendering
|
|
/// is used.
|
|
/// </param>
|
|
void UpdateGraphicsContext(IManagedGraphicsContext? managedGraphicsContext);
|
|
|
|
/// <summary>
|
|
/// Adds the given device provider to the <see cref="Surface" />
|
|
/// </summary>
|
|
/// <param name="deviceProvider"></param>
|
|
void AddDeviceProvider(IRGBDeviceProvider deviceProvider);
|
|
|
|
/// <summary>
|
|
/// Removes the given device provider from the <see cref="Surface" />
|
|
/// </summary>
|
|
/// <param name="deviceProvider"></param>
|
|
void RemoveDeviceProvider(IRGBDeviceProvider deviceProvider);
|
|
|
|
/// <summary>
|
|
/// Applies auto-arranging logic to the surface
|
|
/// </summary>
|
|
void AutoArrangeDevices();
|
|
|
|
/// <summary>
|
|
/// Applies the best available layout for the given <see cref="ArtemisDevice" />
|
|
/// </summary>
|
|
/// <param name="device">The device to apply the best available layout to</param>
|
|
/// <returns>The layout that was applied to the device</returns>
|
|
ArtemisLayout ApplyBestDeviceLayout(ArtemisDevice device);
|
|
|
|
/// <summary>
|
|
/// Apples the provided <see cref="ArtemisLayout" /> to the provided <see cref="ArtemisDevice" />
|
|
/// </summary>
|
|
/// <param name="device"></param>
|
|
/// <param name="layout"></param>
|
|
void ApplyDeviceLayout(ArtemisDevice device, ArtemisLayout layout);
|
|
|
|
/// <summary>
|
|
/// Attempts to retrieve the <see cref="ArtemisDevice" /> that corresponds the provided RGB.NET
|
|
/// <see cref="IRGBDevice" />
|
|
/// </summary>
|
|
/// <param name="rgbDevice">
|
|
/// The RGB.NET <see cref="IRGBDevice" /> to find the corresponding <see cref="ArtemisDevice" />
|
|
/// for
|
|
/// </param>
|
|
/// <returns>If found, the corresponding <see cref="ArtemisDevice" />; otherwise <see langword="null" />.</returns>
|
|
ArtemisDevice? GetDevice(IRGBDevice rgbDevice);
|
|
|
|
/// <summary>
|
|
/// Attempts to retrieve the <see cref="ArtemisLed" /> that corresponds the provided RGB.NET <see cref="Led" />
|
|
/// </summary>
|
|
/// <param name="led">The RGB.NET <see cref="Led" /> to find the corresponding <see cref="ArtemisLed" /> for </param>
|
|
/// <returns>If found, the corresponding <see cref="ArtemisLed" />; otherwise <see langword="null" />.</returns>
|
|
ArtemisLed? GetLed(Led led);
|
|
|
|
/// <summary>
|
|
/// Saves the configuration of the provided device to persistent storage
|
|
/// </summary>
|
|
/// <param name="artemisDevice"></param>
|
|
void SaveDevice(ArtemisDevice artemisDevice);
|
|
|
|
/// <summary>
|
|
/// Saves the configuration of all current devices to persistent storage
|
|
/// </summary>
|
|
void SaveDevices();
|
|
|
|
/// <summary>
|
|
/// Enables the provided device
|
|
/// </summary>
|
|
/// <param name="device">The device to enable</param>
|
|
void EnableDevice(ArtemisDevice device);
|
|
|
|
/// <summary>
|
|
/// Disables the provided device
|
|
/// </summary>
|
|
/// <param name="device">The device to disable</param>
|
|
void DisableDevice(ArtemisDevice device);
|
|
|
|
/// <summary>
|
|
/// Occurs when a single device was added
|
|
/// </summary>
|
|
event EventHandler<DeviceEventArgs> DeviceAdded;
|
|
|
|
/// <summary>
|
|
/// Occurs when a single device was removed
|
|
/// </summary>
|
|
event EventHandler<DeviceEventArgs> DeviceRemoved;
|
|
|
|
/// <summary>
|
|
/// Occurs when the surface has had modifications to its LED collection
|
|
/// </summary>
|
|
event EventHandler LedsChanged;
|
|
}
|
|
} |