• <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>
            象DNF~冒險島等地圖他們都有很多層的地圖層并且移動速度不同~那么是如何實現(xiàn)的呢?下面我給大家講解一下具體實現(xiàn)原理,我做的是一個地圖編輯器,不過原理是一樣的

             
            首先我們應該知道我們的這個游戲有幾層我們先創(chuàng)建一個枚舉類型
            enum MAPTYPE
            {
                ForeGround ,
            //前景層
                Ground,//地圖層
                BackGround,//背景層
                FundusGround,//背景最后層
            }
            ;
            然后創(chuàng)建一個基類我們這里就叫做CMap

             

            class CMap
            {
            public:
                CMap(
            float _x,float _y,const int _ID,bool _bCheck = true);
                
            virtual ~CMap();
                
            void GameLogic(float _dt);//游戲主邏輯函數(shù)
                void GameRender();        //游戲主渲染函數(shù)
                void GameInit();            //游戲初始化函數(shù)
                void GameReleaser();        //游戲釋放函數(shù)
                virtual bool CheckActive()= 0;        //子對象碰撞檢測
                virtual bool ShowActive() = 0;        //子對象是否顯示
                virtual void Logic(float _dt) = 0;    //子對象邏輯
                virtual void Render() = 0;            //子對象渲染
                STRMAP StrMap;        //地圖屬性
            protected:
                
            int ID;
                
            float PosX,PosY;    //對象位置
                static HGE* g_pHGE;    //HGE指針
                int Width,Height;            //對象寬和高度
                static float StrWidth,StrHeight;    //當前卷動寬度
                static float ForeWidth,ForeHeight;    //前景層卷動寬和高度
                static float FundusWidth,FundusHeight;//最后一層背景卷動寬度和高度
                static float BackWidth,BackHeight;//背景卷動寬度和高度
                static float Speed;//卷動速度
            }
            ;

             從這里我們可以看到有3個卷動坐標,我們可以認為有3個視圖窗口,
            可以看圖理解

            我們可以通過CMap的派生類來創(chuàng)建地圖對象然后通過一個鏈表來管理這些對象
            但是雖然我們有3個視圖但是我們要統(tǒng)一他們的坐標~也就是我們最后看到的屏幕左上的坐標,當然也許你創(chuàng)建的地圖有2級緩存~有可能左上并不是0,0點。自已定義了;

            我們在派生類里可以定義一個變量float x,float y;來存放這個對象的左上角坐標;
            通過枚舉在我們創(chuàng)建這個地圖對象的時候給它賦值不同的視圖坐標~就是我們先前定義的那3個視圖坐標~
            這樣就實現(xiàn)了多卷軸視差效果~

            posted on 2009-05-20 17:51 icecoldmoon 閱讀(1670) 評論(1)  編輯 收藏 引用
             
            国产精品久久自在自线观看| 欧洲国产伦久久久久久久| 亚洲人成精品久久久久| 伊人色综合久久天天人手人婷 | 99久久99久久| 午夜精品久久久久9999高清| 亚洲精品白浆高清久久久久久| 天天爽天天狠久久久综合麻豆| 久久精品成人欧美大片| 亚洲狠狠婷婷综合久久久久| yellow中文字幕久久网| 久久久无码精品亚洲日韩按摩 | 无码精品久久一区二区三区| 99久久99这里只有免费费精品| 久久久久久久国产免费看| avtt天堂网久久精品| 久久人人爽人人爽人人片AV东京热 | 婷婷综合久久中文字幕蜜桃三电影| 国产L精品国产亚洲区久久| 日产精品久久久一区二区| 久久精品极品盛宴观看| 国产成人无码精品久久久免费| 久久精品国产亚洲AV大全| 久久久午夜精品福利内容| 久久精品国产清自在天天线| 欧美久久精品一级c片片| 国产精品一区二区久久不卡| 久久综合狠狠综合久久 | av无码久久久久不卡免费网站| 久久久久人妻一区精品果冻| 青青国产成人久久91网| 波多野结衣中文字幕久久| 奇米综合四色77777久久| 亚洲国产精品无码久久98| 性欧美大战久久久久久久| 日日狠狠久久偷偷色综合96蜜桃| 丁香五月综合久久激情| 国产成人精品久久亚洲高清不卡| 国产精品美女久久久久久2018| 精品久久久久久亚洲精品| 99精品久久精品|