android phonegap插件開發方法 plugin

分類: phonegap 2014-03-03 22:41  5951人閱讀  評論(2)  收藏  舉報

此篇文章以cordova 3.4版本編寫 javascript

phonegap的插件開發   與javascript調用android的Activity功能,以及相互傳遞數據. html

本節講的是 自主編寫 phonegap插件提供下載 java

據我總結核心步驟:  建立工程 ; 編寫插件 ;編譯工程; 調用插件; android

 

        按照以下步驟就能生產出代碼: apache

打開cmd 控制檯 json

1 使用命令行 創建phonegap工程 app

2 將工程導入 eclipse eclipse

3 在assents 目錄下的  cordova-plugins.js文件添加配置 ui

4 在plugin目錄下編寫javascript接口 google

5 在res/xml 目錄下配置  config.xml 文件

6 在src目錄下編寫java文件

 

最後在javascript文件中調用接口

 

整體說 主要是後4個步驟詳細分解講解

 

 

接下來給你們分解演示:

目測你們都是已經安裝好環境的,若是沒有搭好環境 能夠查看個人phonegap配置文章點擊打開連接

調用系統的API 官方文檔地址   點擊打開連接

<1> 在控制檯    建立一個phonegap工程  命令以下

[java]  view plain copy 在CODE上查看代碼片 派生到個人代碼片
  1. phonegap create my-app  
  2. cd my-app  
  3. phonegap run android  


<2> 將工程導入 eclipse

 


<3> 配置 cordova _plugins.js 文件

 

首先給你們看看cordova _plugins.js 文件:

 

[javascript]  view plain copy 在CODE上查看代碼片 派生到個人代碼片
  1. cordova.define('cordova/plugin_list'function(require, exports, module) {  
  2. module.exports = [  
  3.     {  
  4.         "file""plugins/org.apache.cordova.camera/www/CameraConstants.js",  
  5.         "id""org.apache.cordova.camera.Camera",  
  6.         "clobbers": [  
  7.             "Camera"  
  8.         ]  
  9.     },  
  10.     {  
  11.         "file""plugins/org.apache.cordova.camera/www/CameraPopoverOptions.js",  
  12.         "id""org.apache.cordova.camera.CameraPopoverOptions",  
  13.         "clobbers": [  
  14.             "CameraPopoverOptions"  
  15.         ]  
  16.     },  
  17.     {  
  18.         "file""plugins/org.apache.cordova.camera/www/Camera.js",  
  19.         "id""org.apache.cordova.camera.camera",  
  20.         "clobbers": [  
  21.             "navigator.camera"  
  22.         ]  
  23.     },  
  24.     {  
  25.         "file""plugins/org.apache.cordova.camera/www/CameraPopoverHandle.js",  
  26.         "id""org.apache.cordova.camera.CameraPopoverHandle",  
  27.         "clobbers": [  
  28.             "CameraPopoverHandle"  
  29.         ]  
  30.     },  
  31.     {  
  32.         "file""plugins/org.apache.cordova.dialogs/www/notification.js",  
  33.         "id""org.apache.cordova.dialogs.notification",  
  34.         "merges": [  
  35.             "navigator.notification"  
  36.         ]  
  37.     },  
  38.     {  
  39.         "file""plugins/org.apache.cordova.dialogs/www/android/notification.js",  
  40.         "id""org.apache.cordova.dialogs.notification_android",  
  41.         "merges": [  
  42.             "navigator.notification"  
  43.         ]  
  44.     },  
  45.     {  
  46.         "file""plugins/org.apache.cordova.vibration/www/vibration.js",  
  47.         "id""org.apache.cordova.vibration.notification",  
  48.         "merges": [  
  49.             "navigator.notification"  
  50.         ]  
  51.     },  
  52.     {  
  53.         "file""plugins/intent.js",  
  54.         "id""org.apache.cordova.intent",  
  55.         "merges": [  
  56.             "navigator.intent"  
  57.         ]  
  58.     },  
  59. ];  
  60. module.exports.metadata =   
  61. // TOP OF METADATA  
  62. {  
  63.     "org.apache.cordova.camera""0.2.7",  
  64.     "org.apache.cordova.dialogs""0.2.6",  
  65.     "org.apache.cordova.vibration""0.3.7",  
  66.     "org.apache.cordova.intent" :"0.0.1",  
  67.   
  68. }  
  69. // BOTTOM OF METADATA  
  70. });  


我以前配置了camera  ,dialog , vibration   ,你們能夠參考

如今來分解  ,這裏要配置2個地方

module.exports= [{}];

module.exports.metadata = { }

 

在module.exports 的花括號裏面配置

