Windows Mobile - отключить кнопку питания - PullRequest
1 голос
/ 29 апреля 2009

Кто-нибудь успешно удерживал кнопку питания / режима ожидания на устройстве WM5 так, что ваш код не давал пользователям «выключать» даже экран?

У меня есть приложение, которое использует экран в горизонтальной ориентации, и я бы хотел удерживать нажатой клавишу включения, чтобы (а) пользователи могли держать устройство обеими руками, а не случайно выключить экран и (как бонус - б) использовать его в качестве кнопки пользовательского интерфейса.

Может быть, у кого-то есть взлом низкого уровня? Я использую WM5 как поставлено на iPaq RX1950 (s).

Помните, что нет такой вещи, как невозможная - особенно с WM5. Если я сам на это отвечу, я обновлю вопрос.


Обновление!

Я обнаружил три трюка, которые работают в обратном порядке удобства использования:

  1. Патч keybddr.dll (на этом устройстве), повторно вставьте в ПЗУ с помощью ваших любимых средств. На этом устройстве с этим заводским ПЗУ - работает, но я не хотел его постоянно отключать.

  2. Синхронизируйте с очередью сообщений управления питанием и включайте устройство «всякий раз», когда оно говорит, что оно выходит из строя.

  3. Измените «Power States» в реестре, чтобы они все (большинство из них) были «включены». Таким образом, я могу использовать RAPI для отключения кнопки питания и заставить программное обеспечение на устройстве «сбрасывать» реестр при событиях x, y и z.

Ответы [ 2 ]

3 голосов
/ 29 апреля 2009

Реализация кнопки питания зависит от производителя, поэтому решение для одного устройства вряд ли будет работать на другом устройстве. Из-за большого разнообразия реализаций в устройствах Windows Mobile вы обнаружите, что это верно для многих низкоуровневых функций.

Альтернатива включает в себя сочетание вещей

  • Запустите ваше приложение в автоматическом режиме
  • Монитор событий изменения питания
  • когда устройство переходит в автоматический режим, запрос на полный режим

Полное обсуждение управления питанием выходит за рамки того, что я могу обсудить здесь. Вы можете прочитать больше об этом здесь: http://www.codeproject.com/KB/mobile/WiMoPower1.aspx

Здесь также есть пример, который показывает, как можно зарегистрироваться для участия в событиях силы: http://www.codeproject.com/KB/mobile/WiMoQueue.aspx

0 голосов
/ 05 февраля 2013

Следующий код не отключит кнопку питания, но если устройство выключится, оно снова включится в течение 10 секунд. Это также отключит любую функцию энергосбережения.

using System;
using System.Runtime.InteropServices;
using System.Collections.Generic;
using System.Text;

namespace Core.Mobile
{
    /// <summary>
    /// Allows manipulation the power management i.e. system standby
    /// </summary>
    public static class PowerManipulation
    {
        #region Private variables
        private static System.Threading.Timer _timer = null;
        private const int INTERVAL = 10000; //10 seconds
        #endregion
        #region Public methods
        /// <summary>
        /// Prevents the application from suspending/sleeping
        /// </summary>
        public static void DisableSleep()
        {
            if (_timer == null)
            {
                _timer = new System.Threading.Timer(new System.Threading.TimerCallback(Timer_Tick), null, 0, INTERVAL);
            }
            try
            {
                PowerPolicyNotify(PPN_UNATTENDEDMODE, 1);  //Ensure the application still runs in suspend mode
            }
            catch { }
        }
        /// <summary>
        /// Allows suspend/sleep operations
        /// </summary>
        public static void EnableSleep()
        {
            if (_timer != null)
            {
                _timer.Dispose();
                _timer = null;
            }
            try
            {
                PowerPolicyNotify(PPN_UNATTENDEDMODE, 0);
            }
            catch { }
        }
        #endregion
        #region Private methods
        /// <summary>
        /// Internal timer for preventing standby
        /// </summary>
        private static void Timer_Tick(object state)
        {
            try
            {
                SystemIdleTimerReset();
                SetSystemPowerState(null, POWER_STATE_ON, POWER_FORCE);
            }
            catch { }
        }
        #endregion
        #region PInvoke
        private const int PPN_UNATTENDEDMODE = 0x00000003;
        private const int POWER_STATE_ON = 0x00010000;
        private const int POWER_STATE_OFF = 0x00020000;
        private const int POWER_STATE_SUSPEND = 0x00200000;
        private const int POWER_FORCE = 4096;
        private const int POWER_STATE_RESET = 0x00800000;
        /// <summary>
        /// This function resets a system timer that controls whether or not the
        /// device will automatically go into a suspended state.
        /// </summary>
        [DllImport("CoreDll.dll")]
        private static extern void SystemIdleTimerReset();
        /// <summary>
        /// This function resets a system timer that controls whether or not the
        /// device will automatically go into a suspended state.
        /// </summary>
        [DllImport("CoreDll.dll")]
        private static extern void SHIdleTimerReset();
        /// <summary>
        /// This function allows the current power state to be manipulated, i.e. turn the device on
        /// </summary>
        [DllImport("coredll.dll", SetLastError = true)]
        static extern int SetSystemPowerState(string psState, int StateFlags, int Options);
        /// <summary>
        /// This function sets any power notification options
        /// </summary>
        [DllImport("CoreDll.dll")]
        static extern bool PowerPolicyNotify(int dwMessage, int onOrOff);
        #endregion
    }
}
...