




版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、C+語言課程設計一迷你高爾夫一、實驗內容玩家通過按下鍵盤上的上下左右方向鍵控制球的移動,使其最終到達出口則游戲通關。要求如下:1、 游戲分成3關,第一關、第二關、第三關界面圖如下:第一關第二關第三關2、 啟動游戲進入第一關,勝利后進入第二關,如果第三關通關,則游戲重新回到第一關。3、 游戲玩法是通關控制鍵盤上的上下左右方向鍵控制球的運動,單擊方向鍵,則球獲得一個向該方向直線運動的速度。如果球遇到方塊,則球停止運動,如果遇到黑洞,則游戲結束,重新開始該游戲,遇到出口則通關。4、 球靜止狀態下會有箭頭指示球可以運動的方向,運動狀態下則箭頭消失。如果球運動出世界邊界,則游戲結束,重新回到該游戲。二、
2、實驗指南實驗一 開始實驗【實驗任務】步驟一、打開FunCode,創建一個的C+語言項目;步驟二、導入GolfGame場景。【實驗思路】按實驗指導完成。【實驗指導】1、 打開FunCode,點擊“項目”菜單,選擇“創建C+工程”注意:工程名名稱要求字母開頭,只能包含字母和數字,且名字中間不能有空格。2、 點擊菜單“項目”中的“導入地圖模塊”,如圖一。跳出一個對話框,選中“GolfGame”模板,點擊“導入到工程”按鈕,如圖二。 圖 一 圖 二3、 導入成功后的,界面如下圖所示:地圖不僅包括界面設計,還包括該游戲可能要用到的其他精靈。添加到“場景”中的精靈,都已經取好名稱,并根據程序要求設置好中心
3、點、鏈接點等,學生只需要直接編程就可以。實驗二 游戲關卡初始化【實驗內容】步驟一、關卡地圖初始化步驟二、清除上一關卡數據步驟三、根據當前關卡,選擇關卡數據【實驗思路】游戲開始的時候首先要清除上一關的游戲數據,即將上一關創建的精靈從地圖中刪掉。將游戲地圖分成12*12的方格界面,游戲總共分成三關,因此我們需要用三個二維數組m_iLevelData1GRID_COUNTGRID_COUNTm_iLevelData2GRID_COUNTGRID_COUNTm_iLevelData3GRID_COUNTGRID_COUNT(其中GRID_COUNT的值為12)來存放這三關的數據即可。二維數組中0表示該
4、位置不創建精靈,否則根據不同的值創建不同精靈,RIGID_BLOCK(值為1)表示創建一個方塊精靈,BLACK_HOLE(值為2)表示創建一個黑洞精靈,GOLF_EXIT(值為3)表示創建一個出口精靈。每次把代表該關卡的二維數組的數據拷貝到存儲當前關卡m_iGridData的二維數組中。【實驗指導】1、 進入LessonX.h的CGameMain類中,添加以下成員變量的聲明:intm_iMoveState;/ 控制球的移動狀態:0當前靜止,可以移動,1、2、3、4:代表上下左右4個方向移動中,按鍵無響應intm_iCurLevel;/ 當前關卡static const floatm_fGrid
5、StartX;/ 第一塊方塊的起始坐標 = -(GRID_COUNT * g_fGridSize * 0.5 - g_fGridSize / 2)static const floatm_fGridStartY;static const floatm_fGridSize;/ 每塊的大小,包括球、出口等都是此大小intm_iRigidBlockCount;/ 本關卡創建的阻擋物方塊數量intm_iBlackHoleCount;/ 本關卡創建的黑洞數量intm_iGolfExitCount;/ 本關卡創建的出口的數量intm_iGridDataGRID_COUNTGRID_COUNT;/二維數組,存
6、儲當前關卡N*N的矩陣方塊信息static const intm_iLevelData1GRID_COUNTGRID_COUNT ;static const intm_iLevelData2GRID_COUNTGRID_COUNT ;static const intm_iLevelData3GRID_COUNTGRID_COUNT ; vector<CSprite*> m_vRigidBlock;/阻擋物精靈向量數組vector<CSprite*> m_vBlackHole;/黑洞精靈向量數組vector<CSprite*> m_vGolfExit;/出口精
7、靈向量數組2、 進入LessonX.h中在頭文件聲明的后面添加下面的宏定義代碼:#defineGRID_COUNT12/ N * N 的矩陣方塊,一個N的大小#defineMAX_LEVEL3/ 最大關卡數量。如果要增加關卡,請先修改此值#defineRIGID_BLOCK1/ 以下3個分別為方塊阻擋物、黑洞、出口的值#defineBLACK_HOLE2#defineGOLF_EXIT33、 在LessonX.h頭文件#include <Windows.h>下面添加:#include <vector>using std:vector;4、 進入LessonX.cpp中添
8、加上面的成員變量的初始化:1) 在構造函數中把m_iGameState的值由0改為1:m_iGameState=1;2) 在構造函數中添加下面代碼:m_iCurLevel=1;m_iMoveState=0;/ 控制球的移動狀態:0當前靜止,可以移動,1、2、3、4:代表上下左右4個方向移動中,按鍵無響應m_iRigidBlockCount=0;/ 本關卡創建的阻擋物方塊數量m_iBlackHoleCount=0;/ 本關卡創建的黑洞數量m_iGolfExitCount=0;3) 對于const類型的成員變量,我們需要在函數外面單獨進行初始化,在文件最后面添加如下代碼:const float C
9、GameMain:m_fGridStartX=-27.5f;const float CGameMain:m_fGridStartY=-27.5f;const float CGameMain:m_fGridSize=5.f;const int CGameMain:m_iLevelData1GRID_COUNTGRID_COUNT = 0, 0, 0, 0,0,0,0,0,0, 0, 0, 0,0, 0, 0, 0,0,0,0,0,0, 0, 0, 0,0, 0, 0, 0,0,0,0,0,0, 0, 0, 0,0, 0, 0, RIGID_BLOCK,RIGID_BLOCK,RIGID_BLOC
10、K,RIGID_BLOCK,RIGID_BLOCK,RIGID_BLOCK, 0, 0, 0,0, 0, 0, RIGID_BLOCK,0,0,0,0,RIGID_BLOCK, 0, 0, 0,0, 0, 0, RIGID_BLOCK,0,0,0,0,RIGID_BLOCK, 0, 0, 0,0, 0, 0, RIGID_BLOCK,0,0,0,0,BLACK_HOLE, 0, 0, 0,0, 0, 0, 0,0,0,0,GOLF_EXIT,RIGID_BLOCK, 0, 0, 0,0, 0, 0, 0,0,0,0,0,0, 0, 0, 0,0, 0, 0, 0,0,0,0,0,0, 0, 0
11、, 0,0, 0, 0, 0,0,0,0,0,0, 0, 0, 0,0, 0, 0, 0,0,0,0,0,0, 0, 0, 0;const int CGameMain:m_iLevelData2GRID_COUNTGRID_COUNT=0, RIGID_BLOCK, RIGID_BLOCK, RIGID_BLOCK, 0, RIGID_BLOCK, RIGID_BLOCK, RIGID_BLOCK, RIGID_BLOCK, RIGID_BLOCK, RIGID_BLOCK, 0,0, RIGID_BLOCK, 0, 0, 0, 0, 0, 0, 0, 0, RIGID_BLOCK, 0,0,
12、 RIGID_BLOCK, 0, 0, 0, 0, 0, 0, 0, 0, RIGID_BLOCK, 0,0, RIGID_BLOCK, 0, 0, 0, 0, 0, 0, 0, 0, RIGID_BLOCK, 0,0, RIGID_BLOCK, 0, 0, 0, 0, 0, 0, 0, 0, RIGID_BLOCK, 0,0, RIGID_BLOCK, 0, 0, 0, 0, 0, 0, 0, 0, RIGID_BLOCK, 0,0, RIGID_BLOCK, 0, 0, 0, RIGID_BLOCK, RIGID_BLOCK, RIGID_BLOCK, 0, 0, RIGID_BLOCK,
13、 0,0, RIGID_BLOCK, 0, 0, 0, 0, 0, RIGID_BLOCK, 0, 0, RIGID_BLOCK, 0,0, RIGID_BLOCK, 0, 0, 0, 0, 0, 0, GOLF_EXIT, RIGID_BLOCK, RIGID_BLOCK, 0,0, RIGID_BLOCK, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,0, RIGID_BLOCK, 0, 0, 0, 0, 0, 0, 0, 0, RIGID_BLOCK, 0,0, RIGID_BLOCK, 0, RIGID_BLOCK, RIGID_BLOCK, RIGID_BLOCK, R
14、IGID_BLOCK, RIGID_BLOCK, RIGID_BLOCK, 0, RIGID_BLOCK, 0;const int CGameMain:m_iLevelData3GRID_COUNTGRID_COUNT=0, 0, 0, 0, 0, 0, 0, 0, RIGID_BLOCK, RIGID_BLOCK, 0, 0,0, 0, RIGID_BLOCK, RIGID_BLOCK, RIGID_BLOCK, 0, 0, 0, 0, 0, 0, RIGID_BLOCK,RIGID_BLOCK, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, RIGID_BLOCK,0, 0,
15、 0, 0, 0, 0, 0, 0, 0, 0, 0, RIGID_BLOCK,0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,0, 0, 0, 0, GOLF_EXIT, 0, 0, 0, 0, 0, 0, 0,0, 0, 0, 0, 0, 0, 0, RIGID_BLOCK, RIGID_BLOCK, 0, 0, 0,0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,0, 0, 0, 0, 0, 0, 0, 0, 0, 0, RIGID_BLOCK, 0,0, 0, 0, RIGID_BLOCK, 0, 0, 0, 0, 0, 0, RIGID_B
16、LOCK, 0,0, 0, 0, 0, BLACK_HOLE, RIGID_BLOCK, 0, 0, 0, 0, 0, 0,0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0;二維數組中0表示該位置不創建精靈,否則根據不同的值創建不同精靈,RIGID_BLOCK(值為1)表示創建一個方塊精靈,BLACK_HOLE(值為2)表示創建一個黑洞精靈,GOLF_EXIT(值為3)表示創建一個出口精靈。4) 進入GameInit函數里面,將球的運動狀態初始化為靜止,添加下面代碼:m_iMoveState=0;5、 游戲初始化的時候,首先我們需要將前邊添加的精靈全部刪除掉。1) 進入Le
17、ssonX.h文件的CGameMain類中添加該函數的聲明:void ClearAllSprite();2) 在LessonX.cpp最后面添加該函數的定義:void CGameMain: ClearAllSprite()3) 再使用3個循環,分別將上一關卡創建的3種精靈刪除掉。在上邊定義的函數中添加如下代碼:intiLoop= 0;for( iLoop = 0; iLoop < m_vRigidBlock.size(); iLoop+ )m_vRigidBlockiLoop->DeleteSprite();for( iLoop = 0; iLoop < m_vBlackHo
18、le.size(); iLoop+ )m_vBlackHoleiLoop->DeleteSprite();for( iLoop = 0; iLoop < m_vGolfExit.size(); iLoop+ )m_vGolfExitiLoop->DeleteSprite();/ 總數置0,重新創建m_iRigidBlockCount=0;m_iBlackHoleCount=0;m_iGolfExitCount=0;其中m_vRigidBlock、m_vBlackHole、m_vGolfExit是存儲三種精靈的向量數組,每一個循環都遍歷一遍向量數組并調用數組中每個精靈的Dele
19、teSprite函數即可。m_vRigidBlock.size()、m_vBlackHole.size()、m_vGolfExit.size()表示每種精靈的總數4) 最后在GameInit()中添加調用此函數的代碼:ClearAllSprite();5) 在GameInit()中,我們對關卡進行選擇初始化。a.選擇關卡我們使用了switch-case結構,程序通過判斷switch中的參數進入到不同的case中去,每個case就是一種情況的實現。代碼如下:/ 控制球在數組中的開始位置(出生點),該位置不能為0.根據關卡數據自行指定intiControlStartX = 0, iControlS
20、tartY = 0;/ 根據當前關卡,選擇關卡數據switch( m_iCurLevel )case 2:iControlStartX=5;iControlStartY=9;memcpy( m_iGridData, m_iLevelData2, sizeof(int) * GRID_COUNT * GRID_COUNT );break;case 3:iControlStartX=3;iControlStartY=6;memcpy( m_iGridData, m_iLevelData3, sizeof(int) * GRID_COUNT * GRID_COUNT );break;/ 如果要新增關
21、卡,在此處增加case即可/ case./ Level1 或者g_iCurLevel錯誤case 1:default:iControlStartX=5;iControlStartY=6;memcpy( m_iGridData, m_iLevelData1, sizeof(int) * GRID_COUNT * GRID_COUNT );break; memcpy函數作用是從源src所指的內存地址的起始位置開始拷貝n個字節到目標dest所指的內存地址的起始位置中。因為二維數組在內存中的存放方式是連續的,因此我們將源地址拷貝給m_iGridData的起始地址之后,系統后自動根據m_iGridDat
22、a的下標來找到正確的值。至此,本實驗結束。實驗三初始化游戲精靈【實驗內容】步驟一、創建精靈步驟二、初始化精靈位置【實驗思路】遍歷二維數組m_iGridData,根據數組值生成對應的精靈實例:值為0的時候不用創建,需要創建的精靈名字前綴為(按照宏定義的1,2,3順序):RigidBlock, BlackHole, GolfExit。每創建一種精靈,將其總數加1 :m_iRigidBlockCount, m_iBlackHoleCount,m_iGolfExitCount。【實驗指導】1、 進入LessonX.h,CGameMain類中添加下面成員變量的聲明:CSprite*m_pControlB
23、all;/控制球精靈CSprite*m_pGolfArrow;/指示箭頭精靈在LessonX.cpp中CGameMain類在構造函數里面添加上面成員變量的初始化:m_pControlBall=new CSprite("ControlBall");m_pGolfArrow=new CSprite("GolfArrow");2、 創建精靈之后需要將精靈移到特定位置,因此我們需要定義一個自定義的函數MoveSpriteToBlock來實現這個功能。1) 進入LessonX.h中添加該函數的聲明:void MoveSpriteToBlock( CSprite*
24、tmpSprite, const int iIndexX, const int iIndexY );2) 在LessonX.cpp最后面添加該函數的定義:void CGameMain:MoveSpriteToBlock( CSprite* tmpSprite, const int iIndexX, const int iIndexY )3) 傳入該函數的是精靈實體以及x,y坐標參數。再通過SetSpritePosition函數設置精靈位置,在該函數里面添加如下代碼:floatfPosX=m_fGridStartX + iIndexX * m_fGridSize;floatfPosY=m_fGr
25、idStartY + iIndexY * m_fGridSize;tmpSprite->SetSpritePosition(fPosX, fPosY);3、 這里定義在GameInit函數中來創建控制球、方塊精靈、出口精靈和黑洞精靈。通過一個函數來實現CreateAllSprite()。原理是通過兩個for循環來,判斷m_iGridData的值,如果為0,則不創建,如果為RIGID_BLOCK則創建一個方塊精靈,為 BLACK_HOLE則創建一個黑洞精靈,為GOLF_EXIT則創建一個出口精靈。由于我們預先在地圖中擺放了三個模板精靈,因此只需要使用CloneSprite函數即可創建新的精
26、靈。然后再調用MoveSpriteToBlock函數將精靈移動到指定位置。最后每創建一個實現精靈,將它添加到相應的精靈向量數組中。、1) 進入LessonX.h文件的CGameMain類中添加該函數的聲明: void CreateAllSprite();2) 在LessonX.cpp最后面添加該函數的定義:void CGameMain: CreateAllSprite()3) 在定義汗的函數中添加變量聲明:intiLoopX = 0, iLoopY = 0;CSprite* tmpSprite;char*szName = NULL;4) 實現兩個for循環:for( iLoopY = 0; i
27、LoopY < GRID_COUNT; iLoopY+ )for( int iLoopX = 0; iLoopX < GRID_COUNT; iLoopX+ )5) 在里面的循環添加判斷代碼:如果是0,則不創建精靈,continue表示跳出本次循環,繼續下一個循環。if( 0 = m_iGridDataiLoopYiLoopX )continue;如果是方塊,則創建方塊精靈:if( RIGID_BLOCK = m_iGridDataiLoopYiLoopX )szName=CSystem:MakeSpriteName("RigidBlock",m_iRigidB
28、lockCount );tmpSprite=new CSprite(szName);tmpSprite->CloneSprite("RigidBlockTemplate");MoveSpriteToBlock( tmpSprite, iLoopX, iLoopY );m_vRigidBlock.push_back(tmpSprite);m_iRigidBlockCount+;如果是黑洞,則創建黑洞精靈:else if( BLACK_HOLE = m_iGridDataiLoopYiLoopX )szName=CSystem:MakeSpriteName( "
29、BlackHole", m_iBlackHoleCount );tmpSprite=new CSprite(szName);tmpSprite->CloneSprite("BlackHoleTemplate");MoveSpriteToBlock( tmpSprite, iLoopX, iLoopY );m_vBlackHole.push_back(tmpSprite);m_iBlackHoleCount+;如果是出口,則創建出口精靈:else if( GOLF_EXIT = m_iGridDataiLoopYiLoopX )szName=CSystem:M
30、akeSpriteName( "GolfExit", m_iGolfExitCount );tmpSprite=new CSprite(szName);tmpSprite->CloneSprite("GolfExitTemplate");MoveSpriteToBlock( tmpSprite, iLoopX, iLoopY );m_vGolfExit.push_back(tmpSprite);m_iGolfExitCount+;6) 將控制球和指示箭頭擺放到初始位置,此時球靜止,因此指示箭頭可見。在上面的兩個循環后面添加下面的代碼:m_pCont
31、rolBall->SetSpriteLinearVelocity( 0.f, 0.f);MoveSpriteToBlock(m_pControlBall,m_iControlStartX,m_iControlStartY);MoveSpriteToBlock(m_pGolfArrow, m_iControlStartX, m_iControlStartY );m_pGolfArrow->SetSpriteVisible(1);7) 最后在GameInit()中調用此函數:CreateAllSprite();至此,本實驗結束。實驗四 移動球【實驗內容】步驟一、響應鍵盤按鍵按下消息步驟
32、二、球精靈坐標轉換為二維格子數組索引步驟三、判斷移動方向,使球獲取速度【實驗思路】首先響應系統的按鍵消息函數,然后獲取精靈坐標,并將其轉換為二維格子中的坐標,判斷其旁邊的格子是否是方塊,如果不是則給球一個移動的速度。【實驗指導】1、 在LessonX.cpp文件的OnKeyDown函數中添加代碼:a.首先判斷游戲狀態,只有在游戲中已經可以移動狀態才響應按鍵,在上面函數中添加下面的代碼:if( 2 != m_iGameState | 0 != m_iMoveState )return;2、 獲取控制球精靈坐標轉換到二維格子數組索引,這里我們需要定義兩個函數SpritePosXToIndexX和S
33、pritePosXToIndexY分別處理精靈坐標轉換為二維格子的X索引和Y索引:1) 進入LessonX.h中添加上面兩個函數的聲明:intSpritePosXToIndexX( const float fPosX );intSpritePosYToIndexY( const float fPosY );2) 進入LessonX.cpp中添加SpritePosXToIndexX的定義:int CGameMain: SpritePosXToIndexX ( const float fPosX )3) 首先得到左右邊界的坐標值。m_fGridStartX是在方塊的中心,所以需要減去半個方塊的寬度
34、才是左邊邊界。在SpritePosXToIndexX函數定義中添加下面的代碼:constfloatfLeftSide=m_fGridStartX - m_fGridSize / 2.f;constfloatfRightSide=fLeftSide + m_fGridSize * GRID_COUNT;4) 最后需要判斷坐標是否出了左右邊界,如果沒有則返回X索引值。在上面的函數里面添加下面的判斷代碼:if( fPosX < fLeftSide | fPosX > fRightSide )return -1;intiIndexX=(int)( (fPosX - fLeftSide) /
35、 m_fGridSize );return iIndexX;5) 在LessonX.cpp中添加SpritePosYToIndexY函數的定義:int CGameMain:SpritePosYToIndexY( const float fPosY )6) 首先獲取上下邊界坐標值。m_fGridStartY是在方塊的中心,所以需要減去半個方塊的寬度才是上邊邊界。在上面的函數定義中添加下面的代碼:constfloatfTopSide=m_fGridStartY - m_fGridSize / 2.f;constfloatfBottomSide=fTopSide + m_fGridSize * GR
36、ID_COUNT;7) 最后判斷是否超過了上下邊界,沒有則返回Y索引值:if( fPosY < fTopSide | fPosY > fBottomSide )return -1;intiIndexY=(int)( (fPosY - fTopSide) / m_fGridSize );return iIndexY;3、 有了上面的兩個函數,我們就可以將控制球精靈坐標轉換到二維格子數組索引,并判斷坐標是否超出邊界,在OnKeyDown函數中添加下面的代碼:floatfPosX=m_pControlBall->GetSpritePositionX(); floatfPosY=m_
37、pControlBall->GetSpritePositionY(); intiIndexX=SpritePosXToIndexX( fPosX );intiIndexY=SpritePosYToIndexY( fPosY );if( iIndexX < 0 | iIndexX >= GRID_COUNT | iIndexY < 0 | iIndexY >= GRID_COUNT )return;4、 根據上下左右方向鍵,先判斷控制球旁邊是否是方塊,如果是方塊則不能移動。不是方塊,則給予控制球一個速度。使用iIndexX, iIndexY的時候,注意要判斷是否是邊
38、緣的索引,如果不判斷就進行加1減1,訪問數組會造成下標溢出。即如果要判斷左邊是否是方塊阻擋,則索引值為 IndexX - 1 。此時必須先判斷iIndexX大于0,才能減一。如果iIndexX為0,代表直接可以移動。1) 如果是按下向上方向鍵:if( KEY_UP = iKey )if( iIndexY > 0 && RIGID_BLOCK = m_iGridDataiIndexY - 1iIndexX )return;/ 給予控制球一個方向速度,并設置移動狀態、隱藏指示箭頭m_iMoveState=1;m_pControlBall->SetSpriteLinear
39、VelocityY(-30.f);m_pGolfArrow->SetSpriteVisible(0);2) 如果是按下向下方向鍵:else if( KEY_DOWN = iKey )if( iIndexY < GRID_COUNT - 1 && RIGID_BLOCK = m_iGridDataiIndexY + 1iIndexX )return;/ 給予控制球一個方向速度,并設置移動狀態、隱藏指示箭頭m_iMoveState=2;m_pControlBall->SetSpriteLinearVelocityY(30.f);m_pGolfArrow->S
40、etSpriteVisible(0);3) 如果是按下向左方向鍵:else if( KEY_LEFT = iKey )if( iIndexX > 0 && RIGID_BLOCK = m_iGridDataiIndexYiIndexX - 1 )return;/ 給予控制球一個方向速度,并設置移動狀態、隱藏指示箭頭m_iMoveState=3;m_pControlBall->SetSpriteLinearVelocityX(-30.f);m_pGolfArrow->SetSpriteVisible(0);4) 如果是按下向右方向鍵:else if( KEY_R
41、IGHT = iKey )if( iIndexX < GRID_COUNT - 1 && RIGID_BLOCK = m_iGridDataiIndexYiIndexX + 1 )return;/ 給予控制球一個方向速度,并設置移動狀態、隱藏指示箭頭m_iMoveState=4;m_pControlBall->SetSpriteLinearVelocityX(30.f);m_pGolfArrow->SetSpriteVisible(0);實驗五球運動情況的處理【實驗內容】步驟一、獲得球所在邊緣格子信息步驟二、不同格子分情況處理【實驗思路】獲取球精靈的當前坐標并
42、將其轉換為二維格子的坐標,判斷在運動中球邊緣的情況,如果已經出了邊界則不需要再判斷,否則如果是方塊則球停靠、是黑洞則重新開始關卡、是出口則通關。【實驗指導】1、 進入LessonX.cpp中的GameRun函數中,移動狀態為移動中,時刻監測控制球的移動情況,根據移動方向的下一個方塊,進行對應的處理。添加下面的if判斷:if( 0 != m_iMoveState )2、 先將控制球精靈坐標轉換到二維格子數組索引,如果控制球已經出了邊界,所以不需要再判斷。在上面的判斷里面添加下面的代碼:floatfPosX=m_pControlBall->GetSpritePositionX();float
43、fPosY=m_pControlBall->GetSpritePositionY();intiIndexX=SpritePosXToIndexX( fPosX );intiIndexY=SpritePosYToIndexY( fPosY );/ 控制球已經出了邊界,所以不需要再判斷if( iIndexX < 0 | iIndexX >= GRID_COUNT | iIndexY < 0 | iIndexY >= GRID_COUNT )return;3、 根據當前方向,獲得控制球邊緣所在的格子信息(球在坐標是在中心點,所以加上球的大小的一半)。總共有4中方向,即上下左右,分別用1、2、3、4來表示,添加下面的代碼:floatfNextPosX=fPosX;floatfNextPosY=fPosY;/if( 1 = m_iMoveState )fNextPosY -= m_fGridSize * 0.5f;else if( 2 = m_iMoveState )fNextPosY += m_fGridSize * 0.5f;else if( 3
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 技能鑒定石油化工類-高級化工總控工真題庫-12
- 產品代理擔保三方協議
- 舉辦活動場地租賃合同
- 2025年縫制機械零部件合作協議書
- 專業展覽策劃組織合同協議
- 專業金融借款與擔保協議
- 電工基礎基礎考試題+參考答案解析
- 3月茶藝師中級模擬練習題及參考答案解析
- 土地承包合同合同
- 挖掘機臺班費合同
- GB/T 45007-2024職業健康安全管理體系小型組織實施GB/T 45001-2020指南
- 2023人教版小學美術四年級上冊期末試卷含部分答案(三套)
- 宋教仁出生及偉大事跡及遇刺真相
- 承包經營食堂日控管周排查月調度記錄和管理表
- 陪診可行性報告
- 專題07-對比手法(解析版)初中現代文閱讀考點+答題技巧模板之記敘文
- 跨國公司的外匯風險管理分析-以TCL科技為例
- 心理健康教育課件《如何面對考試焦慮》
- 污水源熱泵方案
- 完整版江蘇省政府采購專家庫入庫考試題庫(1-4套卷)
- 《唐詩中的春夏秋冬》五年級下冊詩詞鑒賞一等獎課件
評論
0/150
提交評論