国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 辦公 > Flash > 正文

AS3.0實例學習 熟悉xml的運用

2024-09-12 17:50:54
字體:
供稿:網(wǎng)友
案例4:熟悉xml的運用

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

跟之前的一樣,先導入幾個包,這是為了實現(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é)束。
打包文件
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 玉溪市| 舒城县| 连江县| 平远县| 清新县| 沧源| 乐至县| 宾阳县| 贵溪市| 英吉沙县| 武陟县| 名山县| 祁阳县| 关岭| 绥江县| 阿克苏市| 临漳县| 朝阳市| 贡觉县| 松溪县| 南京市| 东山县| 维西| 桦甸市| 渭南市| 蓝田县| 天水市| 潮州市| 绥棱县| 普兰店市| 蚌埠市| 平原县| 江津市| 都昌县| 玉龙| 临泉县| 土默特右旗| 博罗县| 陵水| 吉隆县| 波密县|