mirror of
https://github.com/jkocon/g-helper.git
synced 2026-02-23 13:00:52 +01:00
Ambient Aura tweaks
This commit is contained in:
@@ -359,22 +359,7 @@ namespace GHelper.USB
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void ApplyColor(Color color, bool init = false)
|
public static void ApplyColorStrix(Color[] color, bool init = false)
|
||||||
{
|
|
||||||
Color[] color_list = Enumerable.Repeat(color, 0x12).ToArray();
|
|
||||||
ApplyColor(color_list, init);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void ApplyColor(Color[] color, bool init = false)
|
|
||||||
{
|
|
||||||
|
|
||||||
if (isACPI)
|
|
||||||
{
|
|
||||||
Program.acpi.TUFKeyboardRGB(0, color[0], 0, null);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isStrix && !isOldHeatmap)
|
|
||||||
{
|
{
|
||||||
byte[] msg = new byte[0x40];
|
byte[] msg = new byte[0x40];
|
||||||
|
|
||||||
@@ -419,9 +404,24 @@ namespace GHelper.USB
|
|||||||
AsusHid.WriteAura(msg);
|
AsusHid.WriteAura(msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static void ApplyColor(Color color, bool init = false)
|
||||||
|
{
|
||||||
|
|
||||||
|
if (isACPI)
|
||||||
|
{
|
||||||
|
Program.acpi.TUFKeyboardRGB(0, color, 0, null);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isStrix && !isOldHeatmap)
|
||||||
|
{
|
||||||
|
ApplyColorStrix(Enumerable.Repeat(color, AURA_ZONES).ToArray(), init);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
AsusHid.WriteAura(AuraMessage(0, color[0], color[0], 0));
|
AsusHid.WriteAura(AuraMessage(0, color, color, 0));
|
||||||
AsusHid.WriteAura(MESSAGE_SET);
|
AsusHid.WriteAura(MESSAGE_SET);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -514,9 +514,11 @@ namespace GHelper.USB
|
|||||||
bound.Y += bound.Height / 3;
|
bound.Y += bound.Height / 3;
|
||||||
bound.Height -= (int)Math.Round(bound.Height * (0.33f + 0.022f)); // cut 1/3 of the top screen + windows panel
|
bound.Height -= (int)Math.Round(bound.Height * (0.33f + 0.022f)); // cut 1/3 of the top screen + windows panel
|
||||||
|
|
||||||
var screen_low = AmbientData.CamptureScreen(bound, 512, 288);
|
var screen_low = AmbientData.CamptureScreen(bound, 256, 144);
|
||||||
Bitmap screeb_pxl;
|
Bitmap screeb_pxl;
|
||||||
|
|
||||||
|
int zones = AURA_ZONES;
|
||||||
|
|
||||||
if (isStrix) //laptop with lightbar
|
if (isStrix) //laptop with lightbar
|
||||||
{
|
{
|
||||||
screeb_pxl = AmbientData.ResizeImage(screen_low, 4, 2); // 4x2 zone. top for keyboard and bot for lightbar
|
screeb_pxl = AmbientData.ResizeImage(screen_low, 4, 2); // 4x2 zone. top for keyboard and bot for lightbar
|
||||||
@@ -537,10 +539,9 @@ namespace GHelper.USB
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
zones = 1;
|
||||||
screeb_pxl = AmbientData.ResizeImage(screen_low, 1, 1);
|
screeb_pxl = AmbientData.ResizeImage(screen_low, 1, 1);
|
||||||
var average = ColorUtils.HSV.UpSaturation(screeb_pxl.GetPixel(0, 0), (float)0.3);
|
AmbientData.Colors[0].RGB = ColorUtils.HSV.UpSaturation(screeb_pxl.GetPixel(0, 0), (float)0.3);
|
||||||
for (int i = 0; i < 4; i++) //just color transfer from the bottom screen on keyboard
|
|
||||||
AmbientData.Colors[i].RGB = average;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -550,15 +551,18 @@ namespace GHelper.USB
|
|||||||
|
|
||||||
bool is_fresh = false;
|
bool is_fresh = false;
|
||||||
|
|
||||||
for (int i = 0; i < AURA_ZONES; i++)
|
for (int i = 0; i < zones; i++)
|
||||||
{
|
{
|
||||||
if (AmbientData.result[i].ToArgb() != AmbientData.Colors[i].RGB.ToArgb())
|
if (AmbientData.result[i].ToArgb() != AmbientData.Colors[i].RGB.ToArgb()) is_fresh = true;
|
||||||
is_fresh = true;
|
|
||||||
AmbientData.result[i] = AmbientData.Colors[i].RGB;
|
AmbientData.result[i] = AmbientData.Colors[i].RGB;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (is_fresh)
|
if (is_fresh)
|
||||||
ApplyColor(AmbientData.result, init);
|
{
|
||||||
|
if (isStrix) ApplyColorStrix(AmbientData.result, init);
|
||||||
|
else ApplyColor(AmbientData.result[0], init);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static class AmbientData
|
static class AmbientData
|
||||||
|
|||||||
Reference in New Issue
Block a user