diff --git a/RGB.NET.Devices.Wooting/Enum/WootingPhysicalKeyboardLayout.cs b/RGB.NET.Devices.Wooting/Enum/WootingLayoutType.cs
similarity index 86%
rename from RGB.NET.Devices.Wooting/Enum/WootingPhysicalKeyboardLayout.cs
rename to RGB.NET.Devices.Wooting/Enum/WootingLayoutType.cs
index 07d830f..ddb10e4 100644
--- a/RGB.NET.Devices.Wooting/Enum/WootingPhysicalKeyboardLayout.cs
+++ b/RGB.NET.Devices.Wooting/Enum/WootingLayoutType.cs
@@ -11,9 +11,9 @@ namespace RGB.NET.Devices.Wooting.Enum
///
/// Shop states ANSI (US) and ISO (UK/German/Nodics) - https://wooting.store/collections/wooting-keyboards/products/wooting-two
///
- public enum WootingPhysicalKeyboardLayout
+ public enum WootingLayoutType
{
- US = 0,
- UK = 1
+ ANSI = 0,
+ ISO = 1
}
}
diff --git a/RGB.NET.Devices.Wooting/Generic/WootingRGBDeviceInfo.cs b/RGB.NET.Devices.Wooting/Generic/WootingRGBDeviceInfo.cs
index f217c00..16b3e92 100644
--- a/RGB.NET.Devices.Wooting/Generic/WootingRGBDeviceInfo.cs
+++ b/RGB.NET.Devices.Wooting/Generic/WootingRGBDeviceInfo.cs
@@ -33,6 +33,8 @@ namespace RGB.NET.Devices.Wooting.Generic
///
public WootingDeviceType WootingDeviceType { get; }
+ public WootingLayoutType WootingLayoutType { get; }
+
#endregion
#region Constructors
@@ -46,6 +48,7 @@ namespace RGB.NET.Devices.Wooting.Generic
{
this.DeviceType = deviceType;
this.WootingDeviceType = deviceInfo.DeviceType;
+ this.WootingLayoutType = deviceInfo.LayoutType;
Model = deviceInfo.Model;
DeviceName = DeviceHelper.CreateDeviceName(Manufacturer, Model);
diff --git a/RGB.NET.Devices.Wooting/Keyboard/WootingKeyboardLedMappings.cs b/RGB.NET.Devices.Wooting/Keyboard/WootingKeyboardLedMappings.cs
index 618f31c..bbc8e39 100644
--- a/RGB.NET.Devices.Wooting/Keyboard/WootingKeyboardLedMappings.cs
+++ b/RGB.NET.Devices.Wooting/Keyboard/WootingKeyboardLedMappings.cs
@@ -1,8 +1,8 @@
// ReSharper disable InconsistentNaming
-using System.Collections.Generic;
using RGB.NET.Core;
using RGB.NET.Devices.Wooting.Enum;
+using System.Collections.Generic;
namespace RGB.NET.Devices.Wooting.Keyboard
{
@@ -13,106 +13,8 @@ namespace RGB.NET.Devices.Wooting.Keyboard
{
#region Properties & Fields
- #region TKL
-
- private static readonly Dictionary TKL_US = new()
- {
- { LedId.Keyboard_Escape, (0,0) },
- { LedId.Keyboard_F1, (0,2) },
- { LedId.Keyboard_F2, (0,3) },
- { LedId.Keyboard_F3, (0,4) },
- { LedId.Keyboard_F4, (0,5) },
- { LedId.Keyboard_F5, (0,6) },
- { LedId.Keyboard_F6, (0,7) },
- { LedId.Keyboard_F7, (0,8) },
- { LedId.Keyboard_F8, (0,9) },
- { LedId.Keyboard_F9, (0,10) },
- { LedId.Keyboard_F10, (0,11) },
- { LedId.Keyboard_F11, (0,12) },
- { LedId.Keyboard_F12, (0,13) },
- { LedId.Keyboard_PrintScreen, (0,14) },
- { LedId.Keyboard_PauseBreak, (0,15) },
- { LedId.Keyboard_Custom1, (0,16) },
-
- { LedId.Keyboard_GraveAccentAndTilde, (1,0) },
- { LedId.Keyboard_1, (1,1) },
- { LedId.Keyboard_2, (1,2) },
- { LedId.Keyboard_3, (1,3) },
- { LedId.Keyboard_4, (1,4) },
- { LedId.Keyboard_5, (1,5) },
- { LedId.Keyboard_6, (1,6) },
- { LedId.Keyboard_7, (1,7) },
- { LedId.Keyboard_8, (1,8) },
- { LedId.Keyboard_9, (1,9) },
- { LedId.Keyboard_0, (1,10) },
- { LedId.Keyboard_MinusAndUnderscore, (1,11) },
- { LedId.Keyboard_EqualsAndPlus, (1,12) },
- { LedId.Keyboard_Backspace, (1,13) },
- { LedId.Keyboard_Insert, (1,14) },
- { LedId.Keyboard_Home, (1,15) },
- { LedId.Keyboard_PageUp, (1,16) },
-
- { LedId.Keyboard_Tab, (2,0) },
- { LedId.Keyboard_Q, (2,1) },
- { LedId.Keyboard_W, (2,2) },
- { LedId.Keyboard_E, (2,3) },
- { LedId.Keyboard_R, (2,4) },
- { LedId.Keyboard_T, (2,5) },
- { LedId.Keyboard_Y, (2,6) },
- { LedId.Keyboard_U, (2,7) },
- { LedId.Keyboard_I, (2,8) },
- { LedId.Keyboard_O, (2,9) },
- { LedId.Keyboard_P, (2,10) },
- { LedId.Keyboard_BracketLeft, (2,11) },
- { LedId.Keyboard_BracketRight, (2,12) },
- { LedId.Keyboard_Backslash, (2,13) },
- { LedId.Keyboard_Delete, (2,14) },
- { LedId.Keyboard_End, (2,15) },
- { LedId.Keyboard_PageDown, (2,16) },
-
- { LedId.Keyboard_CapsLock, (3,0) },
- { LedId.Keyboard_A, (3,1) },
- { LedId.Keyboard_S, (3,2) },
- { LedId.Keyboard_D, (3,3) },
- { LedId.Keyboard_F, (3,4) },
- { LedId.Keyboard_G, (3,5) },
- { LedId.Keyboard_H, (3,6) },
- { LedId.Keyboard_J, (3,7) },
- { LedId.Keyboard_K, (3,8) },
- { LedId.Keyboard_L, (3,9) },
- { LedId.Keyboard_SemicolonAndColon, (3,10) },
- { LedId.Keyboard_ApostropheAndDoubleQuote, (3,11) },
- { LedId.Keyboard_Enter, (3,13) },
-
- { LedId.Keyboard_LeftShift, (4,0) },
- { LedId.Keyboard_Z, (4,2) },
- { LedId.Keyboard_X, (4,3) },
- { LedId.Keyboard_C, (4,4) },
- { LedId.Keyboard_V, (4,5) },
- { LedId.Keyboard_B, (4,6) },
- { LedId.Keyboard_N, (4,7) },
- { LedId.Keyboard_M, (4,8) },
- { LedId.Keyboard_CommaAndLessThan, (4,9) },
- { LedId.Keyboard_PeriodAndBiggerThan, (4,10) },
- { LedId.Keyboard_SlashAndQuestionMark, (4,11) },
- { LedId.Keyboard_RightShift, (4,13) },
- { LedId.Keyboard_ArrowUp, (4,15) },
-
- { LedId.Keyboard_LeftCtrl, (5,0) },
- { LedId.Keyboard_LeftGui, (5,1) },
- { LedId.Keyboard_LeftAlt, (5,2) },
- { LedId.Keyboard_Space, (5,6) },
- { LedId.Keyboard_RightAlt, (5,10) },
- { LedId.Keyboard_RightGui, (5,11) },
- { LedId.Keyboard_Application, (5,12) },
- { LedId.Keyboard_RightCtrl, (5,13) },
- { LedId.Keyboard_ArrowLeft, (5,14) },
- { LedId.Keyboard_ArrowDown, (5,15) },
- { LedId.Keyboard_ArrowRight, (5,16) }
- };
-
- private static readonly Dictionary TKL_UK = new()
- {
+ private static readonly Dictionary TKL = new()
+ {
{ LedId.Keyboard_Escape, (0,0) },
{ LedId.Keyboard_F1, (0,2) },
{ LedId.Keyboard_F2, (0,3) },
@@ -209,129 +111,8 @@ namespace RGB.NET.Devices.Wooting.Keyboard
{ LedId.Keyboard_ArrowRight, (5,16) }
};
- #endregion
-
- #region Fullsize
-
- private static readonly Dictionary Fullsize_US = new()
- {
- { LedId.Keyboard_Escape, (0,0) },
- { LedId.Keyboard_F1, (0,2) },
- { LedId.Keyboard_F2, (0,3) },
- { LedId.Keyboard_F3, (0,4) },
- { LedId.Keyboard_F4, (0,5) },
- { LedId.Keyboard_F5, (0,6) },
- { LedId.Keyboard_F6, (0,7) },
- { LedId.Keyboard_F7, (0,8) },
- { LedId.Keyboard_F8, (0,9) },
- { LedId.Keyboard_F9, (0,10) },
- { LedId.Keyboard_F10, (0,11) },
- { LedId.Keyboard_F11, (0,12) },
- { LedId.Keyboard_F12, (0,13) },
- { LedId.Keyboard_PrintScreen, (0,14) },
- { LedId.Keyboard_PauseBreak, (0,15) },
- { LedId.Keyboard_ScrollLock, (0,16) },
- { LedId.Keyboard_Custom1, (0,17) },
- { LedId.Keyboard_Custom2, (0,18) },
- { LedId.Keyboard_Custom3, (0,19) },
- { LedId.Keyboard_Custom4, (0,20) },
-
- { LedId.Keyboard_GraveAccentAndTilde, (1,0) },
- { LedId.Keyboard_1, (1,1) },
- { LedId.Keyboard_2, (1,2) },
- { LedId.Keyboard_3, (1,3) },
- { LedId.Keyboard_4, (1,4) },
- { LedId.Keyboard_5, (1,5) },
- { LedId.Keyboard_6, (1,6) },
- { LedId.Keyboard_7, (1,7) },
- { LedId.Keyboard_8, (1,8) },
- { LedId.Keyboard_9, (1,9) },
- { LedId.Keyboard_0, (1,10) },
- { LedId.Keyboard_MinusAndUnderscore, (1,11) },
- { LedId.Keyboard_EqualsAndPlus, (1,12) },
- { LedId.Keyboard_Backspace, (1,13) },
- { LedId.Keyboard_Insert, (1,14) },
- { LedId.Keyboard_Home, (1,15) },
- { LedId.Keyboard_PageUp, (1,16) },
- { LedId.Keyboard_NumLock, (1,17) },
- { LedId.Keyboard_NumSlash, (1,18) },
- { LedId.Keyboard_NumAsterisk, (1,19) },
- { LedId.Keyboard_NumMinus, (1,20) },
-
- { LedId.Keyboard_Tab, (2,0) },
- { LedId.Keyboard_Q, (2,1) },
- { LedId.Keyboard_W, (2,2) },
- { LedId.Keyboard_E, (2,3) },
- { LedId.Keyboard_R, (2,4) },
- { LedId.Keyboard_T, (2,5) },
- { LedId.Keyboard_Y, (2,6) },
- { LedId.Keyboard_U, (2,7) },
- { LedId.Keyboard_I, (2,8) },
- { LedId.Keyboard_O, (2,9) },
- { LedId.Keyboard_P, (2,10) },
- { LedId.Keyboard_BracketLeft, (2,11) },
- { LedId.Keyboard_BracketRight, (2,12) },
- { LedId.Keyboard_Backslash, (2,13) },
- { LedId.Keyboard_Delete, (2,14) },
- { LedId.Keyboard_End, (2,15) },
- { LedId.Keyboard_PageDown, (2,16) },
- { LedId.Keyboard_Num7, (2,17) },
- { LedId.Keyboard_Num8, (2,18) },
- { LedId.Keyboard_Num9, (2,19) },
- { LedId.Keyboard_NumPlus, (2,20) },
-
- { LedId.Keyboard_CapsLock, (3,0) },
- { LedId.Keyboard_A, (3,1) },
- { LedId.Keyboard_S, (3,2) },
- { LedId.Keyboard_D, (3,3) },
- { LedId.Keyboard_F, (3,4) },
- { LedId.Keyboard_G, (3,5) },
- { LedId.Keyboard_H, (3,6) },
- { LedId.Keyboard_J, (3,7) },
- { LedId.Keyboard_K, (3,8) },
- { LedId.Keyboard_L, (3,9) },
- { LedId.Keyboard_SemicolonAndColon, (3,10) },
- { LedId.Keyboard_ApostropheAndDoubleQuote, (3,11) },
- { LedId.Keyboard_Enter, (3,13) },
- { LedId.Keyboard_Num4, (3,17) },
- { LedId.Keyboard_Num5, (3,18) },
- { LedId.Keyboard_Num6, (3,19) },
-
- { LedId.Keyboard_LeftShift, (4,0) },
- { LedId.Keyboard_Z, (4,2) },
- { LedId.Keyboard_X, (4,3) },
- { LedId.Keyboard_C, (4,4) },
- { LedId.Keyboard_V, (4,5) },
- { LedId.Keyboard_B, (4,6) },
- { LedId.Keyboard_N, (4,7) },
- { LedId.Keyboard_M, (4,8) },
- { LedId.Keyboard_CommaAndLessThan, (4,9) },
- { LedId.Keyboard_PeriodAndBiggerThan, (4,10) },
- { LedId.Keyboard_SlashAndQuestionMark, (4,11) },
- { LedId.Keyboard_RightShift, (4,13) },
- { LedId.Keyboard_ArrowUp, (4,15) },
- { LedId.Keyboard_Num1, (4,17) },
- { LedId.Keyboard_Num2, (4,18) },
- { LedId.Keyboard_Num3, (4,19) },
- { LedId.Keyboard_NumEnter, (4,20) },
-
- { LedId.Keyboard_LeftCtrl, (5,0) },
- { LedId.Keyboard_LeftGui, (5,1) },
- { LedId.Keyboard_LeftAlt, (5,2) },
- { LedId.Keyboard_Space, (5,6) },
- { LedId.Keyboard_RightAlt, (5,10) },
- { LedId.Keyboard_RightGui, (5,11) },
- { LedId.Keyboard_Application, (5,12) },
- { LedId.Keyboard_RightCtrl, (5,13) },
- { LedId.Keyboard_ArrowLeft, (5,14) },
- { LedId.Keyboard_ArrowDown, (5,15) },
- { LedId.Keyboard_ArrowRight, (5,16) },
- { LedId.Keyboard_Num0, (5,18) },
- { LedId.Keyboard_NumPeriodAndDelete, (5,19) }
- };
-
- private static readonly Dictionary Fullsize_UK = new()
- {
+ private static readonly Dictionary Fullsize = new()
+ {
{ LedId.Keyboard_Escape, (0,0) },
{ LedId.Keyboard_F1, (0,2) },
{ LedId.Keyboard_F2, (0,3) },
@@ -449,28 +230,14 @@ namespace RGB.NET.Devices.Wooting.Keyboard
{ LedId.Keyboard_NumPeriodAndDelete, (5,19) }
};
- #endregion
-
///
/// Contains all the hardware-id mappings for Wooting devices.
///
- public static readonly Dictionary>> Mapping =
- new()
- {
- { WootingDeviceType.KeyboardTKL, new Dictionary>
- {
- { WootingPhysicalKeyboardLayout.US, TKL_US },
- { WootingPhysicalKeyboardLayout.UK, TKL_UK }
- }
- },
-
- { WootingDeviceType.Keyboard, new Dictionary>
- {
- { WootingPhysicalKeyboardLayout.US, Fullsize_US },
- { WootingPhysicalKeyboardLayout.UK, Fullsize_UK }
- }
- }
- };
+ public static readonly Dictionary> Mapping = new()
+ {
+ [WootingDeviceType.Keyboard] = Fullsize,
+ [WootingDeviceType.KeyboardTKL] = TKL
+ };
#endregion
}
diff --git a/RGB.NET.Devices.Wooting/Keyboard/WootingKeyboardRGBDevice.cs b/RGB.NET.Devices.Wooting/Keyboard/WootingKeyboardRGBDevice.cs
index cace6cd..2edad16 100644
--- a/RGB.NET.Devices.Wooting/Keyboard/WootingKeyboardRGBDevice.cs
+++ b/RGB.NET.Devices.Wooting/Keyboard/WootingKeyboardRGBDevice.cs
@@ -37,15 +37,14 @@ namespace RGB.NET.Devices.Wooting.Keyboard
private void InitializeLayout()
{
- //TODO DarthAffe 13.02.2021: Check how the mapping can work without knowing the physical layout
- Dictionary mapping = WootingKeyboardLedMappings.Mapping[DeviceInfo.WootingDeviceType][WootingPhysicalKeyboardLayout.US];
+ Dictionary mapping = WootingKeyboardLedMappings.Mapping[DeviceInfo.WootingDeviceType];
foreach (KeyValuePair led in mapping)
AddLed(led.Key, new Point(led.Value.column * 19, led.Value.row * 19), new Size(19, 19));
}
///
- protected override object GetLedCustomData(LedId ledId) => WootingKeyboardLedMappings.Mapping[DeviceInfo.WootingDeviceType][WootingPhysicalKeyboardLayout.US][ledId];
+ protected override object GetLedCustomData(LedId ledId) => WootingKeyboardLedMappings.Mapping[DeviceInfo.WootingDeviceType][ledId];
///
protected override void UpdateLeds(IEnumerable ledsToUpdate) => UpdateQueue.SetData(GetUpdateData(ledsToUpdate));
diff --git a/RGB.NET.Devices.Wooting/Keyboard/WootingKeyboardRGBDeviceInfo.cs b/RGB.NET.Devices.Wooting/Keyboard/WootingKeyboardRGBDeviceInfo.cs
index abfe5dd..4a64690 100644
--- a/RGB.NET.Devices.Wooting/Keyboard/WootingKeyboardRGBDeviceInfo.cs
+++ b/RGB.NET.Devices.Wooting/Keyboard/WootingKeyboardRGBDeviceInfo.cs
@@ -13,7 +13,7 @@ namespace RGB.NET.Devices.Wooting.Keyboard
#region Properties & Fields
///
- public KeyboardLayoutType Layout => KeyboardLayoutType.Unknown;
+ public KeyboardLayoutType Layout { get; }
#endregion
@@ -26,7 +26,14 @@ namespace RGB.NET.Devices.Wooting.Keyboard
/// The native .
internal WootingKeyboardRGBDeviceInfo(_WootingDeviceInfo deviceInfo)
: base(RGBDeviceType.Keyboard, deviceInfo)
- { }
+ {
+ Layout = WootingLayoutType switch
+ {
+ WootingLayoutType.ANSI => KeyboardLayoutType.ANSI,
+ WootingLayoutType.ISO => KeyboardLayoutType.ISO,
+ _ => KeyboardLayoutType.Unknown
+ };
+ }
#endregion
}
diff --git a/RGB.NET.Devices.Wooting/Native/_WootingDeviceInfo.cs b/RGB.NET.Devices.Wooting/Native/_WootingDeviceInfo.cs
index fab57c6..dd4bbed 100644
--- a/RGB.NET.Devices.Wooting/Native/_WootingDeviceInfo.cs
+++ b/RGB.NET.Devices.Wooting/Native/_WootingDeviceInfo.cs
@@ -22,5 +22,7 @@ namespace RGB.NET.Devices.Wooting.Native
internal WootingDeviceType DeviceType { get; private set; }
internal bool V2Interface { get; set; }
+
+ internal WootingLayoutType LayoutType { get; private set; }
}
}