<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-30  評論-123  文章-0  trackbacks-0

    2 ?? Sprite 簡介 ?

    概述
    ?
    Sprite( 精靈 ) 本質上其實就是 MIDP 圖像。事實上,看看 Sprite 的構造函數你就能發現, Sprite 3 個構造函數中有兩個需要傳進一個圖像對象 (Image Object) ;而第三個構造函數是通過一個已經存在的 Sprite 構造 Sprite 。 ?

    Sprite
    3 個構造函數: ?
    l???? Sprite(Image image) : 構造一個不會動的 Sprite ?
    l???? Sprite(Image image, int frameWidth, int frameHeight) : 創建一個可以動的 Sprite ?
    l ????? Sprite(Sprite s) : 通過一個已經存在的 Sprite 構造 Sprite ?

    精靈
    VS 圖像
    ? ?
    精靈負責一個對象的可視化呈現。例如,你可以把 ( 圖1 ) 中的每一幅圖像創建成一個精靈。 ?
    o_1.jpg (圖1)精靈舉例


    精靈的變換

    ?
    盡管精靈是從圖像創建來的,但是與單純的圖像相比,精靈表現出許多附件的功能。例如,精靈提供了變換 (transformations) 功能――允許你旋轉和鏡像一個精靈。 ( 圖2 ) 展示了對精靈的幾個變換:
    o_2.jpg (圖2)精靈的變換 ?

    精靈的參考像素
    ?
    除了變換之外,精靈的另一重要特點就是參考像素這個概念。 默認情況下,精靈的參考像素被定義在 (0,0) 這個位置,如 ( 圖3 ) 所示:
    o_3.jpg ( 圖3 ) 參考像素
    注意: 精靈周圍的淡灰色框只是為了清晰地表現精靈的輪廓

    當你嘗試著將精靈放置在某個特定位置但卻沒有參考點時,你就會發現使用參考像素的好處了。舉個例子來說,在 ( 圖4 ) 中,要把一個音符的頭 ( 音符的圓形部分 ) 放置在線上,另一個放置在兩條線之間,在沒有邏輯參考點的情況下,如果你愿意,可以使用參考像素位置 (0,0) 。
    o_4.jpg
    ( 圖4 ) 改變精靈的位置

    下一板塊將會演示如何用參考像素精確的解決這一問題。

    改變參考像素位置 ?
    讓我們改變音符的參考像素位置。如 ( 圖5五 ) 所示:
    o_5.jpg
    ( 圖5 ) 新參考像素
    采用新的參考像素位置,把音符放到五線譜 ( 樂譜中橫線的專業名稱 ) 的適當位置,更加直觀。
    o_6.jpg
    ( 圖6 ) 用參考像素改變位置


    精靈動畫 ?
    圖像相比,精靈的另一個好處就是能夠實現動畫。使用帶有多幀畫面的精靈(如圖7所示),實現動畫變成了簡單地調用適當的方法,這些方法用于管理每一個畫面按順序顯示出來從而形成動畫效果的方法
    o_7.jpg
    ( 7) 精靈幀

    注意: 雖然圖像也可以包含多幀畫面,但是精靈擁有獨特的能夠簡單有效地實現動畫的方法。在下一章你將看到用精靈實現動畫的全部細節。

    創建精靈
    ?
    接下來,你會看到一小段代碼。這段實例代碼繼承自 Sprite 類,它將向你展示如何創建一個精靈: ?

    /*--------------------------------------------------?
    * AppleSprite.java?
    *-------------------------------------------------*/?
    import javax.microedition.lcdui.game.*;?
    import javax.microedition.lcdui.*;?

    public class AppleSprite extends Sprite {?
    ?? public AppleSprite(Image image) {?
    ?? //Sprite 類的構造函數 ?
    ?? super(image);?
    ?? // 設置在畫布上的位置 ... 后面將詳細介紹 ?
    ?? setRefPixelPosition(146, 35);?
    ?? }
    }

    假設你有一張蘋果的PNG圖片,參照下面的代碼就能創建一個精靈的實例了:??
    private AppleSprite spApple; // 蘋果精靈?
    ?? ...?
    ?? try {?
    ?? // 非動畫精靈?
    ?? spApple = new AppleSprite(Image.createImage("/apple.png"));?
    ?? }catch (Exception e) {?
    ????? System.out.println("不能讀取PNG文件");?
    ?? }

    注意:PNG格式是J2ME/MIDP支持的唯一的圖像格式。要獲得更多關于PNG文件的信息,請訪問http://www.libpng.org/pub/png/。

    (本文翻譯自John Muchow的Work with sprites in J2ME。)

    posted on 2006-04-22 11:52 學二的貓 閱讀(1585) 評論(1)  編輯  收藏 所屬分類: J2ME

    評論:
    # re: 用Sprite編寫J2ME程序--第二章 Sprite簡介 2008-04-16 16:34 | 青大
    頂  回復  更多評論
      
    主站蜘蛛池模板: 久久精品国产亚洲香蕉| 亚洲国产成人久久综合碰| 成年人在线免费观看| 亚洲精品美女在线观看| 少妇人妻偷人精品免费视频| 久久精品国产亚洲沈樵| 黄色视屏在线免费播放| 亚洲精品在线视频观看| 国产18禁黄网站免费观看| 免费精品国自产拍在线播放| 国产jizzjizz视频全部免费| 99久久婷婷免费国产综合精品| 亚洲人成影院在线高清| 久久久久亚洲AV无码专区网站| 中文字幕版免费电影网站| 亚洲成色在线综合网站| 免费激情视频网站| 在线观看免费播放av片| 最新亚洲人成无码网站| 少妇中文字幕乱码亚洲影视| 噼里啪啦电影在线观看免费高清| 免费一级特黄特色大片| 亚洲男人的天堂在线| 亚洲毛片αv无线播放一区| 宅男666在线永久免费观看| 中美日韩在线网免费毛片视频 | 成年女人免费碰碰视频| 国产午夜不卡AV免费| 免费人成大片在线观看播放| ASS亚洲熟妇毛茸茸PICS| 青青草国产免费久久久91 | 免费国产在线观看| 高潮毛片无遮挡高清免费| 亚洲精品无码乱码成人| 国产无遮挡裸体免费视频 | 精品一区二区三区免费视频 | 99久久精品免费视频| 亚洲乱码在线观看| 亚洲区小说区图片区| 免费的一级片网站| 97在线线免费观看视频在线观看|