通過(guò)實(shí)例學(xué)習(xí)Flash AS3.0——案例四_Flash教程
推薦:通過(guò)實(shí)例學(xué)習(xí)AS3.0——案例三首先聲明:本人大菜鳥(niǎo)一個(gè),剛接觸AS3不久,許多理念還沒(méi)來(lái)得及灌輸,這些case都是從網(wǎng)上down的,但因?yàn)榻庹f(shuō)是英文的,不利我們學(xué)習(xí),我就充當(dāng)一個(gè)translater
首先聲明:本人大菜鳥(niǎo)一個(gè),剛接觸AS3不久,許多理念還沒(méi)來(lái)得及灌輸,這些case都是從網(wǎng)上down的,但因?yàn)榻庹f(shuō)是英文的,不利我們學(xué)習(xí),我就充當(dāng)一個(gè)translater,順便可以讓自己鞏固一下知識(shí)。
水平有限,錯(cuò)誤難免,歡迎大蝦小蝦,大鳥(niǎo)小鳥(niǎo)指正。
下面進(jìn)入正題:
案例4:熟悉xml的運(yùn)用
說(shuō)明:一個(gè)簡(jiǎn)單的相冊(cè),先載入xml,然后載入xml列表里的images縮略圖,點(diǎn)擊縮略圖出現(xiàn)大圖以及大圖的說(shuō)明。這個(gè)案例較前面幾個(gè)復(fù)雜了一些,不過(guò)假如熟悉了AS3的語(yǔ)法,還是比較輕易理解的。
演示: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)入幾個(gè)包,這是為了實(shí)現(xiàn)圖片的漸入漸出效果。然后是定義幾個(gè)變量,這里xmlList可能比較生疏,這個(gè)變量的作用主要是獲得xml的child列表,下面具體運(yùn)用的時(shí)候,它的作用就一目了然了。
通過(guò)URLLoader載入xml,然后監(jiān)聽(tīng)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
會(huì)報(bào)錯(cuò),因?yàn)閮蓚(gè)變量的類型不一樣。
這里可以看到xmlList,它是取得xml的children,對(duì)于使用xml非常方便。
然后實(shí)例化imageLoader,并載入xmlList里定義的縮略圖,注重這里的寫(xiě)法。
調(diào)整一下坐標(biāo),并給imageLoader添加了一個(gè)name屬性,這個(gè)屬性的值就是xml文件里的圖片地址,這有利于下面的showPicture函數(shù)。
然后將縮略圖放到舞臺(tái)上,并監(jiān)聽(tīng)它的鼠標(biāo)點(diǎ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);
這個(gè)點(diǎn)擊后顯示大圖的函數(shù),由于前面已經(jīng)給name屬性添加了圖片地址,所以這里直接拿來(lái)用就可以了。
大圖載入后分配一下坐標(biāo),添加到舞臺(tái)上,接下來(lái)就該顯示圖片的說(shuō)明了。
這里的做法是循環(huán)xmlList,然后比較xml里source是否與這里的name相等,是的話,將該xml的值賦予imageText,不過(guò)顯然有更簡(jiǎn)單的做法,就是在上面的xmlLoaded函數(shù)中為imageLoader添加一個(gè)text屬性,然后在showPicture里直接拿來(lái)用就可以了。
然后給圖片來(lái)一個(gè)漸入效果,這個(gè)之前已經(jīng)講過(guò)了。
最后兩行是定義imageText的對(duì)齊方式,這里是左對(duì)齊,然后放到舞臺(tái)上。
整個(gè)案例到此結(jié)束。
分享:通過(guò)實(shí)例學(xué)習(xí)flash AS3.0——案例二首先聲明:本人大菜鳥(niǎo)一個(gè),剛接觸AS3不久,許多理念還沒(méi)來(lái)得及灌輸,這些case都是從網(wǎng)上down的,但因?yàn)榻庹f(shuō)是英文的,不利我們學(xué)習(xí),我就充當(dāng)一個(gè)translater
- as中禁用ESC鍵
- AS3.0 圖片變黑白 圖片彩色變黑白代碼
- flash as3.0 跨域的解決辦法
- 模板無(wú)憂FLASH透明代碼
- Flash教你制作卡通MM眨眼睛動(dòng)畫(huà)
- Flash從零開(kāi)始學(xué)習(xí)創(chuàng)建單選按鈕
- Flash繪制小龍與花插畫(huà)場(chǎng)景
- Flash程序的測(cè)試方法
- Flash CS4文字顏色緩動(dòng)特效
- 網(wǎng)頁(yè)中演示類FLASH動(dòng)畫(huà)制作規(guī)范
- Flash CS3循環(huán)背景的運(yùn)用技巧
- Flash鼠繪技巧教你制作紅綠色的樹(shù)葉
Flash教程Rss訂閱網(wǎng)站制作教程搜索
Flash教程推薦
- Flash MX2004入門(mén)與進(jìn)階實(shí)例——元件和實(shí)例(11)
- AS3.0 圖片變黑白 圖片彩色變黑白代碼
- Flash8制作動(dòng)態(tài)開(kāi)門(mén)效果網(wǎng)頁(yè)菜單
- Flash MX2004入門(mén)與進(jìn)階實(shí)例——?jiǎng)幼髂_本(4)
- Flash鼠繪技巧教你制作紅綠色的樹(shù)葉
- Flash MX2004入門(mén)與進(jìn)階實(shí)例——?jiǎng)幼髂_本進(jìn)階(1)
- Flash MX2004入門(mén)與進(jìn)階實(shí)例——元件和實(shí)例(1)
- Flash MX2004入門(mén)與進(jìn)階實(shí)例——聲音和視頻(14)
- Flash MX2004入門(mén)與進(jìn)階實(shí)例——時(shí)間軸特效和行為(3)
- 網(wǎng)頁(yè)中演示類FLASH動(dòng)畫(huà)制作規(guī)范
- 相關(guān)鏈接:
- 教程說(shuō)明:
Flash教程-通過(guò)實(shí)例學(xué)習(xí)Flash AS3.0——案例四
。