Flex上傳本地圖片并提前瀏覽的實(shí)現(xiàn)方法
更新時(shí)間:2014年01月14日 15:02:50 作者:
個(gè)性頭像最終需要上傳到服務(wù)器的文件系統(tǒng)中,但是程序希望在用戶選擇后直接有個(gè)預(yù)覽,針對這個(gè)問題,下面有個(gè)不粗的實(shí)現(xiàn),希望對大家有所幫助
經(jīng)常會(huì)設(shè)計(jì)一個(gè)這樣的功能,比如更改個(gè)性頭像,這個(gè)個(gè)性頭像最終需要上傳到服務(wù)器的文件系統(tǒng)中,但是程序希望在用戶選擇后直接有個(gè)預(yù)覽,然后用戶才進(jìn)行上傳。這個(gè)功能技術(shù)上其實(shí)就是需要對本地的文件能進(jìn)行讀取。在flash player10中有個(gè)類FileReference的類可以實(shí)現(xiàn)這個(gè)功能,而實(shí)現(xiàn)對文件讀取的接口是load( )函數(shù),要注意的是:
a、這個(gè)函數(shù)只能在UI操作中使用,比如用戶按下按鈕。
b、加載進(jìn)來后的本地文件無法在AS中使用
c、這個(gè)接口是一個(gè)異步的過程,也就不是馬上就加載進(jìn)來,需要加Listener來操作。
下面是參考代碼
<?xml version="1.0" encoding="utf-8"?>
<s:Application xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark"
xmlns:mx="library://ns.adobe.com/flex/mx" minWidth="955" minHeight="600"
creationComplete="creationCompleteHandler(event)">
<fx:Script>
<![CDATA[
import flash.net.FileReference;
import flash.net.FileFilter;
import flash.events.IOErrorEvent;
import flash.events.Event;
private var fr:FileReference;
private var imageTypes:FileFilter;
private function creationCompleteHandler(event:Event):void {
fr = new FileReference();
imageTypes = new FileFilter("Images (*.jpg, *.jpeg, *.png, *.gif)","*.jpg; *.jpeg; *.png; *.gif;")
fr.addEventListener(Event.SELECT, selectHandler);//增加當(dāng)打開瀏覽文件后,用戶選擇好文件后的Listener
}
private function browseHandler(event:Event):void {
fr.browse([imageTypes]);//打開瀏覽文件的dialog
}
private function selectHandler(event:Event):void {
fr.addEventListener(Event.COMPLETE, onLoadComplete);//增加一個(gè)文件加載load完成后的listener
fr.load(); //加載用戶選中文件
}
private function onLoadComplete(e:Event):void
{
imgPhoto.source = fr.data;
}
]]>
</fx:Script>
<s:layout>
<s:BasicLayout/>
</s:layout>
<fx:Declarations>
<!-- 將非可視元素(例如服務(wù)、值對象)放在此處 -->
</fx:Declarations>
<mx:Image id="imgPhoto" visible="true" autoLoad="true" width="1000" height="500"/>
<mx:Button id="btnBrowse" label="Browse" click="browseHandler(event)" />
</s:Application>
a、這個(gè)函數(shù)只能在UI操作中使用,比如用戶按下按鈕。
b、加載進(jìn)來后的本地文件無法在AS中使用
c、這個(gè)接口是一個(gè)異步的過程,也就不是馬上就加載進(jìn)來,需要加Listener來操作。
下面是參考代碼
復(fù)制代碼 代碼如下:
<?xml version="1.0" encoding="utf-8"?>
<s:Application xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark"
xmlns:mx="library://ns.adobe.com/flex/mx" minWidth="955" minHeight="600"
creationComplete="creationCompleteHandler(event)">
<fx:Script>
<![CDATA[
import flash.net.FileReference;
import flash.net.FileFilter;
import flash.events.IOErrorEvent;
import flash.events.Event;
private var fr:FileReference;
private var imageTypes:FileFilter;
private function creationCompleteHandler(event:Event):void {
fr = new FileReference();
imageTypes = new FileFilter("Images (*.jpg, *.jpeg, *.png, *.gif)","*.jpg; *.jpeg; *.png; *.gif;")
fr.addEventListener(Event.SELECT, selectHandler);//增加當(dāng)打開瀏覽文件后,用戶選擇好文件后的Listener
}
private function browseHandler(event:Event):void {
fr.browse([imageTypes]);//打開瀏覽文件的dialog
}
private function selectHandler(event:Event):void {
fr.addEventListener(Event.COMPLETE, onLoadComplete);//增加一個(gè)文件加載load完成后的listener
fr.load(); //加載用戶選中文件
}
private function onLoadComplete(e:Event):void
{
imgPhoto.source = fr.data;
}
]]>
</fx:Script>
<s:layout>
<s:BasicLayout/>
</s:layout>
<fx:Declarations>
<!-- 將非可視元素(例如服務(wù)、值對象)放在此處 -->
</fx:Declarations>
<mx:Image id="imgPhoto" visible="true" autoLoad="true" width="1000" height="500"/>
<mx:Button id="btnBrowse" label="Browse" click="browseHandler(event)" />
</s:Application>
相關(guān)文章
獲取到AdvancedDataGrid選中行的全部數(shù)據(jù)
通過AdvancedDataGrid的id來獲取selectedItem和selectedItems屬性,下面有個(gè)不不錯(cuò)的示例大家可以參考下2014-02-02
Flex設(shè)置LinkButton的背景色有思路有源碼
Flex中沒有設(shè)置LinkButton的背景色的屬性,可以直接通過調(diào)用樣式方法畫出LinkButton的背景色2014-08-08
flex中使用css樣式修改TextArea滾動(dòng)條的皮膚代碼
使用css樣式修改TextArea滾動(dòng)條的皮膚,具體示例代碼如下,感興趣的朋友可以參考下,希望對大家有所幫助2013-08-08
Flex中TitleWindow傳值思路及實(shí)現(xiàn)
這篇文章主要介紹了Flex中TitleWindow傳值思路及實(shí)現(xiàn),需要的朋友可以參考下2014-05-05
Flex打開新窗口將主窗口數(shù)據(jù)傳給子窗口然后返回
主窗口打開子窗口,主窗口有數(shù)據(jù)傳給打開的子窗口,子窗口關(guān)閉時(shí)直接返回主窗口,具體的實(shí)現(xiàn)如下,感興趣的朋友可以參考2013-12-12

