gpt4 book ai didi

使用 PhoneGap 从 Android 调用 Javascript

转载 作者:太空宇宙 更新时间:2023-11-03 11:40:08 25 4
gpt4 key购买 nike

我有一个用 PhoneGap 构建的应用程序,我正在尝试与 Javascript 进行通信来自 native 代码。

在我的 DroidGap扩展类:

@Override
public void onCreate(Bundle savedInstanceState) {
Logger.log("oncreate");
super.onCreate(savedInstanceState);
super.init();
super.appView.getSettings().setJavaScriptEnabled(true);
super.appView.getSettings().setSupportZoom(true);
super.appView.getSettings().setBuiltInZoomControls(true);
super.appView.getSettings().setDisplayZoomControls(false);
jsinterface = new CommunicationInterface(this, appView);
super.appView.addJavascriptInterface(jsinterface, "communicationinterface");
}

javascript接口(interface):

public class CommunicationInterface {
private WebView mAppView;
private DroidGap mGap;

public CommunicationInterface(DroidGap gap, WebView view) {
mAppView = view;
mGap = gap;
}

public String getTestString() {
return "teststring";
}

public void parse(Object o) {
Logger.log(o);
}
}

Javacript位于外部文件中(我创建了一个 HTML 文件,其中在 header 中包含此行:<script type="text/javascript" src="scripts.js"></script>)

Scripts.js :

function sendToInterface() {
alert("alert");
var map = new Object();
(...)
window.communicationinterface.parse(map); //communication js -> android seems to work.
}

我在其他帖子中读到可以在 PhoneGap 和 Android 之间进行通信,但到目前为止我还没有取得任何成功。我确实设法创建了一个警报,但那是 loadUrl("javascript:alert('Alert');") , 但我也读到你不应该这样做,因为那是 sendJavascript()是为了(它会导致泄漏、重新加载页面等)。我试图通过 sendJavascript() 射出几根弦方法,但无济于事:

  • sendJavascript("javascript:alert('Alert');")
  • sendJavascript("javascript:sendToInterface();")
  • sendJavascript("sendToInterface();")
  • sendJavascript("window.sendToInterface();")

如何从 native -> PhoneGap 进行通信(或者我已有的有什么问题)?到目前为止,其他帖子和问题都没有帮助我解决这个特殊问题。

阅读:

编辑

我写了一个工作项目:

Java部分

import org.apache.cordova.DroidGap;
import org.json.JSONException;
import org.json.JSONObject;

import android.os.Bundle;
import android.util.Log;

public class App extends DroidGap {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
super.loadUrl("file:///sdcard/ds/index.html");
System.out.println("loading from sdcard");
Thread t = new Thread() {
public void run() {
try {
for (int i = 0; i < 3; i++) {
sleep(2000);
sendValue("value " + i, "another vlaue " + i);
}
} catch (Exception e) {
e.printStackTrace();
}
};
};
t.start();
}

public void sendValue(String value1, String value2) {

System.out.println("sendvalue in app");
JSONObject data = new JSONObject();
try {
data.put("value1", value1);
data.put("value2", value2);
} catch (JSONException e) {
Log.e("CommTest", e.getMessage());
}
String js = String.format("window.plugins.appcomm.updateValues('%s');",
data.toString());
this.sendJavascript(js);
}
}

import org.apache.cordova.api.Plugin;
import org.apache.cordova.api.PluginResult;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

import android.util.Log;

public class AppComm extends Plugin{

private static AppComm instance;

public AppComm () {
instance = this;
}

public static AppComm getInstance() {
return instance;
}

@Override
public PluginResult execute(String action, JSONArray args, String callbackId) {
System.out.println("in execute from appcomm");


return null;
}

public void sendValue(String value1, String value2) {
System.out.println("sendvalue in appComm");
JSONObject data = new JSONObject();
try {
data.put("value1", value1);
data.put("value2", value2);
} catch (JSONException e) {
Log.e("CommTest", e.getMessage());
}
String js = String.format(
"window.plugins.commtest.updateValues('%s');",
data.toString());
this.sendJavascript(js);
}
}

res/xml/plugins.xml

<plugins>
<plugin name="App" value="org.apache.cordova.App"/>
<plugin name="Geolocation" value="org.apache.cordova.GeoBroker"/>
<plugin name="Device" value="org.apache.cordova.Device"/>
<plugin name="Accelerometer" value="org.apache.cordova.AccelListener"/>
<plugin name="Compass" value="org.apache.cordova.CompassListener"/>
<plugin name="Media" value="org.apache.cordova.AudioHandler"/>
<plugin name="Camera" value="org.apache.cordova.CameraLauncher"/>
<plugin name="Contacts" value="org.apache.cordova.ContactManager"/>
<plugin name="File" value="org.apache.cordova.FileUtils"/>
<plugin name="NetworkStatus" value="org.apache.cordova.NetworkManager"/>
<plugin name="Notification" value="org.apache.cordova.Notification"/>
<plugin name="Storage" value="org.apache.cordova.Storage"/>
<plugin name="Temperature" value="org.apache.cordova.TempListener"/>
<plugin name="FileTransfer" value="org.apache.cordova.FileTransfer"/>
<plugin name="Capture" value="org.apache.cordova.Capture"/>
<plugin name="Battery" value="org.apache.cordova.BatteryListener"/>
<plugin name="SplashScreen" value="org.apache.cordova.SplashScreen"/>

