技术开发 频道

游戏是这样写成的(六)

  【IT168 技术文档】

iPhone 系統里已有不少字體, 我們理論上可以用NSString 來畫字:

[string drawAtPoint:CGPointMake(x, y) withFont:font]

但因為速度關係和不想以系統的東西混合了OpenGL ES一起運用, 我們還得另外想想辦法.

如果大家有詳細的看過Texture2D 的代碼, 會發現一個 initWithString 的生成貼圖的方法, 它的功能就是把一段文字, 畫在一張貼圖上, 我們跟著就可以應用這個貼圖在自己的遊戲中. 一般不用太多文字的遊戲, 這個方法基本就可以解決了我們的所需.

當然為了比較有彈性, 我們應該搞一個font 類, 讓我們可以任意的顯示每個英文字母! 有了這個想法, 於是就有了這次帶給大家的 CCFont!

在 Texture2D里新加了一個 makeASCIIBitmapFont 的功能, 它把由 ASCII 碼32 ~ 127 共95個字母, 都畫到一張貼圖上(見截圖下方), 而CCFont 就會根據這張貼圖, 生成95個 CCSprite 來對應每個字母, 接著我們就可以利用這個 CCSprite  陣矩來顯示字串了!

void CCFont::drawString(const char *text, float x, float y)
{
    char ch;
    int idx;
 
    while ((ch = *text++) != 0)
    {
        idx = ch - 32;
        mCharacters[idx]->render(x, y);
        x += mCharWidthArray[idx];
 
    }
}

CCSprite 也新加了setCenter, 大家現在可以任意設定CCSprite 的中心點!

本文实例iDemo_6下载:http://www.rayfile.com/files/336cbbd7-3bee-11de-85f2-0014221b798a/

0
相关文章