freetype 使用小結

FreeType是一個完全開源的、可擴展、可定製且可移植的字體引擎,它提供TrueType字體驅動的實現統一的接口來訪問多種字體格式文件,

包括點陣字、TrueType、OpenType、Type1、


CID、CFF、Windows FON/FNT、X11 PCF等。FreeType函數庫具有以下特點:
(1)它使得客戶應用程序可以方便地訪問字體文件,無論字體文件存儲在哪裏,並且與字體格式無關。
(2)能方便地提取全局字體數據,這些數據普遍存在於一般的字體格式中。(例如:全局度量標準,字符編碼/字符映射表,等等)
(3)能方便地提取某個字符的字形數據(度量標準,圖像,名字等其他任何數據)
(4)具備訪問字體格式特定的功能(例如:SFNT表,多重控制,OpenType輪廓表)


使用FreeType引擎來顯示字符的流程如圖.2所示(FreeType Team,2008)。
首先需要初始化FreeType庫,然後依次根據字符的編碼處理一個字符,把它轉化爲點陣的位圖信息,最後根據字符的信息,在相應的地方把它顯示出來。

根據以上流程圖相應的函數如下:
(1)首先對FreeType庫進行初始化,並且讀取矢量字庫文件。
FT_Init_FreeType(&library);//創建新的庫對象,準備作其他操作時使用FT_New_Face(library,filename,0,&face);
FT_Init_FreeType()他會缺省地註冊一些模塊。這個方式中,模塊列表在構建時動態計算,並依賴ftinit部件的內容。
FT_New_Face()通常用來創建外觀對象,如果函數調用成功,返回0。外觀對象包含一些用來描述全局字體數據的屬性,可以被客戶程序直接訪問。它包括外
觀中字形的數量、外觀家族的名稱、風格名稱、EM大小等。這個函數包括的參數library是一個全局的變量,而filename是矢量字庫的路徑(c文件路徑名)。
這裏通過以上兩個步驟首先建立了FreeType庫的一個實例。然後使用一個字庫文件來得到字體的face對象接口。


(2)得到face對象之後,需要設置當前字體的屬性,尺寸對象的內容可以通過調用函數FT_Set_Pixel_Sizes()來改變。
當一個新的face對象建立時,對於可伸縮字體格式,size對象默認值爲字符大小水平和垂直均爲10象素。對於定長字體格式,這個大小是未定義的,所以必
須在裝載一個字形前設置該值。
FT_Set_Pixel_Sizes(face,//當前face對象
16,//字符點陣寬度
16//字符點陣高度
);
以上函數把字符象素設置爲16*16象素,因此最後的位圖信息就是16*16點陣象素。


(3)設置完字體的屬性之後,需要得到字符的輪廓信息。
一個face對象包含一個或多個字符表(charmap),字符表是用來轉換字符碼到字形索引的。TrueType字體文件通常包含兩個字符表,一個用來轉換Unicode字
符碼到字形索引,另一個用來轉換Apple Roman編碼到字形索引。這樣的字體既可以用於Windows(使用Unicode),同時又可用於Macintosh(使用Apple Roman)。
另外需要注意,一個特定的字符表可能沒有覆蓋完字體裏面的全部字形。
當新建一個face對象時,它默認選擇Unicode字符表。根據字符的Unicode編碼來得到它的glyph索引。代碼如下:
FT_Get_Char_Index(face,charcode);這個函數會在face裏被選中的字符表中查找與給出的字符碼對應的字形索引。

從face中來得到字符對應的glyph後,需要讀取到glyph slo(t存儲字形的對象:字形槽)中才能使用。
FT_Load_Glyph(face,glyph_index,FT_LOAD_DEFAULT);
FT_Load_Glyph()的第三個參數是裝載標誌load_flags,其值是位標誌集合,用來指示某些特殊操作的,默認值爲FT_LOAD_DEFAULT即0。這個函數會設法
從face中裝載對應的字形圖像。
然後通過FT_Get_Glyph()簡單地提取一個字形圖像。FT_Get_Glyph(face->glyph,&glyph);最後把字形對象轉換成一個位圖:
FT_Glyph_To_Bitmap(&glyph,FT_RENDER_MODE_NORMAL,0,1);
glyph是源字形句柄的地址;第二個參數是標準的渲染模式;第三個參數是二維矢量的指針,該二維矢量是在轉換前用來平移源字形圖像的,該指針爲0時
表明渲染前不需要平移源字形;最後一個參數是一個布爾值,用來指示該函數是否要銷燬源字形對象。
bitmap=(FT_BitmapGlyph)glyph;經過轉化之後,字體的點陣信息就存放在bitmap參數裏面,再把點陣信息寫
入OSD的buffer中,即可顯示出相應的字符。
依據以上算法,將FreeType應用到高清播放機中時,能正常顯示菜單界面字幕。然而在播放影片的過程中,srt字幕顯示過慢,無法跟進視頻播放的進度,滯
後現象非常嚴重。

