精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Firefox OS中跨應(yīng)用數(shù)據(jù)交互

移動開發(fā)
由于受到安全的限制,WEB應(yīng)用跨域調(diào)用實現(xiàn)起來是比較麻煩的。傳統(tǒng)的做法有服務(wù)器代理、jsonp接口等,但在firefox os中并不需要如此大費周折。在firefox os中已經(jīng)提供了跨應(yīng)用交互的機(jī)制,雖然目前來看并不是特別的方便,但已經(jīng)可以實現(xiàn)基本的跨應(yīng)用交互的App了。本文將以一個實際的DEMO來講解B2G的跨應(yīng)用調(diào)用。

由于受到安全的限制,WEB應(yīng)用跨域調(diào)用實現(xiàn)起來是比較麻煩的。傳統(tǒng)的做法有服務(wù)器代理、jsonp接口等,但在firefox os中并不需要如此大費周折。在firefox os中已經(jīng)提供了跨應(yīng)用交互的機(jī)制,雖然目前來看并不是特別的方便,但已經(jīng)可以實現(xiàn)基本的跨應(yīng)用交互的App了。本文將以一個實際的DEMO來講解B2G的跨應(yīng)用調(diào)用。

概要介紹

本文將開發(fā)兩個應(yīng)用,應(yīng)用一:Caller,應(yīng)用二:Receiver

Caller中有一個Show Images的按鈕,點擊該按鈕將啟動Receiver,Receiver中提供了一些圖片瀏覽的功能,在Receiver中選擇圖片后,點擊Select按鈕,將把圖片傳送到Caller中,并在Caller中展現(xiàn)該選擇的圖片

整體效果如下

 

Caller應(yīng)用

[[60720]]

Receiver應(yīng)用

細(xì)節(jié)說明

Receiver

在Firefox OS中,要讓應(yīng)用可被其他應(yīng)用調(diào)用,需要在該應(yīng)用的manifest.webapp中進(jìn)行聲明。我們看一下Receiver的manifest.webapp文件

  1. {  
  2.      "name": "Receiver",  
  3.      "launch_path": "/index.html",  
  4.      "developer": {  
  5.          "name": "chyblog",  
  6.          "url": "http://www.chyblog.com"  
  7.      },  
  8.      "icons": {  
  9.          "120": "/style/icons/Receiver.png"  
  10.      },  
  11.      "permissions": [  
  12.          "background",  
  13.          "backgroundservice",  
  14.          "attention",  
  15.          "contacts",  
  16.          "settings",  
  17.          "desktop-notification"  
  18.      ],  
  19.      "activities": {  
  20.          "pick": {  
  21.              "filters": {  
  22.                  "type": ["image/png", "image/gif"]  
  23.              },  
  24.              "returnValue": true,  
  25.              "disposition": "inline"  
  26.          }  
  27.      }  
  28.  }  

其中activities屬性聲明了一個web activity,取名為pick,其中filters屬性告訴system對哪些類型的請求響應(yīng),Receiver應(yīng)用,可以響應(yīng)名稱為pick,type為image/png或者image/gif類型的響應(yīng)。

returnValue是一個布爾類型的屬性,為true時,聲明該web activity需要返回數(shù)據(jù)給調(diào)用它的應(yīng)用,false則不需要返回數(shù)據(jù)給調(diào)用者

disposition屬性有兩種可選值,window和inline,如果為window,則會以啟動一個新應(yīng)用的方式打開,如果為inline,則會臨時啟動一個畫面顯示該應(yīng)用的界面。

在Receiver應(yīng)用中,還需要用js編寫響應(yīng)調(diào)用的處理代碼

  1. navigator.mozSetMessageHandler('activity', webActivityHandler);  
  2.  
  3. var activityRequest;  
  4.  
  5. var webActivityHandler = function(request) {  
  6.     activityRequest = request;  
  7.  
  8.     document.getElementById('button').disabled = '';  
  9.     document.getElementById('cancelButton').disabled = '';  
  10.  };  

以上代碼注冊了一個事件響應(yīng)句柄,并將請求者的信息保存在全局變量activityRequest中