<plugin name="AppComm" value="com.example.plugin.AppComm"/>
</plugins>

Cordova .xml

<?xml version="1.0" encoding="utf-8"?>
<cordova>
<access origin=".*"/> <!-- allow local pages -->
<log level="DEBUG"/>
<preference name="classicRender" value="true" />
</cordova>

Index.html 标题

<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1.0" />
<title>
</title>
<link rel="stylesheet" href="http://code.jquery.com/mobile/1.1.0/jquery.mobile-1.1.0.css" />
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js">
</script>
<script src="http://code.jquery.com/mobile/1.1.0/jquery.mobile-1.1.0.min.js">
</script>
<script type="text/javascript" charset="utf-8" src="cordova.js"></script>
<script type="text/javascript" charset="utf-8">
var AppComm=function(){};

AppComm.prototype.updateValues=function(a){
var map = new Object();
map["X1"] = "hallo";
map["X2"] = "hi";
cordova.exec(null, null, null);
};

cordova.addConstructor(function(){cordova.addPlugin("appcomm",new AppComm)});
</script>
</head>

问题之一是 javascript 在一个单独的文件中(我认为这是问题之一)。如果没有太多要问的,我怎样才能正确地调用 java,以及使用什么值? execute方法如何实现和调用(我JQuery很烂)?

最佳答案

首先,您使用的是 Plugin 子类。 Plugin 已弃用,并已替换为 CordovaPlugin。如果您使用的是旧版本的 PhoneGap,我建议您升级。

其次,您的 exec 调用是错误的。插件开发文档清楚地说明您必须传递 5 个参数,同时传递 3 个空值。您希望如何处理?

cordova.exec(function(winParam) {}, function(error) {}, "service",
"action", ["firstArgument", "secondArgument", 42,
false]);

这里,serviceaction 和参数数组决定了您的 Java 代码中会发生什么。前两个决定了 JavaScript 在特定条件下会发生什么。因此,虽然您可以为前两个使用 null,但您必须指定后三个。

我有一个适用于 PhoneGap 2.3.0 的工作示例插件。请看下面的代码:

public class ExampleJSCommunicator extends CordovaPlugin {

public boolean execute (final String action, final JSONArray args, CallbackContext callbackContext) throws JSONException {
PluginResult.Status status = PluginResult.Status.OK;
String result = "";

cordova.getActivity ().runOnUiThread (new Runnable () {
@Override
public void run() {
try {
String displayText = "";
if (action.equals ("buttonClicked")) {
displayText = args.getString(0) + " was clicked";
}

else if (action.equals ("animationRunning")) {
displayText = args.getBoolean(0) ? "Animation started running" : "Animation stopped running";
}

TextView label = (TextView) cordova.getActivity().findViewById (R.id.textView);
label.setText (displayText + " and the Activity knows it!");
} catch (JSONException e) {
e.printStackTrace();
}
}
});

return true;
}
}

使用上面的代码,您的 Java 端插件能够处理两个自定义“操作”- buttonClickedanimationRunning。这些操作符合我的目的,但您可以用其他方式命名。

现在,您仍然需要注册您的插件,以便 Cordova 知道它。这是在 xml/config.xml 文件中完成的。在 plugins 下,您必须添加以下内容:

<plugin name="ExampleJSCommunicator" value="com.example.phonegap.ExampleJSCommunicator"/>

然后您可以按如下方式从 JavaScript 传递数据(或“操作”)。注意参数(which.idanimationRunning 是数组传递的):

cordova.exec (null, null, "ExampleJSCommunicator", "buttonClicked", [which.id]);  // my first action
cordova.exec (null, null, "ExampleJSCommunicator", "animationRunning", [animationRunning]); // my second action

这两个 exec 调用将触发 ExampleJSCommunicator 类中的 execute 方法,并将在相应的 if block 中得到处理。在何处调用 exec 并不重要,只要在包含 cordova.js 文件后声明 JavaScript 代码即可。我的 JavaScript 包含在一个单独的 main.js 文件中,它工作得很好:

<script type="text/javascript" charset="utf-8" src="cordova.js"></script>
<script type="text/javascript" charset="utf-8" src="main.js"></script>

关于使用 PhoneGap 从 Android 调用 Javascript,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15852499/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com