WinHelper.cs 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. using SWRIS.Enums;
  2. using System.Runtime.InteropServices;
  3. namespace SWRIS.Extensions
  4. {
  5. /// <summary>
  6. /// 包含控制屏幕关闭以及系统休眠相关的方法。
  7. /// </summary>
  8. public static class SystemSleep
  9. {
  10. /// <summary>
  11. /// Enables an application to inform the system that it is in use, thereby preventing the system from entering sleep or turning off the display while the application is running.
  12. /// </summary>
  13. [DllImport("kernel32")]
  14. private static extern ExecutionState SetThreadExecutionState(ExecutionState esFlags);
  15. /// <summary>
  16. /// 设置此线程此时开始一直将处于运行状态,此时计算机不应该进入睡眠状态。
  17. /// 此线程退出后,设置将失效。
  18. /// 如果需要恢复,请调用 <see cref="RestoreForCurrentThread"/> 方法。
  19. /// </summary>
  20. /// <param name="keepDisplayOn">
  21. /// 表示是否应该同时保持屏幕不关闭。
  22. /// 对于游戏、视频和演示相关的任务需要保持屏幕不关闭;而对于后台服务、下载和监控等任务则不需要。
  23. /// </param>
  24. public static void PreventForCurrentThread(bool keepDisplayOn = true)
  25. {
  26. SetThreadExecutionState(keepDisplayOn
  27. ? ExecutionState.Continuous | ExecutionState.SystemRequired | ExecutionState.DisplayRequired
  28. : ExecutionState.Continuous | ExecutionState.SystemRequired);
  29. }
  30. /// <summary>
  31. /// 恢复此线程的运行状态,操作系统现在可以正常进入睡眠状态和关闭屏幕。
  32. /// </summary>
  33. public static void RestoreForCurrentThread()
  34. {
  35. SetThreadExecutionState(ExecutionState.Continuous);
  36. }
  37. /// <summary>
  38. /// 重置系统睡眠或者关闭屏幕的计时器,这样系统睡眠或者屏幕能够继续持续工作设定的超时时间。
  39. /// </summary>
  40. /// <param name="keepDisplayOn">
  41. /// 表示是否应该同时保持屏幕不关闭。
  42. /// 对于游戏、视频和演示相关的任务需要保持屏幕不关闭;而对于后台服务、下载和监控等任务则不需要。
  43. /// </param>
  44. public static void ResetIdle(bool keepDisplayOn = true)
  45. {
  46. SetThreadExecutionState(keepDisplayOn
  47. ? ExecutionState.SystemRequired | ExecutionState.DisplayRequired
  48. : ExecutionState.SystemRequired);
  49. }
  50. }
  51. }