[javascript]  view plain copy 在CODE上查看代碼片 派生到個人代碼片
  1. {  
  2.         "file""plugins/intent.js",  
  3.         "id""org.apache.cordova.intent",  
  4.         "merges": [  
  5.             "navigator.intent"  
  6.         ]  
  7.     },  

 

file 表明  javascript寫的接口位置

id   表明  惟一

merges   表明你在 javascript中調用該接口的語句    (相似activity中的 getApplication() 等等 ;就是個調用語句)

 

在module.exports.metadata 中配置id  

標號隨意 

 

<4> 在plugin目錄下編寫javascript接口
 

 

貼上intent.js的接口代碼

[javascript]  view plain copy 在CODE上查看代碼片 派生到個人代碼片
  1. cordova.define("org.apache.cordova.intent"function(require, exports, module) {   
  2.   
  3. var exec = require('cordova/exec');  
  4.   
  5.   
  6.   
  7. module.exports = {  
  8.   
  9.     /** 
  10.      * 一共5個參數 
  11.        第一個 :成功會掉 
  12.        第二個 :失敗回調 
  13.        第三個 :將要調用的類的配置名字(在config.xml中配置 稍後在下面會講解) 
  14.        第四個 :調用的方法名(一個類裏可能有多個方法 靠這個參數區分) 
  15.        第五個 :傳遞的參數  以json的格式 
  16.      */  
  17.     demo: function(mills) {  
  18.         exec(function(winParam){  
  19.             alert(winParam);  
  20.         }, null"Demo""intent", [mills]);  
  21.     },  
  22. };  
  23.   
  24. });  


Demo中成功返回 會彈出一個Alert();

 

在javascript中的 調用語句是

[javascript]  view plain copy 在CODE上查看代碼片 派生到個人代碼片
  1. navigator.intent.demo(1);      

 

 

貼上整的javascript

 


[javascript]  view plain copy 在CODE上查看代碼片 派生到個人代碼片
  1. <!DOCTYPE html>  
  2. <html>    
  3. <head>     
  4.   <title>Notification Example</title>   
  5.   <script type="text/javascript" charset="utf-8" src="cordova.js"></script>      
  6.   <script type="text/javascript" charset="utf-8">      
  7.    // Wait for device API libraries to load      
  8.    //      
  9.    document.addEventListener("deviceready", onDeviceReady, false);      
  10.    // device APIs are available      
  11.    //      
  12.    function onDeviceReady() {          
  13.      // Empty      
  14.     }      
  15.     // Show a custom alert      
  16.       
  17.     //    native的 Dialog 對話框  
  18.     function showAlert() {        navigator.notification.alert(            'You are the winner!',  // message              
  19.       'Game Over',              
  20.     // title              
  21.     'Done'                    
  22.     // buttonName          
  23.     );    }      
  24.     // Beep three times      
  25.     //    響鈴3聲  
  26.     function playBeep() {        navigator.notification.beep(3);    }      
  27.     // Vibrate for 2 seconds      
  28.     //    振動  
  29.     function vibrate() {         navigator.notification.vibrate(100000);    }      
  30.     //       跳轉  
  31.     function intent() {          navigator.intent.demo(1);          }      
  32.   
  33.     </script>    
  34.     </head>    
  35.     <body>      
  36.     <p><a href="#" onclick="showAlert(); return false;">Show Alert</a></p>      
  37.     <p><a href="#" onclick="playBeep(); return false;">Play Beep</a></p>      
  38.     <p><a href="#" onclick="vibrate(); return false;">Vibrate</a></p>    
  39.     <p><a href="#" onclick="intent(); return false;">Html跳轉到android界面</a></p>    
  40.     </body>  
  41.     </html>  


 

 

 

 

 

 

<5> 在res/xml 目錄下配置  config.xml 文件 

 

config.xml配置 加上 以下

[html]  view plain copy 在CODE上查看代碼片 派生到個人代碼片
  1. <feature name="Demo">  
  2.     <param name="android-package" value="plugins.Plugin_intent" />  
  3. </feature>  


feature的name屬性   很是重要 

name必須是步驟< 4 >中   function中調用的類名

value屬性指定插件在src目錄下的java文件  (命名空間)

 

 

今天就寫到這裏 

 

 

 example:

      明天整理後提交  今晚先睡了 ~~~謝謝 

      插件Demo下載地址: http://download.csdn.net/detail/aaawqqq/6992627

           

工程下載    將phonegap的platforms導入到eclipse中  

若是報錯clear一下  查看導的lib包 有沒有報錯

若是還有錯  那麼就是您選用了  google的API   改爲最新版的android  API 就行了

具體排查錯誤  能夠看個人這一篇Blog:  http://blog.csdn.net/aaawqqq/article/details/20463183

相關文章
相關標籤/搜索