成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Windows Mobile 6.5新功能Widget開發詳解

移動開發
Windows Mobile 6.5新功能Widget開發詳解是本文要介紹的內容,主要是來了解并學習Windows Mobile Widget的應用,具體來看本文。

Windows Mobile 6.5新功能Widget開發詳解是本文要介紹的內容,主要是來了解并學習Windows Mobile Widget的應用。本文通過一個CurrencyConverter(外匯兌換)例子,講述Windows Mobile新功能Widget開發的基本概念和步驟,同時講述了Widget如何調用WebService。最近比較關心匯率波動,所以在Widget上實現一個匯率轉換器程序。

什么是Widget

Windows Mobile6.5引入了Widget功能。為Windows Mobile開發提供了新的方式,使得開發Windows Mobile程序變得更簡便,Widget的規范請看下面鏈接:http://www.w3.org/TR/2008/WD-widgets-20081222/。Widget有三個關鍵文件如下圖。

Windows Mobile 6.5 新功能widget開發  - GameStart - Program  Management

Config.xml為配置文件,配置Widget的屬性,這些屬性包括名字,使用的html文件,是否訪問網絡以及圖標等等。

  1. <?xml version="1.0" encoding="utf-8" ?> 
  2. <widget version="1.0" xmlns="http://www.w3.org/ns/widgets" id=""> 
  3.     <name>Currency Converter</name> 
  4.     <content src="currency.htm" type="text/html" /> 
  5.     <access network="true" /> 
  6.     <icon src="currency.gif"/> 
  7.     <description>This is a currency converter widget!</description> 
  8. </widget>  

Currency.gif為圖標文件,實際應用中,該文件可以為png,ico等其他圖形格式。

Currency.htm為Widget的核心文件,開發Widget的核心就是開發該html文件,這里的html是指純html(RawHTML),開發者可以使用HTML來布局,使用CSS來定制樣式,使用JavaScript來控制業務邏輯。開發widget使我想起幾年前做JavaScript的日子,那時候還沒有Ajax,ASP.net的服務器控件的交互性十分差,用戶老是投訴界面的操作性,只好手工編寫大量的JavaScript來提高用戶體驗。每次調試JavaScript只能在IE5上執行,然后alert()出調試信息。開發Widget,我還沒有找到很好的方法進行調試,還是有點像以前開發JavaScript那樣,使用alert()的方式進行調試。

實現

HTML

  1. <html> 
  2. <head> 
  3.     <title>Currency Converter</title> 
  4.     <script src="currency.js" type="text/javascript"></script> 
  5. </head> 
  6. <body> 
  7. <table> 
  8.     <tr> 
  9.         <td> 
  10.         From   
  11.         </td> 
  12.         <td> 
  13.             <select id="FromBox"> 
  14.               <option value="AUD" selected="selected">Australian Dollar(AUD)</option> 
  15.               <option value="CNY">Chinese Yuan(CNY)</option> 
  16.               <option value="HKD">Hong Kong Dollar(HKD)</option> 
  17.               <option value="USD">U.S. Dollar(USD)</option> 
  18.             </select> 
  19.         </td> 
  20.     </tr> 
  21.     <tr> 
  22.         <td> 
  23.         To   
  24.         </td> 
  25.         <td> 
  26.             <select id="ToBox"> 
  27.               <option value="AUD">Australian Dollar(AUD)</option> 
  28.               <option value="CNY" selected="selected">Chinese Yuan(CNY)</option> 
  29.               <option value="HKD">Hong Kong Dollar(HKD)</option> 
  30.               <option value="USD">U.S. Dollar(USD)</option> 
  31.             </select> 
  32.         </td> 
  33.     </tr> 
  34.     <tr> 
  35.         <td colspan=2> 
  36.         <input type="text" id="Result" readonly onclick="clickConvert()" />   
  37.         </td> 
  38.     </tr> 
  39. </table> 
  40. </body> 
  41. </html>  

這里的HTMl十分簡單,只是顯示兩個下拉框來表示幣種,使用一個inputtext來顯示Webservice查詢結果。

 

Windows Mobile 6.5 新功能widget開發  - GameStart - Program  Management

 

#p#

菜單

菜單指的是Windows Mobile的左右操作菜單,widget.menu為Windows Mobile特有,在PC上調試該菜單不能呈現。

  1. var menu = widget.menu;  
  2. var menumenu1001 = menu.createMenuItem(1001);  
  3. menu1001.text = "Convert";  
  4. menu1001.onSelect = clickConvert;  
  5. menu.setSoftKey(menu1001, menu.leftSoftKeyIndex); 

上面代碼重寫左邊菜單,顯示"Convert",并且綁定事件方法clickConvert,效果圖如上。

調用WebService

