自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

PhoneGap的Android端插件開發(fā)

移動(dòng)開發(fā) Android
鑒于PhoneGap才剛剛新起,還有許多功能因?yàn)槠脚_的差異性無法很好的解決,所以我們在實(shí)際的開發(fā)中,發(fā)現(xiàn)有很多功能還需要完善,一種比較好的方式就是編寫平臺依賴的插件,進(jìn)而擴(kuò)展PhoneGap的功能。

前面一篇文章 《移動(dòng) APP 之跨平臺解決方案》 介紹了一種跨平臺的解決方案,即用開發(fā)web app的方式來編寫mobile app。鑒于PhoneGap才剛剛新起,還有許多功能因?yàn)槠脚_的差異性無法很好的解決,所以我們在實(shí)際的開發(fā)中,發(fā)現(xiàn)有很多功能還需要完善,一種比較好 的方式就是編寫平臺依賴的插件,進(jìn)而擴(kuò)展PhoneGap的功能。

本文介紹一下開發(fā)和使用插件的一個(gè)流程,以 VideoPlayer 為例。

  1. 環(huán)境搭建,下載 phonegap-android 的源碼,下載地址 https://github.com/phonegap/phonegap-android
  2. 編寫video.js,提供給web開發(fā)端的接口定義,定義了一個(gè)VideoPlayer類和play函數(shù),參數(shù)為要播放的文件視頻地址,代碼如下:
    1. /** 
    2.  * Constructor 
    3.  */ 
    4. function VideoPlayer() { 
    5. }; 
    6.  
    7. /** 
    8.  * Starts the video player intent 
    9.  * 
    10.  * @param url           The url to play 
    11.  */ 
    12. VideoPlayer.prototype.play = function(url) { 
    13.     PhoneGap.exec(nullnull"VideoPlayer""playVideo", [url]); 
    14. }; 
    15.  
    16. /** 
    17.  * Load VideoPlayer 
    18.  */ 
    19. PhoneGap.addConstructor(function() { 
    20.     PhoneGap.addPlugin("videoPlayer"new VideoPlayer()); 
    21. }); 
  3. 編寫 Android VideoPlayer 的具體實(shí)現(xiàn)代碼,VideoPlayer/src/com/phonegap/plugins/video/VideoPlayer.java
    1. package com.phonegap.plugins.video; 
    2.  
    3. import org.json.JSONArray; 
    4. import org.json.JSONException; 
    5. import android.content.Intent; 
    6. import android.net.Uri; 
    7. import com.phonegap.api.Plugin; 
    8. import com.phonegap.api.PluginResult; 
    9.  
    10. public class VideoPlayer extends Plugin { 
    11.     private static final String YOU_TUBE = "youtube.com"
    12.  
    13.     @Override 
    14.     public PluginResult execute(String action, JSONArray args, String callbackId) { 
    15.         PluginResult.Status status = PluginResult.Status.OK; 
    16.         String result = ""
    17.  
    18.         try { 
    19.             if (action.equals("playVideo")) { 
    20.                 playVideo(args.getString(0)); 
    21.             } 
    22.             else { 
    23.                 status = PluginResult.Status.INVALID_ACTION; 
    24.             } 
    25.             return new PluginResult(status, result); 
    26.         } catch (JSONException e) { 
    27.             return new PluginResult(PluginResult.Status.JSON_EXCEPTION); 
    28.         } 
    29.     } 
    30.  
    31.     private void playVideo(String url) { 
    32.         // Create URI 
    33.         Uri uri = Uri.parse(url); 
    34.  
    35.         Intent intent = null
    36.         // Check to see if someone is trying to play a YouTube page. 
    37.         if (url.contains(YOU_TUBE)) { 
    38.             // If we don't do it this way you don't have the option for youtube 
    39.             intent = new Intent(Intent.ACTION_VIEW, uri); 
    40.         } else { 
    41.             // Display video player 
    42.             intent = new Intent(Intent.ACTION_VIEW); 
    43.             intent.setDataAndType(uri, "video/*"); 
    44.         } 
    45.  
    46.         this.ctx.startActivity(intent); 
    47.     } 
  4. 配置插件, res/xml/plugins.xml 添加如下代碼
    1. <plugin name="VideoPlayer" value="com.phonegap.plugins.video.VideoPlayer"/> 
  5. 編寫代碼進(jìn)行調(diào)用,文件開頭引入js代碼框架,然后進(jìn)行VideoPlayer類的play函數(shù)調(diào)用
    1. <script type="text/javascript" charset="utf-8" src="phonegap.js"></script> 
    2. <script type="text/javascript" charset="utf-8" src="video.js"></script> 
    3.  
    4.  //Sample use: 
    5.  /** 
    6.     * Display an intent to play the video. 
    7.     * 
    8.     * @param url           The url to play 
    9.     */ 
    10.  //play(url) 
    11.  
    12. window.plugins.videoPlayer.play("http://path.to.my/video.mp4"); 
    13. window.plugins.videoPlayer.play("file:///path/to/my/video.mp4"); 
  6. 到此為止,插件的開發(fā)和部署,以及調(diào)用就都o(jì)k了,是不是很簡單??!

最后向大家推薦一本書籍《PhoneGap Beginner’s Guide》,相信通過本書的學(xué)習(xí),就知道了怎樣利用PhoneGap來開發(fā)跨平臺的mobile app了,同時(shí)也可以關(guān)注https://github.com/phonegap項(xiàng)目的最新進(jìn)展情況和新特性,如果可以的話,貢獻(xiàn)自己的力量來進(jìn)行完善和擴(kuò)充!

責(zé)任編輯:佚名 來源: 潤物無聲的博客
相關(guān)推薦

2011-10-11 10:06:12

PhoneGap插件

2012-03-07 11:17:19

AndroidPhoneGap插件

2011-09-02 13:38:56

PhoneGap插件Android

2011-07-05 15:26:23

2011-09-13 09:49:59

PhoneGap插件

2011-12-30 15:11:36

Adobe視頻PhoneGap

2011-09-05 14:26:43

PhoneGap插件

2011-07-01 15:02:53

PhoneGap移動(dòng)開發(fā)框架

2011-07-05 17:29:53

PhoneGapevents

2011-12-19 08:57:46

PhoneGapNativeContr

2011-12-14 11:38:42

PhoneGapJavaAndroid

2012-03-07 15:07:54

PhoneGapAndroid源碼示例

2011-07-19 13:26:50

iPhone PhoneGap 框架

2011-12-15 09:45:21

PhoneGap

2011-12-22 19:57:38

PhoneGap

2011-08-31 13:11:53

AndroidPhoneGap

2014-07-04 09:43:22

2011-09-02 14:06:38

PhoneGapEclipseAndroid

2011-09-13 13:36:17

PhoneGap

2011-08-31 13:27:52

AndroidPhoneGap
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號