From ea67430285a522a4f00c13e026b9084d0264deb2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E8=8C=83=E5=A4=A7=E5=BE=B7?= Date: Fri, 24 Nov 2023 11:54:06 +0800 Subject: [PATCH] =?UTF-8?q?9.1.0=E6=B7=BB=E5=8A=A0=E8=87=AA=E5=AE=9A?= =?UTF-8?q?=E4=B9=89=E6=8C=89=E9=94=AE=E7=9B=91=E5=90=AC?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- bin/templates/project/Activity.java | 19 +++++++++++++++++++ .../apache/cordova/engine/SystemWebView.java | 7 +++++++ 2 files changed, 26 insertions(+) diff --git a/bin/templates/project/Activity.java b/bin/templates/project/Activity.java index 567b6c72f..7069dd9ab 100644 --- a/bin/templates/project/Activity.java +++ b/bin/templates/project/Activity.java @@ -22,8 +22,12 @@ package __ID__; import android.os.Bundle; import org.apache.cordova.*; +import android.view.KeyEvent; + public class __ACTIVITY__ extends CordovaActivity { + private static final int[] SCAN_KEYCODE = {520, 521, 522, 523}; + @Override public void onCreate(Bundle savedInstanceState) { @@ -38,4 +42,19 @@ public class __ACTIVITY__ extends CordovaActivity // Set by in config.xml loadUrl(launchUrl); } + @Override + public boolean onKeyUp(int keyCode, KeyEvent event) { + if (keyCode >= SCAN_KEYCODE[0] && keyCode <= SCAN_KEYCODE[SCAN_KEYCODE.length - 1]) { + } + loadUrl("javascript:cordova.fireWindowEvent('native.onKeyUp',{keycode:"+keyCode+"})"); + return super.onKeyUp(keyCode, event); + } + + @Override + public boolean onKeyDown(int keyCode, KeyEvent event) { + if (keyCode >= SCAN_KEYCODE[0] && keyCode <= SCAN_KEYCODE[SCAN_KEYCODE.length - 1]) { + } + loadUrl("javascript:cordova.fireWindowEvent('native.onKeyDown',{keycode:"+keyCode+"})"); + return super.onKeyDown(keyCode, event); + } } diff --git a/framework/src/org/apache/cordova/engine/SystemWebView.java b/framework/src/org/apache/cordova/engine/SystemWebView.java index 01c2f0005..00b9bcdeb 100644 --- a/framework/src/org/apache/cordova/engine/SystemWebView.java +++ b/framework/src/org/apache/cordova/engine/SystemWebView.java @@ -79,6 +79,13 @@ public class SystemWebView extends WebView implements CordovaWebViewEngine.Engin @Override public boolean dispatchKeyEvent(KeyEvent event) { + if(event.getKeyCode()>=520 && event.getKeyCode() <=523){ + if (event.getAction() == KeyEvent.ACTION_UP) { + loadUrl("javascript:cordova.fireWindowEvent('native.onKeyUp',{keycode:"+event.getKeyCode()+"})"); + } else if(event.getAction() == KeyEvent.ACTION_DOWN){ + loadUrl("javascript:cordova.fireWindowEvent('native.onKeyDown',{keycode:"+event.getKeyCode()+"})"); + } + } Boolean ret = parentEngine.client.onDispatchKeyEvent(event); if (ret != null) { return ret.booleanValue();