當(dāng)用戶點擊Select按鈕后,將把圖片信息傳送給Caller。代碼如下

  1. function select() {  
  2.     if (!activityRequest) {  
  3.         alert('There are no any pending activity request.');  
  4.         return;  
  5.     }  
  6.  
  7.     // Return the request  
  8.     activityRequest.postResult({  
  9.         type : 'image/png',  
  10.         text : getBase64Image(selectedImg)  
  11.     });  
  12.     activityRequest = null;  
  13.  
  14.     // close app, currently useless,  
  15.     // see https://bugzilla.mozilla.org/show_bug.cgi?id=789392 
  16.     window.close();  
  17. };  

由于兩個應(yīng)用的數(shù)據(jù)交互只能使用文本信息傳遞,這里將Receiver中的圖片以base64文字編碼的方式傳給Caller,在Caller中,將該文本設(shè)置到backgroundImage中,即可顯示,獲取圖片的base64編碼的代碼如下

  1. function getBase64Image(imgSrc) {  
  2.     var img = new Image();  
  3.     img.src = imgSrc;  
  4.     var canvas = document.createElement("canvas");  
  5.     canvas.width = img.width;  
  6.     canvas.height = img.height;  
  7.     var ctx = canvas.getContext("2d");  
  8.     ctx.drawImage(img, 0, 0);  
  9.     var dataURL = canvas.toDataURL("image/png", 0.2);  
  10.     return dataURL;  
 

Caller

Call應(yīng)用中,主要是觸發(fā)Receiver調(diào)用的響應(yīng)和接受返回數(shù)據(jù)的處理

Call首先創(chuàng)建一個activity請求,需要告訴system,請求的名稱和類型。并注冊請求成功返回和請求失敗時的處理邏輯。而請求如何去調(diào)用,完全由system控制。創(chuàng)建請求的代碼如下

  1. var a = new MozActivity({ name : 'pick', data : { type : 'image/png' } }); a.onsuccess = function() { reopenApp(); document.getElementById('showImg').style.backgroundImage = "url(" + this.result.text + ")"; document.getElementById('result').textContent = 'well done'; }; a.onerror = function() { reopenApp(); document.getElementById('showImg').style.backgroundImage = ""; document.getElementById('result').textContent = '(canceled)'; };

需要強調(diào)的是,Caller和Receiver是兩個獨立的應(yīng)用,兩者之間的交互都是system app負(fù)責(zé)的。我們需要做的,就是聲明web activity,觸發(fā)請求和響應(yīng)請求。

源碼下載:http://chyblog-chyblog.stor.sinaapp.com/wp-content/uploads/2012/10/webActivity.zip

 

責(zé)任編輯:Yeva 來源: chyblog.com
相關(guān)推薦

2012-09-04 13:35:24

Firefox OS

2013-01-14 12:25:49

Firefox OS

2013-01-14 12:19:48

Firefox OSFirefox OS

2013-01-14 12:24:06

Firefox OS

2013-01-14 13:21:09

Firefox os

2013-06-24 09:23:25

Firefox OS火狐手機(jī)Android

2013-01-14 12:53:13

Firefox OSIndexedDB

2013-01-14 12:10:46

firefox osfirefox os

2013-09-02 11:18:06

Firefox OSMarketplace

2013-01-14 13:14:11

Firefox OS

2012-09-12 09:08:54

Firefox OS

2014-01-09 14:07:46

Firefox OS操作系統(tǒng)

2012-09-29 10:24:14

Firefox OS

2014-06-16 10:20:46

Firefox OSWeb Apps

2015-11-12 13:47:53

Firefox OSAPPFirefox

2013-02-25 09:15:30

MWC 2013Firefox OS

2013-01-08 14:58:48

Firefox OS

2009-03-23 09:57:19

2009-12-08 14:43:04

WCF跨域

2011-10-08 15:18:38

MozillaFirefox移動戰(zhàn)略
點贊
收藏

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

91视频在线观看免费| 精久久久久久| 欧美日韩国产首页| 少妇精品久久久久久久久久| 色婷婷久久综合中文久久蜜桃av| 国产日产一区| 欧美日韩精品高清| 可以在线看黄的网站| 亚洲精品久久久久久动漫器材一区| 在线欧美福利| 上原亚衣av一区二区三区| 成人性生交视频免费观看| 国产www视频在线观看| 久久新电视剧免费观看| 91久久久久久久| 麻豆久久久久久久久久| 日本成人小视频| 精品久久久影院| 亚洲色图久久久| 国产偷倩在线播放| 国产女人18水真多18精品一级做| 96国产粉嫩美女| 中文字幕精品三级久久久| 久久免费大视频| 亚洲国产小视频| 亚洲最大天堂网| 小视频免费在线观看| 亚洲欧美电影一区二区| 欧美激情国产日韩| av av片在线看| 久热精品在线| 久久久亚洲网站| 色偷偷男人天堂| 九九热hot精品视频在线播放| 欧美色图在线观看| 精品久久久久久久久久中文字幕| 蜜桃视频网站在线观看| 91小视频在线| 国产伦精品一区二区三区四区免费| 在线观看免费观看在线| 国产一区白浆| 欧美黑人一级爽快片淫片高清| 国产性猛交xx乱| 日本午夜精品久久久| 欧美刺激午夜性久久久久久久| 久久黄色免费看| 日本不卡1234视频| 亚洲综合一区二区三区| 26uuu成人| 97电影在线看视频| 久久精品夜色噜噜亚洲a∨| 国产欧美日韩视频一区二区三区| 国产男女猛烈无遮挡| 久久丁香综合五月国产三级网站 | 欧美极品色图| 日本黄色不卡视频| 国产成人精品一区二区三区网站观看 | 国产人妻人伦精品1国产丝袜| 欧美中文高清| 欧美精品日韩综合在线| 香港日本韩国三级网站| 99久久伊人| 欧美三级欧美一级| 色片在线免费观看| 久久亚洲资源中文字| 欧美日韩国产欧美日美国产精品| av污在线观看| av日韩一区| 日韩午夜av电影| 韩国三级在线看| 久久国产精品色av免费看| 亚洲精品福利资源站| 亚洲少妇18p| 神马午夜久久| 国产午夜精品免费一区二区三区| 国产熟妇久久777777| 黑人操亚洲人| 久久视频中文字幕| 久久综合久久鬼| 国产精品久久国产愉拍| 热久久这里只有精品| 国产精品51麻豆cm传媒 | 亚洲二区视频在线| 欧美日韩性生活片| 香蕉视频亚洲一级| 欧美日本国产一区| 国产精品二区视频| 天天躁日日躁狠狠躁欧美巨大小说| 日韩电影免费观看中文字幕 | 国产美女明星三级做爰| 国产99久久久国产精品潘金 | 天天爽夜夜爽视频| 欧美freesex8一10精品| 一区二区欧美亚洲| 久久久久亚洲AV成人| 99亚洲视频| 成人激情视频小说免费下载| 亚洲av无码乱码国产精品久久| 91影院在线免费观看| 亚洲黄色成人久久久| 亚洲精品一线| 色94色欧美sute亚洲线路一久| 国产三级生活片| 玖玖玖免费嫩草在线影院一区| 亚洲欧洲偷拍精品| 欧美黑人一级片| 天使萌一区二区三区免费观看| 成人欧美一区二区三区黑人孕妇| 四虎永久在线观看| 国产精品色在线| 亚洲国产精品无码av| 欧美一级二级视频| 日韩久久久精品| 人妻视频一区二区| 亚洲国产专区| 国产精品一久久香蕉国产线看观看 | 欧美边添边摸边做边爱免费| 亚欧色一区w666天堂| 玖玖爱视频在线| 日韩欧美天堂| 色中色综合影院手机版在线观看 | 3atv一区二区三区| 亚洲av综合一区二区| 在线高清一区| 亚洲在线一区二区| 91视频在线观看| 日韩欧美在线播放| 成人性生活免费看| 最新国产精品| 成人国产精品一区| 国产永久免费高清在线观看| 午夜精品久久久久久久久| 日韩成人av免费| 欧美一二区在线观看| 91国内产香蕉| 天天干天天做天天操| 夜夜精品视频一区二区| 国产5g成人5g天天爽| 欧美午夜精彩| 国产精品美女主播在线观看纯欲| 亚洲人成色777777老人头| 亚洲成av人片在线| 日本一区二区免费视频| 午夜视频一区| 91在线精品观看| 丝袜美腿av在线| 欧美一区二区免费视频| 亚洲波多野结衣| 国精产品一区一区三区mba视频| 亚洲欧洲精品在线| 精品三级在线| 精品精品国产国产自在线| 一区二区三区在线免费观看视频| 久久精品夜色噜噜亚洲aⅴ| 日韩精品一区二区三区久久| 久久精品福利| 午夜免费在线观看精品视频| 五十路在线视频| 疯狂做受xxxx高潮欧美日本 | 欧美国产亚洲另类动漫| 日本www.色| 成人三级视频| 91视频免费在线| 在线heyzo| 精品国产免费一区二区三区四区| 国产亚洲欧美精品久久久www | 90岁老太婆乱淫| 日韩精品免费专区| 亚洲一区二区三区四区中文| 日韩一区二区三区四区五区 | 丁香花在线电影| 亚洲成人三级在线| 五月婷婷色丁香| 欧美激情中文不卡| 国产高清av片| 一区二区精品| 日本精品一区二区| 天天综合91| 久久青草精品视频免费观看| 日韩美女一级视频| 欧美日韩一区国产| 久草免费新视频| 久久综合久久综合久久| 国产成人黄色网址| 欧美午夜在线| 欧美午夜精品久久久久免费视 | 成人免费网址| 亚洲精品久久视频| 亚洲一区中文字幕在线| 一区二区三区在线视频观看| 日本japanese极品少妇| 捆绑紧缚一区二区三区视频 | 美女尤物在线视频| 亚洲深夜福利在线| 国产高清视频免费| 欧美性xxxxxxxxx| 久久精品黄色片| 久久久精品免费观看| 日本亚洲一区二区三区| 久久一区精品| 黄色片免费在线观看视频| 国产99久久精品一区二区300| 成人激情视频在线观看| 另类专区亚洲| 欧美激情喷水视频| 欧美极品另类| 亚洲男子天堂网| 午夜免费福利视频| 欧美综合亚洲图片综合区| 久久久久国产精品夜夜夜夜夜| 国产性做久久久久久| 亚洲色图欧美另类| 老鸭窝一区二区久久精品| 日韩精品视频久久| 欧美日本在线| 中文字幕一区二区三区在线乱码| 天堂综合网久久| 99re视频在线播放| 国产伊人久久| 国产va免费精品高清在线观看| 欧美日韩在线视频免费观看| 色99之美女主播在线视频| 天堂a√在线| 欧美大片在线观看一区| 91丨九色丨蝌蚪丨对白| 色综合久久综合中文综合网| 久一视频在线观看| 亚洲精品美腿丝袜| 国产精品一区二区亚洲| 久久久精品综合| 黄色工厂在线观看| 成人午夜免费电影| 秋霞午夜鲁丝一区二区 | 国产视频久久久久久| 国产精品香蕉一区二区三区| 国产高潮免费视频| 免费成人在线网站| 日韩av片网站| 免播放器亚洲一区| 日本免费色视频| 秋霞午夜鲁丝一区二区老狼| 久久久久狠狠高潮亚洲精品| 国产欧美日韩综合一区在线播放| 被灌满精子的波多野结衣| 黄色另类av| 欧日韩免费视频| 亚洲精品影院在线观看| 91免费黄视频| 99亚洲一区二区| 37pao成人国产永久免费视频| 国产精品亚洲综合久久| 免费看国产曰批40分钟| 亚洲一区二区三区四区五区午夜 | 日韩国产高清污视频在线观看| 黄频网站在线观看| 亚洲精品www久久久| 无码国产精品一区二区色情男同| 欧美精品一区二区三区在线播放| 欧美特黄一级视频| 日韩电影在线观看永久视频免费网站| 手机看片国产1024| 亚洲色图50p| 日本美女在线中文版| 久久夜精品香蕉| 欧美人与性动交α欧美精品图片| 97免费视频在线| 婷婷六月国产精品久久不卡| 国产精品久久久久一区二区| 亚洲精品aaa| 国产精品加勒比| 夜夜躁狠狠躁日日躁2021日韩| 日韩欧美在线一区二区| 欧美gay男男猛男无套| 超碰10000| 国产精品最新自拍| 污网站免费在线| 国产精品2024| 蜜桃精品成人影片| 1000精品久久久久久久久| 国产性生活网站| 色狠狠一区二区三区香蕉| 97caocao| 亚洲精品美女视频| 国内精品不卡| 91精品国产色综合久久不卡98口| 在线国产成人影院| 99国产高清| 国产成人三级| japanese在线播放| 久热国产精品| 蜜臀aⅴ国产精品久久久国产老师| 久久这里只有精品首页| 伊人在线视频观看| 色综合一区二区三区| 国产精品久久免费| 亚洲精品自在久久| 在线看福利影| 国产精品男人爽免费视频1| 97一区二区国产好的精华液| 亚洲v国产v| 亚洲国内精品| 下面一进一出好爽视频| 国产亚洲一区二区三区| 久久这里只有精品免费| 欧美日韩国产乱码电影| 天堂av资源网| 久久伊人精品天天| 成人日韩精品| 精品国产一二| 欧美日韩国产欧| 国产一级片自拍| 国产农村妇女毛片精品久久麻豆| 国产一级生活片| 欧美一区二区国产| 91涩漫在线观看| 欧美有码在线视频| www.国产精品一区| 97超碰免费观看| 日韩成人精品视频| 日本少妇色视频| 亚洲国产综合91精品麻豆| 国产精品无码AV| 在线日韩av观看| 电影久久久久久| 欧美日韩在线一二三| 99国产精品| 国模私拍在线观看| 亚洲一二三四在线| 国内精品久久久久久久久久久| 最新亚洲国产精品| 欧美成a人片在线观看久| 久久久久久亚洲精品不卡4k岛国| 国内精品久久久久久久97牛牛 | 中文字幕在线观看1| 亚洲片av在线| 老司机成人影院| 欧美一区二区三区四区在线观看地址 | 欧美交换配乱吟粗大25p| 免费在线观看日韩欧美| 30一40一50老女人毛片| 欧美日韩国产精品| 五月婷中文字幕| 欧美一级视频一区二区| 久久精品色综合| 成人午夜精品久久久久久久蜜臀| 国产精品亚洲а∨天堂免在线| 久久久久亚洲av片无码| 欧美日韩国产小视频在线观看| 国产大学生校花援交在线播放| 日本精品在线视频| 国产在线日韩精品| 日韩av手机版| 国产精品久久777777| 91丨九色丨蝌蚪丨对白| 免费不卡在线观看av| 色悠久久久久综合先锋影音下载| 在线观看17c| 成人福利电影精品一区二区在线观看| 久久久久人妻一区精品色欧美| 亚洲国产精品va在看黑人| 日韩电影毛片| 久久久久久国产精品mv| 久久一二三四| 内射一区二区三区| 欧美成人video| 免费毛片b在线观看| 午夜精品美女久久久久av福利| 美女一区二区三区在线观看| 日本二区三区视频| 欧美岛国在线观看| 涩涩涩在线视频| 亚洲视频在线观看日本a| 国产精品伊人色| 国产精品黄色大片| 在线国产精品视频| 日韩在线成人| 六月激情综合网| 中文字幕永久在线不卡| 成人久久精品人妻一区二区三区| 55夜色66夜色国产精品视频| 日本欧美视频| 制服丝袜av在线| 欧美在线free| 牛牛电影国产一区二区| 久久久久久久久一区| 麻豆一区二区99久久久久| 久久久久久久久久99| 亚洲欧美日韩高清| 欧美高清一级片| 国产精品动漫网站| 亚洲免费在线播放| 青青国产在线| 91九色露脸| 日韩高清在线一区| 久久精品视频6| 视频一区视频二区国产精品| 国内露脸中年夫妇交换精品| 久久这里只精品| 性做久久久久久久久| 日本电影全部在线观看网站视频|