Windows 窗体中的电源管理

Windows 窗体应用程序可以利用 Windows 操作系统中的电源管理功能。 应用程序可以监视计算机的电源状态,并在发生状态更改时采取措施。 例如,如果应用程序在便携式计算机上运行,则可能希望在计算机的电池电量低于特定级别时禁用应用程序中的某些功能。

.NET Framework 提供一个 PowerModeChanged 事件,每当电源状态发生更改(例如用户暂停或恢复操作系统时或 AC 电源状态或电池状态发生更改时)。 SystemInformation 类的 PowerStatus 属性可用于查询当前状态,如以下代码示例所示。

public Form1()
{
    InitializeComponent();
    SystemEvents.PowerModeChanged += new PowerModeChangedEventHandler(SystemEvents_PowerModeChanged);
}

void SystemEvents_PowerModeChanged(object sender, PowerModeChangedEventArgs e)
{
    switch (SystemInformation.PowerStatus.BatteryChargeStatus)
    {
        case System.Windows.Forms.BatteryChargeStatus.Low:
            MessageBox.Show("Battery is running low.", "Low Battery", MessageBoxButtons.OK, MessageBoxIcon.Exclamation);
            break;
        case System.Windows.Forms.BatteryChargeStatus.Critical:
            MessageBox.Show("Battery is critcally low.", "Critical Battery", MessageBoxButtons.OK, MessageBoxIcon.Stop);
            break;
        default:
            // Battery is okay.
            break;
    }
}
Public Sub New()
    InitializeComponent()
    AddHandler Microsoft.Win32.SystemEvents.PowerModeChanged, AddressOf PowerModeChanged
End Sub

Private Sub PowerModeChanged(ByVal Sender As System.Object, ByVal e As Microsoft.Win32.PowerModeChangedEventArgs)
    Select Case SystemInformation.PowerStatus.BatteryChargeStatus
        Case BatteryChargeStatus.Low
            MessageBox.Show("Battery is running low.", "Low Battery", MessageBoxButtons.OK, _
                            System.Windows.Forms.MessageBoxIcon.Exclamation)
        Case BatteryChargeStatus.Critical
            MessageBox.Show("Battery is critically low.", "Critical Battery", MessageBoxButtons.OK, _
                            System.Windows.Forms.MessageBoxIcon.Stop)
        Case Else
            ' Battery is okay.
            Exit Select
    End Select
End Sub

除了 BatteryChargeStatus 枚举之外,PowerStatus 属性还包含用于确定电池容量(BatteryFullLifetime)和电池充电百分比(BatteryLifePercentBatteryLifeRemaining)的枚举。

可以使用 ApplicationSetSuspendState 方法将计算机置于休眠或挂起模式。 如果 force 参数设置为 false,操作系统会将事件广播给请求暂停权限的所有应用程序。 如果 disableWakeEvent 参数设置为 true,操作系统将禁用所有唤醒事件。

下面的代码示例演示如何将计算机置于休眠状态。

if (SystemInformation.PowerStatus.BatteryChargeStatus == System.Windows.Forms.BatteryChargeStatus.Critical)
{
    Application.SetSuspendState(PowerState.Hibernate, false, false);
}
If SystemInformation.PowerStatus.BatteryChargeStatus = System.Windows.Forms.BatteryChargeStatus.Critical Then
    Application.SetSuspendState(PowerState.Hibernate, False, False)
End If

另请参阅