zoukankan      html  css  js  c++  java
  • Phonegap通过JS访问本地接口的两种方法

    Phonegap为跨设备的应用开发提供了一个解决方案。如果某个应用只有js和html,则可以通过Phonegap的在线build工具,编译出多个平台的app安装包。当然通过Phonegap提供的js可以访问部分设备的资源,如网络连接(Connection)、相机(Camera)、文件(File)、存储(Storage)等,具体可以参看Phonegap开发文档。但很多Android应用,仅仅使用这些资源是满足不了需求的,所以必然需要访问本地接口的方法。

     

    初步实验,至少有两个方法可以访问本地的接口。

    • 开发Phonegap Plugin。通过实现Phonegap提供的接口,然后在config.xml中注册插件,就可以通过js开访问了。具体可以参考Plugin Development GuideDeveloping a Plugin on Android
    • 直接写Java类,通过DroidGap.appView.addJavascriptInterface暴露Java接口。按照这篇博客可以写出来。

    对于第一种方法,虽然官方已经提供了教程,但我认为还是有必要梳理一下流程,因为官网的教程忽略了由于升级需要的更改。

    • 实现CordovaPlugin 提供接口
    Java代码  收藏代码
    1. <span style="font-size: 14px;">package org.apache.cordova.plugin;  
    2.   
    3. import org.apache.cordova.api.CordovaPlugin;  
    4. import org.apache.cordova.api.PluginResult;  
    5. import org.json.JSONArray;  
    6. import org.json.JSONException;  
    7. import org.json.JSONObject;  
    8.   
    9. /** 
    10.  * This class echoes a string called from JavaScript. 
    11.  */  
    12. public class Echo extends CordovaPlugin {  
    13.     @Override  
    14.     public boolean execute(String action, JSONArray args, CallbackContext callbackContext) throws JSONException {  
    15.         if (action.equals("echo")) {  
    16.             String message = args.getString(0);   
    17.             this.echo(message, callbackContext);  
    18.             return true;  
    19.         }  
    20.         return false;  
    21.     }  
    22.   
    23.     private void echo(String message, CallbackContext callbackContext) {  
    24.         if (message != null && message.length() > 0) {   
    25.             callbackContext.success(message);  
    26.         } else {  
    27.             callbackContext.error("Expected one non-empty string argument.");  
    28.         }  
    29.     }  
    30. }</span>  

     

    • 修改config.xml

    添加以下代码

     

    Xml代码  收藏代码
    1. <span style="font-size: 14px;"><plugin name="Echo" value="org.apache.cordova.plugin.Echo" /></span>  
    • 为windows(或者其他对象)添加echo方法

    官网为cordova.exec(...),这里需要根据2.6的js接口使用作以下修改。

    Js代码  收藏代码
    1. <span style="font-size: 14px;">window.echo = function(str, callback) {</span>  
    2. <span style="font-size: 14px;">    <strong>var exec = cordova.require('cordova/exec');</strong>  
    3.     <strong>exec</strong>(callback, function(err) {  
    4.         callback('Nothing to echo.');  
    5.     }, "Echo""echo", [str]);  
    6. };</span>  

     

    •  通过js调用接口
    Js代码  收藏代码
    1. <span style="font-size: 14px;">window.echo("echome"function(echoValue) {  
    2.     alert(echoValue == "echome"); // should alert true.  
    3. });</span>  

     另外,对于回调函数调用的线程有三种情况:

     

     

    • 如果直接调用,即callbackContext.success(),则在WebCore 线程中执行,而是在UI线程。
    • 如果希望在UI线程中直接,需要将回调函数封装在Runanble中,放在cordova.getActivity().runOnUiThread中执行。

     

    Java代码  收藏代码
    1. <span style="font-size: 14px;">cordova.getActivity().runOnUiThread(new Runnable() {  
    2.             public void run() {  
    3.                 ...  
    4.                 callbackContext.success(); // Thread-safe.  
    5.             }  
    6.         });  
    7.  </span>  

     

     

    • 如果期望在单独的线程中执行(不至于阻塞WebCore线程),则使用 cordova.getThreadPool().execute方法。
    Java代码  收藏代码
      1. <span style="font-size: 14px;"> cordova.getThreadPool().execute(new Runnable() {  
      2.             public void run() {  
      3.                 ...  
      4.                 callbackContext.success(); // Thread-safe.  
      5.             }  
      6.         });</span> 
  • 相关阅读:
    e667. 在给定图像中创建缓冲图像
    e661. 确定图像中是否有透明像素
    e673. Getting Amount of Free Accelerated Image Memory
    e663. 在gif图像中获取透明和色彩的数量
    e662. 取的图像的色彩模型
    e675. 翻转缓冲图像
    e665. 在图像中过滤三元色
    e679. 浮雕化图像
    e669. 绘制缓冲图像
    e664. 在图像中获取子图像
  • 原文地址:https://www.cnblogs.com/zhwl/p/3184324.html
Copyright © 2011-2022 走看看