首先聲明:本人大菜鳥一個,剛接觸AS3不久,許多理念還沒來得及灌輸,這些case都是從網(wǎng)上down的,但因為解說是英文的,不利我們學(xué)習(xí),我就充當一個translater,順便可以讓自己鞏固一下知識。
水平有限,錯誤難免,歡迎大蝦小蝦,大鳥小鳥指正。
下面進入正題:
案例4:熟悉xml的運用
說明:一個簡單的相冊,先載入xml,然后載入xml列表里的images縮略圖,點擊縮略圖出現(xiàn)大圖以及大圖的說明。這個案例較前面幾個復(fù)雜了一些,不過如果熟悉了AS3的語法,還是比較容易理解的。
演示:http://www.live-my-life-with-yuyi.com/as3_cases/gallery_tween/
代碼:
import fl.transitions.Tween; import fl.transitions.easing.*; var imageText:TextField = new TextField(); var fadeTween:Tween; var imageLoader:Loader; var xml:XML; var xmlList:XMLList; var xmlLoader:URLLoader = new URLLoader(); xmlLoader.load(new URLRequest("data/images.xml")); xmlLoader.addEventListener(Event.COMPLETE, xmlLoaded);
跟之前的一樣,先導(dǎo)入幾個包,這是為了實現(xiàn)圖片的漸入漸出效果。然后是定義幾個變量,這里xmlList可能比較陌生,這個變量的作用主要是獲得xml的child列表,下面具體運用的時候,它的作用就一目了然了。 通過URLLoader載入xml,然后監(jiān)聽xml,一旦載入完成,就觸發(fā)xmlLoaded函數(shù)。
function xmlLoaded(event:Event):void { xml = XML(event.target.data); xmlList = xml.children(); for(var i:int = 0; i < xmlList.length(); i++) { imageLoader = new Loader(); imageLoader.load(new URLRequest(xmlList[i].attribute("thumb"))); imageLoader.x = 25; imageLoader.y = i * 150 + 25; imageLoader.name = xmlList[i].attribute("source"); addChild(imageLoader); imageLoader.addEventListener(MouseEvent.CLICK, showPicture); } }
這里有一些地方需要注意,比如第一句
xml = XML(event.target.data);
如果直接
xml = event.target.data
會報錯,因為兩個變量的類型不一樣。
這里可以看到xmlList,它是取得xml的children,對于使用xml非常方便。 然后實例化imageLoader,并載入xmlList里定義的縮略圖,注意這里的寫法。 調(diào)整一下坐標,并給imageLoader添加了一個name屬性,這個屬性的值就是xml文件里的圖片地址,這有利于下面的showPicture函數(shù)。 然后將縮略圖放到舞臺上,并監(jiān)聽它的鼠標點擊事件。
function showPicture(event:MouseEvent):void { imageLoader = new Loader(); imageLoader.load(new URLRequest(event.target.name)); imageLoader.x = 200; imageLoader.y = 25; addChild(imageLoader); imageText.x = imageLoader.x; imageText.y = 351; for(var j:int = 0; j < xmlList.length(); j++) { if(xmlList[j].attribute("source") == event.target.name) { imageText.text = xmlList[j]; } } fadeTween = new Tween(imageLoader,"alpha",None.easeNone,0,1,1,true); } imageText.autoSize = TextFieldAutoSize.LEFT; addChild(imageText);
這個點擊后顯示大圖的函數(shù),由于前面已經(jīng)給name屬性添加了圖片地址,所以這里直接拿來用就可以了。 大圖載入后分配一下坐標,添加到舞臺上,接下來就該顯示圖片的說明了。 這里的做法是循環(huán)xmlList,然后比較xml里source是否與這里的name相等,是的話,將該xml的值賦予imageText,不過顯然有更簡單的做法,就是在上面的xmlLoaded函數(shù)中為imageLoader添加一個text屬性,然后在showPicture里直接拿來用就可以了。 然后給圖片來一個漸入效果,這個之前已經(jīng)講過了。 最后兩行是定義imageText的對齊方式,這里是左對齊,然后放到舞臺上。
整個案例到此結(jié)束。
源文件下載
經(jīng)典論壇討論: http://bbs.blueidea.com/thread-2807809-1-1.html
本文鏈接:http://m.95time.cn/tech/multimedia/2007/5100.asp
出處:藍色理想
責(zé)任編輯:moby
◎進入論壇RIA設(shè)計與應(yīng)用版塊參加討論
|