該匯率轉換程序是通過查詢WebService來實現的,我使用的是http://www.webservicex.net/免費的WebService。調用WebService的代碼如下:

  1. var xmlHttpRequest = null;  
  2.  
  3. function clickConvert() {  
  4.     if (window.XMLHttpRequest)   
  5.     {  
  6.         xmlHttpRequest = new XMLHttpRequest();  
  7.     }  
  8.     else if (window.ActiveXObject)   
  9.     {  
  10.         xmlHttpRequest = new ActiveXObject("Microsoft.XMLHTTP");  
  11.     }  
  12.       
  13.     var url = "http://www.webservicex.net/CurrencyConvertor.asmx/ConversionRate?FromCurrency="   
  14.                 + document.getElementById("FromBox").value   
  15.                 + "&ToCurrency="  
  16.                 + document.getElementById("ToBox").value;  
  17.     xmlHttpRequest.open("GET", url, true);  
  18.     xmlHttpRequest.onreadystatechange = getData;  
  19.     xmlHttpRequest.send(null);  
  20. }  
  21.  
  22. function getData() {  
  23.     if ((xmlHttpRequest.readyState == 4) &&( xmlHttpRequest.status == 200))  
  24.     {  
  25.  
  26.         var myXml = xmlHttpRequest.responseXML;  
  27.         var xmlobject = null;  
  28.         var XMLText = null;  
  29.         if (window.ActiveXObject)  
  30.         {  
  31.             XMLText = myXml.childNodes[1].firstChild.nodeValue;   
  32.         }  
  33.         else  
  34.         {  
  35.             XMLText = myXml.childNodes[0].firstChild.nodeValue;  
  36.         }  
  37.         var result = document.getElementById("Result");  
  38.         result.value = document.getElementById("FromBox").value  
  39.                                + " to "  
  40.                                + document.getElementById("ToBox").value  
  41.                                + " : "  
  42.                                + XMLText;  
  43.     }   

先生成XMLHttpRequest的對象,組成需要訪問的WebService的Url,通過GET的方式進行訪問。返回結果的處理是異步的,通過onreadystatechange屬性指定異步處理函數。在訪問過程中,getData()會被回調幾次,需要判斷xmlHttpRequest的readyState和status來決定結果的返回。返回結果的讀取和WebService的接口有關,根據WebService的出口分析需要的數據。這樣一個調用WebService的過程就完成了。

調試

可以通過PC的IE進行調試,但是由于IE上沒有Windows Mobile的菜單,所以需要做一點點特殊處理,例如我把名為Result的input框加入菜單的事件,那樣在IE上只要點擊該input框就可以進行調試了。

  1. <input type="text" id="Result" readonly onclick="clickConvert()" />  

理論上也可以使用FireBug來進行調試,可是平臺相關性的在Firefox就不能用了。

構建

構建過程很簡單,不需要編譯,只需要壓縮成zip格式的文件,把名字改成*.wgt或者*.widget就可以了。

Windows Mobile 6.5 新功能widget開發  - GameStart - Program  Management

我使用的7zip來進行構建,也可以寫批處理文件進行構建,例如mark.bat文件,在批處理文件內進行壓縮。

 

Windows Mobile 6.5 新功能widget開發  - GameStart - Program  Management

 

 

 

部署

把*.wgt文件拷貝到SDcard。在Windows Mobile打開SDCard。

Windows Mobile 6.5 新功能widget開發  - GameStart - Program  Management
Windows Mobile 6.5 新功能widget開發  - GameStart - Program  Management

點擊Yes進行安裝。

運行

安裝后在Start菜單看到新的Widget。

Windows Mobile 6.5 新功能widget開發  - GameStart - Program  Management

運行結果如下。

Windows Mobile 6.5 新功能widget開發  - GameStart - Program  Management

目前為止一個調用WebService的Widget已經完成了。是不是很簡單呢,我們基于免費WebService開發其他Widget

小結:Windows Mobile 6.5新功能Widget開發詳解的內容介紹完了,希望通過Windows Mobile Widget開發內容的學習能對你有所幫助!

責任編輯:zhaolei 來源: 博客園
相關推薦

2011-09-08 10:29:27

Windows MobWidget

2010-05-23 10:29:29

Widget開發

2011-09-08 10:18:09

Windows MobWidgets

2009-06-23 10:06:03

2011-04-25 16:40:21

開發環境搭建Windows Mob

2013-08-19 16:27:08

Windows 8.1

2012-08-22 15:45:29

Windows Ser

2009-05-18 09:06:37

微軟WMWindows Mob

2009-05-19 10:44:23

微軟Windows mob移動OS

2011-04-25 17:17:55

Gesture APIWindows Mob

2009-02-18 21:16:16

2009-06-04 14:18:44

Windows Mob工具包

2009-06-01 08:48:44

微軟Windows Mob移動OS

2009-04-28 09:47:44

WM6.5Windows Mob智能手機

2009-03-12 08:34:54

2010-03-26 09:13:00

Windows Mob系統更新

2009-02-17 10:41:38

Windows Mob操作高清照片

2010-02-02 17:04:38

Windows MobWindows Mob下載

2009-07-07 08:46:11

微軟Windows 7新功能

2011-09-09 20:14:58

Android Wid
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 一区二区三区在线 | 黄色精品| 久久久久久99 | 成人免费观看视频 | 日韩电影免费在线观看中文字幕 | 99视频免费看 | 91亚洲国产成人精品一区二三 | 99在线观看视频 | 日韩av一区二区在线 | 国产福利91精品 | 狠狠插狠狠操 | 亚洲一区二区电影在线观看 | 亚洲一区二区电影网 | www.久久久久久久久 | 日韩一区二区三区在线 | 亚洲日韩中文字幕一区 | 一级特黄色毛片 | 99色综合| 蜜臀久久| 毛片网站在线观看视频 | 久久久久久亚洲欧洲 | 亚洲精品一区二区三区在线 | 国产成人精品视频在线观看 | 国产在线中文 | 免费观看一级毛片 | 一区二区三区在线看 | 波多野结衣精品 | 欧美久久一级 | 久久精品国产一区二区三区不卡 | 国产一区二区在线免费观看 | 99国内精品 | 国产精品视频久久久久久 | 国产精品一区二区无线 | 精品国产乱码久久久久久蜜臀 | 午夜成人免费视频 | 91大神在线看 | 日韩在线视频免费观看 | 91精品国产综合久久久密闭 | 国产农村妇女毛片精品久久麻豆 | 中文字幕日韩欧美一区二区三区 | 国产一区二区精华 |