Link:INB Home|INB English| INB русский язык|INB العربية|INB Türkiye|INB فارسی|INB Español|INB Français|INB Português|INB Deutsch|INB 國語|INB 中文|INB 日本语|INB 한국어|INB ภาษาไทย|INB tiếng Việt||FL 教程Flash 通過實例學習Flash AS3.0——案例四-
INB 國語論壇
歡迎光臨(工業與草根研究員)對工業時代充滿了戰鬥精神,你和我都通過網絡空間與當地草根精神研究員來到瘋狂實驗室。家inbforum.com,永久名稱:tw-inbforum.forums2u.com
INB 國語論壇
歡迎光臨(工業與草根研究員)對工業時代充滿了戰鬥精神,你和我都通過網絡空間與當地草根精神研究員來到瘋狂實驗室。家inbforum.com,永久名稱:tw-inbforum.forums2u.com
INB 國語論壇

歡迎光臨(工業與草根研究員)對工業時代充滿了戰鬥精神,你和我都通過網絡空間與當地草根精神研究員來到瘋狂實驗室。家inbforum.com,永久名稱:tw-inbforum.forums2u.com


您沒有登錄。 請登錄註冊

《《《《《《《上一页INBforum   向下

上一页INBforum》》》》》》》上一篇主題 下一篇主題 向下  內容 [第1頁(共1頁)]

1FL 教程Flash 通過實例學習Flash AS3.0——案例四- Empty FL 教程Flash 通過實例學習Flash AS3.0——案例四- 周四 3月 03, 2011 7:22 am

Admin

Admin
Admin
首先聲明:本人大菜鳥一個,剛接觸AS3不久,許多理念還沒來得及灌輸,這些case都是從網上down的,但因為解說是英文的,不利我們學習,我就充當一個translater,順便可以讓自己鞏固一下知識。

水平有限,錯誤難免,歡迎大蝦小蝦,大鳥小鳥指正。

下面進入正題:





案例4:熟悉xml的運用

說明:一個簡單的相冊,先載入xml,然后載入xml列表里的images縮略圖,點擊縮略圖出現大圖以及大圖的說明。這個案例較前面幾個復雜了一些,不過假如熟悉了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);





跟之前的一樣,先導入幾個包,這是為了實現圖片的漸入漸出效果。然后是定義幾個變量,這里xmlList可能比較生疏,這個變量的作用主要是獲得xml的child列表,下面具體運用的時候,它的作用就一目了然了。
通過URLLoader載入xml,然后監聽xml,一旦載入完成,就觸發xmlLoaded函數。

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里定義的縮略圖,注重這里的寫法。
調整一下坐標,并給imageLoader添加了一個name屬性,這個屬性的值就是xml文件里的圖片地址,這有利于下面的showPicture函數。
然后將縮略圖放到舞臺上,并監聽它的鼠標點擊事件。

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);





這個點擊后顯示大圖的函數,由于前面已經給name屬性添加了圖片地址,所以這里直接拿來用就可以了。
大圖載入后分配一下坐標,添加到舞臺上,接下來就該顯示圖片的說明了。

里的做法是循環xmlList,然后比較xml里source是否與這里的name相等,是的話,將該xml的值賦予imageText,不過顯然有更簡
單的做法,就是在上面的xmlLoaded函數中為imageLoader添加一個text屬性,然后在showPicture里直接拿來用就可以了。
然后給圖片來一個漸入效果,這個之前已經講過了。
最后兩行是定義imageText的對齊方式,這里是左對齊,然后放到舞臺上。





整個案例到此結束。

源文件下載]

http://tw.inbforum.com

上一页INBforum   向下

上一页INBforum上一篇主題 下一篇主題 回頂端  內容 [第1頁(共1頁)]

這個論壇的權限:
無法 在這個版面回復文章

Copyright ©2009-2010 LTD Creative Commons License
This work is licensed under a Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.

IT:SINGLESERVGoogle谷歌翻译TranslateFORUMSOFTLAYERGoogle谷歌广告联盟AdSenseAsia

 

Free forum | ©phpBB | 免費論壇互助中心 | 違法舉報 | Latest discussions