添加模拟power key 动作

diff --git a/android/frameworks/base/services/java/com/android/server/power/PowerManagerService.java b/android/frameworks/base/services/java/com/android/server/power/PowerManagerService.java
index 090a9aa..de78261 100644
--- a/android/frameworks/base/services/java/com/android/server/power/PowerManagerService.java
+++ b/android/frameworks/base/services/java/com/android/server/power/PowerManagerService.java
@@ -72,6 +72,15 @@ import libcore.util.Objects;
 import com.mitac.android.common.*;
 import android.net.wifi.WifiManager;
 import java.io.FileWriter;
+//piano start
+import android.view.KeyEvent;
+import android.hardware.input.InputManager;
+
+import android.os.SystemProperties;
+import android.view.InputDevice;
+import android.view.InputEvent;
+import android.view.KeyCharacterMap;
+//piano end

 
 /**
  * The power manager service is responsible for coordinating power management
@@ -2435,11 +2444,34 @@ public final class PowerManagerService extends IPowerManager.Stub
             }
 
             if (mBatteryForceSleep != BatteryManager.BATTERY_WORK_FINE) {
+                sendKey(KeyEvent.KEYCODE_POWER, 1);//添加模拟power key 动作
+                SystemClock.sleep(1000);
+                Slog.i(USERTAG, "sleep 1s");

                 goToSleep(SystemClock.uptimeMillis(), PowerManager.GO_TO_SLEEP_REASON_USER);
             }
         }
     }
-
+//piano start
+    private boolean injectEventSync(KeyEvent event) {
+        final InputManager mInputManager = (InputManager)mContext.getSystemService(Context.INPUT_SERVICE);
+        return mInputManager.injectInputEvent(event, InputManager.INJECT_INPUT_EVENT_MODE_ASYNC);
+    }   
+    private boolean sendKey(int keyCode, int metaState) {
+        final long eventTime = SystemClock.uptimeMillis();
+        KeyEvent downEvent = KeyEvent.obtain(eventTime, eventTime, KeyEvent.ACTION_DOWN,
+                keyCode, 0, metaState, KeyCharacterMap.VIRTUAL_KEYBOARD, 0, 0,
+                InputDevice.SOURCE_KEYBOARD, null);
+        if (injectEventSync(downEvent)) {
+            KeyEvent upEvent = KeyEvent.obtain(eventTime, eventTime, KeyEvent.ACTION_UP,
+                    keyCode, 0, metaState, KeyCharacterMap.VIRTUAL_KEYBOARD, 0, 0,
+                    InputDevice.SOURCE_KEYBOARD, null);
+            if(injectEventSync(upEvent)) {
+                return true;
+            }
+        }
+        return false;
+    }
+//piano end  
 
     private final class BootCompletedReceiver extends BroadcastReceiver {
         @Override
         public void onReceive(Context context, Intent intent) {

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值