freetype相關鏈接:

1.http://www.freetype.org/freetype2/docs/tutorial/step1.html

2.http://www.unixresources.net/linux/clf/kylix/archive/00/00/59/21/592188.html

3.http://blog.csdn.net/absurd/archive/2006/10/28/1354499.aspx

4.http://www.wangchao.net.cn/bbsdetail_58348.html

5.http://topic.csdn.net/u/20080408/14/4C2ED903-3A22-46EC-8736-D9773FFB189A.html

6.http://www.wonstar.com/service/detail/124.html

7.http://book.csdn.net/bookfiles/308/10030812801.shtml

轉自:http://blog.csdn.net/saintevil/article/details/5747582#


libfreetype使用例子;

安裝我就不說了,自己安裝2.4.9版本;

例子代碼如下:

 

  1. #include <ft2build.h>  
  2. #include FT_FREETYPE_H  
  3. #include <freetype/freetype.h>  
  4. #include <freetype/ftglyph.h>  
  5.   
  6.   
  7. int main()  
  8. {  
  9.   
  10. FT_Library    pFTLib         =  NULL;  
  11. FT_Face        pFTFace         =  NULL;  
  12. FT_Error    error         =   0 ;  
  13. //Init FreeType Lib to manage memory  
  14. error  =  FT_Init_FreeType( & pFTLib);  
  15. if (error)  
  16. {  
  17.     pFTLib  =   0 ;  
  18.     printf( " There is some error when Init Library " );  
  19.      return   - 1 ;  
  20. }  
  21.   
  22. //create font face from font file  
  23. error  =  FT_New_Face(pFTLib,  "/usr/share/fonts/truetype/thai/Waree-Bold.ttf" ,  0 ,  & pFTFace);  
  24.  if ( ! error)  
  25.  {  
  26.     FT_Set_Char_Size(pFTFace,  16 << 6 ,  16 << 6 ,  300 ,  300 );  
  27.     FT_Glyph    glyph;  
  28.      //  load glyph 'C'  
  29.     FT_Load_Glyph(pFTFace, FT_Get_Char_Index(pFTFace,  67 ), FT_LOAD_DEFAULT);  
  30.     error  =  FT_Get_Glyph(pFTFace -> glyph,  & glyph);  
  31.      if ( ! error)  
  32.      {  
  33.          //  convert glyph to bitmap with 256 gray  
  34.         FT_Glyph_To_Bitmap( & glyph, ft_render_mode_normal,  0 ,  1 );  
  35.         FT_BitmapGlyph    bitmap_glyph  =  (FT_BitmapGlyph)glyph;  
  36.         FT_Bitmap &     bitmap  =  bitmap_glyph -> bitmap;  
  37.          for ( int  i = 0 ; i < bitmap.rows;  ++ i)  
  38.          {  
  39.              for ( int  j = 0 ; j < bitmap.width;  ++ j)  
  40.              {  
  41.                  //  if it has gray>0 we set show it as 1, o otherwise  
  42.                 printf( " %d " , bitmap.buffer[i * bitmap.width + j] ? 1 : 0 );  
  43.             }  
  44.             printf( " \n " );  
  45.         }  
  46.          //  free glyph  
  47.         FT_Done_Glyph(glyph);  
  48.         glyph  =  NULL;  
  49.     }  
  50.      //  free face  
  51.     FT_Done_Face(pFTFace);  
  52.     pFTFace  =  NULL;  
  53. }  
  54.   
  55.  //  free FreeType Lib  
  56. FT_Done_FreeType(pFTLib);  
  57. pFTLib  =  NULL;  
  58.   
  59. }  
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章