• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

              C++博客 :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
              117 Posts :: 2 Stories :: 61 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(8)

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

             

                游戲地圖的畫面是游戲中不可缺少的重要環(huán)節(jié)之一,要產(chǎn)生游戲地圖,除了可以直接使用已經(jīng)繪制好的地圖外,對于一些畫面不太復(fù)雜,且具有重復(fù)性質(zhì)的地圖或場景,有一個比較好的解決辦法,那就是利用地圖拼接的方法,將一小塊一小塊的小地圖組合成較大的地圖。
                地圖拼接的優(yōu)點在于節(jié)省系統(tǒng)資源,因為一張大型的地圖會占用比較多的內(nèi)存空間,且加載速度較慢,如果游戲中使用了為數(shù)較多的大型地圖,那么勢必會降低程序運行時的性能,而且需要相當(dāng)可觀的內(nèi)存空間。

                本篇隨筆從最基本的平面地圖貼圖開始講起,這種貼圖方法相當(dāng)直觀,即利用一張張四方形的小圖塊組成同樣是四方形的大地圖。下圖便是一張由3種不同圖塊組合而成的平面地圖。
                事實上,這張地圖是由4×3張小圖塊組成的,列方向是4張圖塊,行方向是3張圖塊,這里使用列與行這樣的字眼,是因為隨后將使用數(shù)組來定義地圖中出現(xiàn)圖塊的內(nèi)容。
                從這張圖中可以看到,一共出現(xiàn)了3中不一樣的地圖,這是因為程序中會事先以數(shù)組定義哪個位置上要出現(xiàn)哪一種地圖,使得拼接出來的地圖能夠符合需求。現(xiàn)在假設(shè)圖中3種不同圖塊的編號分別為0、1和2,那么可以以下面的這個一維數(shù)組來定義出上圖中的地圖。
            int mapblock[12]={0,1,1,1,  //第1列
                                                       
            2,0,1,2,  //第2列
                                                       
            2,2,2,2}
            //第3列
                  //為什么用一維數(shù)組而不是二維數(shù)組呢?


                將這個一維數(shù)組以行列的方式排列,可以看出每個數(shù)組元素對應(yīng)圖中的哪個圖塊。
                需要提醒的是,由于使用的是一位數(shù)組來定義地圖內(nèi)容,因此上面這個數(shù)組的每個元素的索引值是0……11.但是,由于程序里不論計算圖塊貼圖的位置還是計算整張地圖的長寬尺寸,都是以行列來進(jìn)行換算的,所以需要將數(shù)組的索引值轉(zhuǎn)換成相應(yīng)的列編號與行編號,轉(zhuǎn)換公式如下:

            列編號 = 索引值 / 每一列的圖塊個數(shù)(行數(shù));
            行編號 = 索引值 % 每一列的圖塊個數(shù)(行數(shù));

                下圖驗證上面的公式,方格中的編號是一維數(shù)組的元素索引值。


                這里需要注意的是,列編號與行編號的起始值都是從0開始算起,而一旦算出了列編號與行編號之后,便可以按照圖塊的寬與高來求出圖塊貼圖的位置,下面是計算圖塊左上點貼圖坐標(biāo)的公式。

             

            左上點X坐標(biāo) = 行編號 × 圖塊的寬度;
            左上點Y坐標(biāo) = 列編號 × 圖塊的高度;

            范例ch2_9:運用不同小圖塊,示范平面地圖拼接的技巧。
            下載地址:ch2_9(上傳到windows live空間,可能需要MSN賬號登陸)
            說明:程序源代碼中有相關(guān)的注釋。
            程序運行結(jié)果如下圖:

             
            PS:如想獲得更多關(guān)于Visual C++游戲開發(fā)的內(nèi)容,可點擊隨筆:《Visual C++游戲編程基礎(chǔ)》學(xué)習(xí)筆記——索引隨筆

            posted on 2010-04-09 09:26 煙皚 閱讀(2368) 評論(2)  編輯 收藏 引用 所屬分類: 《Visual C++游戲編程基礎(chǔ)》學(xué)習(xí)筆記

            Feedback

            # re: 游戲地圖制作——平面地圖貼圖[未登錄] 2010-08-02 18:09 cliz
            你好 我登入msn 也下載不了你的代碼啊。。
            能不能發(fā)給我一份啊。。謝謝了。。
            souliz@live.cn  回復(fù)  更多評論
              

            # re: 游戲地圖制作——平面地圖貼圖 2013-07-23 23:36 求學(xué)
            你好,登入後代碼已經(jīng)消失,能否寄給我一份?謝謝
            sa39390419@yahoo.com.tw
            (ps:其它講解的代碼也已消失)  回復(fù)  更多評論
              

            麻豆成人久久精品二区三区免费 | 一级做a爰片久久毛片人呢| 久久久久久曰本AV免费免费| 欧美日韩精品久久久久| 久久久久久精品免费看SSS| 久久精品亚洲中文字幕无码麻豆| 精品免费tv久久久久久久| 久久伊人色| 国内精品久久人妻互换| 精品久久久久中文字| 亚洲国产精品久久久天堂| 99久久婷婷国产综合精品草原| 久久中文字幕视频、最近更新| 7777久久久国产精品消防器材| 99久久成人国产精品免费| 伊人久久大香线蕉综合网站| 久久久精品2019免费观看| 久久久久久久久久免免费精品 | 97久久香蕉国产线看观看| 久久精品国产72国产精福利| www性久久久com| 久久伊人精品一区二区三区| 国产精品午夜久久| 国产麻豆精品久久一二三| 99精品国产免费久久久久久下载| 人人狠狠综合久久亚洲婷婷| 麻豆AV一区二区三区久久| 怡红院日本一道日本久久| 午夜欧美精品久久久久久久| 亚洲精品视频久久久| 久久久久这里只有精品 | 久久精品亚洲乱码伦伦中文 | 精品国产乱码久久久久久浪潮| 国产高潮国产高潮久久久| 国产亚洲精品美女久久久| 国产精品18久久久久久vr| 99久久成人国产精品免费 | 国内精品久久久久久野外| 久久丫精品国产亚洲av| 欧美牲交A欧牲交aⅴ久久| 久久Av无码精品人妻系列 |