• <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)  編輯 收藏 引用
             
            久久精品国产91久久麻豆自制 | 精品久久久久国产免费| 国产精品久久久久影视不卡| 精品久久久无码人妻中文字幕豆芽| 国内精品人妻无码久久久影院导航| 无码精品久久久久久人妻中字| 人妻少妇久久中文字幕一区二区| 91精品国产91久久综合| 久久九九免费高清视频| 狠狠色狠狠色综合久久| 久久久久夜夜夜精品国产| 性做久久久久久久久浪潮| 亚洲国产精品无码久久98| 久久高清一级毛片| 久久婷婷五月综合国产尤物app| 国产99久久九九精品无码| 久久伊人五月丁香狠狠色| 亚洲国产精久久久久久久| 久久久亚洲AV波多野结衣| 99国产精品久久久久久久成人热| 天天综合久久一二三区| 亚洲国产成人久久精品动漫| 性做久久久久久久久浪潮| 久久亚洲精品中文字幕三区| 97精品依人久久久大香线蕉97| 999久久久免费国产精品播放| 亚洲AV日韩AV永久无码久久| 国内精品久久久久久久coent| 狠狠88综合久久久久综合网| 亚洲综合伊人久久大杳蕉| 亚洲欧洲久久久精品| 久久久精品波多野结衣| 18岁日韩内射颜射午夜久久成人| 午夜天堂av天堂久久久| 亚洲欧美日韩精品久久亚洲区| 久久国产成人精品国产成人亚洲| 日本三级久久网| 久久久WWW成人| 亚洲色欲久久久久综合网| 久久久午夜精品福利内容| 亚洲v国产v天堂a无码久久|