flex2使用webservice完成天氣預報

http://www.webservicex.net/globalweather.asmx是一個公共免費的webservice接口,提供全球主要城市的當天天氣情況(包括中國的主要城市),firefox下打開鏈接,用GetCitiesByCountry方法和china參數試運行一下,可以看到返回一個xml結構表示支持的城市名稱(用這些城市名稱作爲參數使用GetWeather方法就能得到天氣信息了)。下面我們就使用flex2豐富的用戶體驗來實現簡單的天氣查詢系統。
IDE:Flex builder 3

打開flex 2 language reference,可以看到web service 應用相關的namespace有兩個:
  • mx.rpc.soap
  • mx.rpc.soap.mxml
從名稱上來看,後者是前者的component封裝(實際上就是如此),說白了mx.rpc.soap.mxml下的兩個class可以使用mxml tag的聲明方式來定義一個web service,一般情況下,這樣的聲明方式可讀性還是比較好的,代碼量比較少,還有一些UI上擴展的功能可以利用(比如WebService class的ShowBusyCursor方法)。聲明方式很簡單
xml 代碼
 
  1. <mx:WebService id="weatherWS" wsdl="http://www.webservicex.net/globalweather.asmx?WSDL" showBusyCursor="true" fault="wsFaultPopAlert()"/>  
這就是一個簡單的webservice定義,然後我們可以加上operation聲明,或者使用編程方式調用。以本例來講,可以直接使用編程方式調用,就跟普通的方法調用形式一樣:
xml 代碼
  1. weatherWS.GetCitiesByCountry("China");  
很簡單吧,都不需要關注底層技術。

聲明方式也是可以的:
xml 代碼
 
  1. <mx:WebService id="weatherWS" wsdl="http://www.webservicex.net/globalweather.asmx?WSDL" showBusyCursor="true" fault="wsFaultPopAlert()">  
  2.     <mx:operation name="GetCitiesByCountry"/>  
  3. mx:WebService>  
mx:operation其實就是mx.rpc.soap.mxml.Operation,裏面有一個public funciton -- send(...args),代表方法調用,於是:
xml 代碼
  1. weatherWS.GetCitiesByCountry.send("china")  
這樣也是可以的。

除此以外WebService提供兩個event:
分別代表調用出錯和成功事件,兩者都沒有提供用戶默認實現,需要用編程方式實現事件處理。特別是用ResultEvent可以獲得調用結果(就是本例開始獲得的xml結果,剩下的處理就是分析xml結構啦)。

下面是模塊代碼:
xml 代碼
 
  1. xml version="1.0" encoding="utf-8"?>  
  2. <mx:Panel xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" width="174" height="200" title="Weather" creationComplete="init()">  
  3.       
  4.     <mx:Script>  
  5.          
  6.             private var citysArr:Array = new Array(); 
  7.              
  8.             private function init():void 
  9.             { 
  10.                 citysArr.push({label:"choose..."}); 
  11.                 cityCombo.selectedIndex = 0; 
  12.                 weatherWS.addEventListener(ResultEvent.RESULT, wsResult); 
  13.                 weatherWS.GetCitiesByCountry("China"); 
  14.                  
  15.                 this.title = "Weather(connecting...)"; 
  16.             } 
  17.              
  18.             private function wsResult(eve:ResultEvent):void 
  19.             { 
  20.                 this.title = "Weather"; 
  21.                 weatherWS.removeEventListener(ResultEvent.RESULT,wsResult); 
  22.                 XML.ignoreWhitespace = true; 
  23.                 XML.ignoreComments = true; 
  24.                 XML.ignoreProcessingInstructions = true; 
  25.                 var xml:XML = new XML(eve.result.toString()); 
  26.                  
  27.                 var cityNum:int = xml.Table.length(); 
  28.                 for(var i:int=0 ; i 
  29.                 { 
  30.                     citysArr.push({label:xml.Table[i].City}); 
  31.                 } 
  32.                  
  33.                 cityCombo.addEventListener(ListEvent.CHANGE, cityListChooseHandler); 
  34.                 weatherWS.addEventListener(ResultEvent.RESULT, onCityInfo); 
  35.             } 
  36.              
  37.              
  38.             private function cityListChooseHandler(eve:ListEvent):void 
  39.             { 
  40.                 var cityName:String = cityCombo.selectedLabel; 
  41.                 cityInfo.htmlText = ""; 
  42.                 weatherWS.GetWeather(cityName,"china"); 
  43.             } 
  44.              
  45.             private function onCityInfo(eve:ResultEvent):void 
  46.             { 
  47.                 var xml:XML = new XML(eve.result.toString()); 
  48.                 var infoNum:int = xml.children().length(); 
  49.                 for(var i:int=0 ; i 
  50.                 { 
  51.                     var nodestr:String = xml.children()[i].toXMLString(); 
  52.                     cityInfo.htmlText += " 
  53.                 } 
  54.             } 
  55.              
  56.             private function wsFaultPopAlert():void 
  57.             { 
  58.                 Alert.show("WebService access failed"); 
  59.             } 
  60.         ]]>  
  61.     mx:Script>  
  62.       
  63.     <mx:WebService id="weatherWS" wsdl="http://www.webservicex.net/globalweather.asmx?WSDL" showBusyCursor="true" fault="wsFaultPopAlert()"/>  
  64.       
  65.     <mx:Label x="0" y="0" text="City"/>  
  66.     <mx:ComboBox id="cityCombo" x="34" y="-2" width="120" dataProvider="{citysArr}" labelField="label"/>  
  67.     <mx:TextArea id="cityInfo" x="0" y="26" width="100%" height="100%" selectable="false"/>  
  68.     <mx:ControlBar>  
  69.     mx:ControlBar>  
  70. mx:Panel>  
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章