mirror of
https://github.com/jkocon/g-helper.git
synced 2026-02-23 13:00:52 +01:00
Charge limit will be applied every time powe mode changes (incl hibernate)
This commit is contained in:
@@ -35,7 +35,7 @@
|
|||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<PackageReference Include="hidlibrary" Version="3.3.40" />
|
<PackageReference Include="hidlibrary" Version="3.3.40" />
|
||||||
<PackageReference Include="LibreHardwareMonitorLib" Version="0.9.1" />
|
<PackageReference Include="System.Management" Version="7.0.0" />
|
||||||
<PackageReference Include="TaskScheduler" Version="2.10.1" />
|
<PackageReference Include="TaskScheduler" Version="2.10.1" />
|
||||||
<PackageReference Include="WinForms.DataVisualization" Version="1.7.0" />
|
<PackageReference Include="WinForms.DataVisualization" Version="1.7.0" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|||||||
102
Program.cs
102
Program.cs
@@ -1,7 +1,8 @@
|
|||||||
using LibreHardwareMonitor.Hardware;
|
using Microsoft.Win32;
|
||||||
using System.Diagnostics;
|
using System.Diagnostics;
|
||||||
using System.Management;
|
using System.Management;
|
||||||
using System.Security.Principal;
|
using System.Security.Principal;
|
||||||
|
using System.Text;
|
||||||
using System.Text.Json;
|
using System.Text.Json;
|
||||||
|
|
||||||
|
|
||||||
@@ -80,27 +81,9 @@ public class AppConfig
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public class UpdateVisitor : IVisitor
|
|
||||||
{
|
|
||||||
public void VisitComputer(IComputer computer)
|
|
||||||
{
|
|
||||||
computer.Traverse(this);
|
|
||||||
}
|
|
||||||
public void VisitHardware(IHardware hardware)
|
|
||||||
{
|
|
||||||
hardware.Update();
|
|
||||||
foreach (IHardware subHardware in hardware.SubHardware) subHardware.Accept(this);
|
|
||||||
}
|
|
||||||
public void VisitSensor(ISensor sensor) { }
|
|
||||||
public void VisitParameter(IParameter parameter) { }
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public class HardwareMonitor
|
public class HardwareMonitor
|
||||||
{
|
{
|
||||||
|
|
||||||
Computer computer;
|
|
||||||
|
|
||||||
public float? cpuTemp = -1;
|
public float? cpuTemp = -1;
|
||||||
public float? gpuTemp = -1;
|
public float? gpuTemp = -1;
|
||||||
@@ -121,73 +104,34 @@ public class HardwareMonitor
|
|||||||
public void ReadSensors()
|
public void ReadSensors()
|
||||||
{
|
{
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
if (computer is not Computer)
|
|
||||||
{
|
|
||||||
computer = new Computer
|
|
||||||
{
|
|
||||||
IsGpuEnabled = true,
|
|
||||||
IsBatteryEnabled = true,
|
|
||||||
};
|
|
||||||
|
|
||||||
if (IsAdministrator()) computer.IsCpuEnabled = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
computer.Open();
|
|
||||||
computer.Accept(new UpdateVisitor());
|
|
||||||
} catch
|
|
||||||
{
|
|
||||||
Debug.WriteLine("Failed to read sensors");
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
cpuTemp = -1;
|
cpuTemp = -1;
|
||||||
gpuTemp = -1;
|
gpuTemp = -1;
|
||||||
batteryDischarge = -1;
|
batteryDischarge = -1;
|
||||||
batteryCharge = -1;
|
|
||||||
|
|
||||||
foreach (IHardware hardware in computer.Hardware)
|
try
|
||||||
{
|
{
|
||||||
//Debug.WriteLine("Hardware: {0}", hardware.Name);
|
|
||||||
//Debug.WriteLine("Hardware: {0}", hardware.HardwareType);
|
|
||||||
|
|
||||||
foreach (ISensor sensor in hardware.Sensors)
|
if (cpuTemp < 0)
|
||||||
{
|
{
|
||||||
if (sensor.SensorType == SensorType.Temperature)
|
var ct = new PerformanceCounter("Thermal Zone Information", "Temperature", @"\_TZ.THRM", true);
|
||||||
{
|
cpuTemp = ct.NextValue() - 273;
|
||||||
if (hardware.HardwareType.ToString().Contains("Cpu") && sensor.Name.Contains("Core"))
|
ct.Dispose();
|
||||||
{
|
|
||||||
cpuTemp = sensor.Value;
|
|
||||||
//Debug.WriteLine("\tSensor: {0}, value: {1}", sensor.Name, sensor.Value);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hardware.HardwareType.ToString().Contains("Gpu") && sensor.Name.Contains("Core"))
|
|
||||||
{
|
|
||||||
gpuTemp = sensor.Value;
|
|
||||||
}
|
|
||||||
|
|
||||||
//Debug.WriteLine("\tSensor: {0}, value: {1}", sensor.Name, sensor.Value);
|
|
||||||
|
|
||||||
}
|
|
||||||
else if (sensor.SensorType == SensorType.Power)
|
|
||||||
{
|
|
||||||
if (sensor.Name.Contains("Discharge"))
|
|
||||||
{
|
|
||||||
batteryDischarge = sensor.Value;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (sensor.Name.Contains("Charge"))
|
|
||||||
{
|
|
||||||
batteryCharge = sensor.Value;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (batteryDischarge < 0)
|
||||||
|
{
|
||||||
|
var ct = new PerformanceCounter("Power Meter", "Power", "Power Meter (0)", true);
|
||||||
|
batteryDischarge = ct.NextValue() / 1000;
|
||||||
|
ct.Dispose();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
} catch
|
||||||
|
{
|
||||||
|
Debug.WriteLine("Failed reading sensors");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void StopReading()
|
public void StopReading()
|
||||||
@@ -240,6 +184,7 @@ namespace GHelper
|
|||||||
settingsForm.AutoGPUMode(isPlugged ? 1 : 0);
|
settingsForm.AutoGPUMode(isPlugged ? 1 : 0);
|
||||||
settingsForm.AutoScreen(isPlugged ? 1 : 0);
|
settingsForm.AutoScreen(isPlugged ? 1 : 0);
|
||||||
|
|
||||||
|
SystemEvents.PowerModeChanged += SystemEvents_PowerModeChanged;
|
||||||
|
|
||||||
IntPtr dummy = settingsForm.Handle;
|
IntPtr dummy = settingsForm.Handle;
|
||||||
|
|
||||||
@@ -247,6 +192,10 @@ namespace GHelper
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static void SystemEvents_PowerModeChanged(object sender, PowerModeChangedEventArgs e)
|
||||||
|
{
|
||||||
|
settingsForm.SetBatteryChargeLimit(config.getConfig("charge_limit"));
|
||||||
|
}
|
||||||
|
|
||||||
static void WatcherEventArrived(object sender, EventArrivedEventArgs e)
|
static void WatcherEventArrived(object sender, EventArrivedEventArgs e)
|
||||||
{
|
{
|
||||||
@@ -283,7 +232,6 @@ namespace GHelper
|
|||||||
});
|
});
|
||||||
return;
|
return;
|
||||||
case 88: // Plugged
|
case 88: // Plugged
|
||||||
settingsForm.SetBatteryChargeLimit(config.getConfig("charge_limit"));
|
|
||||||
settingsForm.BeginInvoke(delegate
|
settingsForm.BeginInvoke(delegate
|
||||||
{
|
{
|
||||||
settingsForm.AutoGPUMode(1);
|
settingsForm.AutoGPUMode(1);
|
||||||
|
|||||||
Reference in New Issue
Block a user