學習總結 在Flex中如何嵌入Flex字體
本文和大家重點討論一下在Flex中嵌入Flex字體方法,在Flex中所有非系統安裝Flex字體都需要注冊后才能使用。希望本文的介紹能讓你有所收獲。
在Flex中嵌入Flex字體方法總結
嵌入Flex字體
語法
- [Embed(source="C:/WINDOWS/Fonts/arial.ttf",
- fontName="Arial",
- mimeType="application/x-font")]
- private var ArialFont:Class;
source: 字體文件所在路徑(本地)
fontName: 程序中所使用的字體別名
mimeType: 照抄就行了=_=
其中source還可以是指定為字體名稱,而不一定是字體文件.另外還有其它屬性可以設置,詳細查看這里
在Flex中所有非系統安裝Flex字體都需要注冊后才能使用。對于一個用上述方法直接嵌入字體的Flex程序,該嵌入字體會被自動注冊。
可以通過以下程序查詢:
- var font_list:Array = Font.enumerateFonts();
- for(var i:int=0; i<font_list.length; i++)
- trace(Font(font_list[i]).fontName);
嵌入的Flex字體會排列在前面.
◆問題是,如果系統里面有這個字體,我何必還要去嵌入呢?
假如你的系統里面有個奇怪的字體,當你肆無忌憚的用在了你的項目里,而整個作品仍到網上后,其它用戶的機器里面沒有這個奇怪的字體,他們可能就看不到,或者看到的是他們系統中所帶字體顯示出來的文字。這顯然不是你想要的,所以,在使用一些別人可能沒有的字體時,嵌入是很有必要的.但如果就這樣直接嵌入,最直接的影響就是加大swf文件的大小.可憐我們這些用漢字的,一個中文字體動不動就幾M...orz.如果一個項目有一堆swf要用幾個相同的中文字體,每個swf都嵌一遍,估計這個項目加起來不會比帝國時代來的小-_-.說的再技術性一點,這么做還不便于維護,修改等等......
此類問題可算是老生常談了,所以我們要做的辦法就是共享字體.
這個方法在flash里面很簡單,只要在庫中選擇添加新字體,然后選擇自己要的字體,修改元件屬性為共享導出,最后發布就行了.具體看這里
整個過程就是如何去使用共享庫,這個技術很古老了,但還是很管用的,到了Flex2,這個過程實際上更簡單了,如果有flash的朋友,可以直接看Flex的幫助 - 如何使用flash類型的字體
我這里要講的是,不用flash,直接用Flex完成所有動作.
首先,挑個要嵌入的Flex字體,比如04b_08,這個字體不是每個人都裝的.因為Flex可以用程序來支持直接嵌入字體,所以挑的字體不管是否已經安裝在系統中,都是無所謂的.測試的時候,你也可以把安裝在系統中的字體先刪除(記得備份),有些系統字體是無法刪除的,比如Arail,Verdana,宋體等.
接著,建立一個as文件,叫FontAssets.as好了,寫入如下代碼后保存 package
- {
- import flash.display.Sprite;
- public class FontAssets extends Sprite
- {
- [Embed(source="assets/04b_08.ttf", fontName="04b_08", mimeType="application/x-font")]
- public var PixelFont:Class;
- }
- }
as3語法我就不多說了,不清楚的看這里
◆為什么要繼承Sprite呢?
因為這個swf文件要在以后的程序中被加載.被加載的swf基類必須是繼承Sprite的.你不信的可以試試不繼承,這個swf可以通過編譯,但加載他的就無法通過編譯了,如果關掉嚴格檢測,運行時就會拋異常...
其實嘛,想想flash,root的類型就是MovieClip,是必然存在的,所以要生成一個swf,必須繼承Sprite也是合理的.因為在as3里面,MovieClip是繼承Sprite的
◆兩個字體對象,為什么要聲明為public呢?
因為到時候要在外部訪問這兩個對象呀.當然,有心人也可以用getter方法來設置成為"只讀"的,我這里就懶一下了^^_.
接著,建立一個mxml文件,叫testSharedFonts.mxml.寫入以下代碼并保存
- <?xml version="1.0" encoding="utf-8"?>
- <mx:Application
- xmlns:mx="http://www.adobe.com/2006/mxml"
- layout="absolute"
- styleName="plain"
- >
- <mx:Script>
- <![CDATA[
- private function fontLoadComplete(evt:Event):void
- {
- try{
- Font.registerFont( evt.target.content["PixelFont"] );
- txt1.setStyle("fontFamily", "04b_08");
- }
- catch(e:Error){
- trace(e.toString());
- }
- }
- ]]>
- </mx:Script>
- <mx:SWFLoader source="FontAssets.swf" complete="fontLoadComplete(event);"/>
- <mx:VBox>
- <mx:Text id="txt1" text="test words" fontSize="12"/>
- <mx:Text id="txt2" text="test words" fontSize="12"/>
- </mx:VBox>
- </mx:Application>
◆Flex字體嵌入成功,要注意以下幾點
1.注冊字體的時候,訪問PixelFont的方法是當初AS2時候典型的作弊方法,目的為了騙過編譯器,省的它說,當前對象沒有這個變量或方法.但是 AVM2比較牛,如果訪問的變量或方法確實不存在或者是訪問權限不對,它會在運行時拋異常,這也是為什么,上面我要聲明為public的原因!
2.加載進來的共享字體,一定要先注冊才能使用,對于FontAssets.swf,前面說過,當PixelFont在嵌入的同時就已經注冊好了,但是對于testSharedFonts.swf,則不是,所以加載完了FontAssets.swf之后,還要注冊.
3.一個FontAssets可以同時嵌入多個字體,這樣就可以形成一個共享字體庫,但要注意如果字體太多,這個庫(swf文件)也會變的很大.
【編輯推薦】