




版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、C+語言課程設計一迷你高爾夫一、實驗內容玩家通過按下鍵盤上的上下左右方向鍵控制球的移動,使其最終到達出口則游戲通關。要求如下:1、 游戲分成3關,第一關、第二關、第三關界面圖如下:第一關第二關第三關2、 啟動游戲進入第一關,勝利后進入第二關,如果第三關通關,則游戲重新回到第一關。3、 游戲玩法是通關控制鍵盤上的上下左右方向鍵控制球的運動,單擊方向鍵,則球獲得一個向該方向直線運動的速度。如果球遇到方塊,則球停止運動,如果遇到黑洞,則游戲結束,重新開始該游戲,遇到出口則通關。4、 球靜止狀態(tài)下會有箭頭指示球可以運動的方向,運動狀態(tài)下則箭頭消失。如果球運動出世界邊界,則游戲結束,重新回到該游戲。二、
2、實驗指南實驗一 開始實驗【實驗任務】步驟一、打開FunCode,創(chuàng)建一個的C+語言項目;步驟二、導入GolfGame場景?!緦嶒炈悸贰堪磳嶒炛笇瓿??!緦嶒炛笇А?、 打開FunCode,點擊“項目”菜單,選擇“創(chuàng)建C+工程”注意:工程名名稱要求字母開頭,只能包含字母和數(shù)字,且名字中間不能有空格。2、 點擊菜單“項目”中的“導入地圖模塊”,如圖一。跳出一個對話框,選中“GolfGame”模板,點擊“導入到工程”按鈕,如圖二。 圖 一 圖 二3、 導入成功后的,界面如下圖所示:地圖不僅包括界面設計,還包括該游戲可能要用到的其他精靈。添加到“場景”中的精靈,都已經(jīng)取好名稱,并根據(jù)程序要求設置好中心
3、點、鏈接點等,學生只需要直接編程就可以。實驗二 游戲關卡初始化【實驗內容】步驟一、關卡地圖初始化步驟二、清除上一關卡數(shù)據(jù)步驟三、根據(jù)當前關卡,選擇關卡數(shù)據(jù)【實驗思路】游戲開始的時候首先要清除上一關的游戲數(shù)據(jù),即將上一關創(chuàng)建的精靈從地圖中刪掉。將游戲地圖分成12*12的方格界面,游戲總共分成三關,因此我們需要用三個二維數(shù)組m_iLevelData1GRID_COUNTGRID_COUNTm_iLevelData2GRID_COUNTGRID_COUNTm_iLevelData3GRID_COUNTGRID_COUNT(其中GRID_COUNT的值為12)來存放這三關的數(shù)據(jù)即可。二維數(shù)組中0表示該
4、位置不創(chuàng)建精靈,否則根據(jù)不同的值創(chuàng)建不同精靈,RIGID_BLOCK(值為1)表示創(chuàng)建一個方塊精靈,BLACK_HOLE(值為2)表示創(chuàng)建一個黑洞精靈,GOLF_EXIT(值為3)表示創(chuàng)建一個出口精靈。每次把代表該關卡的二維數(shù)組的數(shù)據(jù)拷貝到存儲當前關卡m_iGridData的二維數(shù)組中?!緦嶒炛笇А?、 進入LessonX.h的CGameMain類中,添加以下成員變量的聲明:intm_iMoveState;/ 控制球的移動狀態(tài):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;/ 本關卡創(chuàng)建的阻擋物方塊數(shù)量intm_iBlackHoleCount;/ 本關卡創(chuàng)建的黑洞數(shù)量intm_iGolfExitCount;/ 本關卡創(chuàng)建的出口的數(shù)量intm_iGridDataGRID_COUNTGRID_COUNT;/二維數(shù)組,存
6、儲當前關卡N*N的矩陣方塊信息static const intm_iLevelData1GRID_COUNTGRID_COUNT ;static const intm_iLevelData2GRID_COUNTGRID_COUNT ;static const intm_iLevelData3GRID_COUNTGRID_COUNT ; vector m_vRigidBlock;/阻擋物精靈向量數(shù)組vector m_vBlackHole;/黑洞精靈向量數(shù)組vector m_vGolfExit;/出口精靈向量數(shù)組2、 進入LessonX.h中在頭文件聲明的后面添加下面的宏定義代碼:#defineG
7、RID_COUNT12/ N * N 的矩陣方塊,一個N的大小#defineMAX_LEVEL3/ 最大關卡數(shù)量。如果要增加關卡,請先修改此值#defineRIGID_BLOCK1/ 以下3個分別為方塊阻擋物、黑洞、出口的值#defineBLACK_HOLE2#defineGOLF_EXIT33、 在LessonX.h頭文件#include 下面添加:#include using std:vector;4、 進入LessonX.cpp中添加上面的成員變量的初始化:1) 在構造函數(shù)中把m_iGameState的值由0改為1:m_iGameState=1;2) 在構造函數(shù)中添加下面代碼:m_iCu
8、rLevel=1;m_iMoveState=0;/ 控制球的移動狀態(tài):0當前靜止,可以移動,1、2、3、4:代表上下左右4個方向移動中,按鍵無響應m_iRigidBlockCount=0;/ 本關卡創(chuàng)建的阻擋物方塊數(shù)量m_iBlackHoleCount=0;/ 本關卡創(chuàng)建的黑洞數(shù)量m_iGolfExitCount=0;3) 對于const類型的成員變量,我們需要在函數(shù)外面單獨進行初始化,在文件最后面添加如下代碼:const float CGameMain:m_fGridStartX=-27.5f;const float CGameMain:m_fGridStartY=-27.5f;const
9、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_BLOCK,RIGID_BLOCK,RIGID_BLOCK,RIGID_BLOCK, 0, 0, 0,0, 0, 0, RIGID_BLOCK,0,0,0,0,RIG
10、ID_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, 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 CGame
11、Main: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, RIGID_BLOCK, 0, 0, 0, 0, 0, 0, 0, 0, RIGID_BLOCK, 0,0, RIGID_BLOCK, 0, 0, 0, 0
12、, 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, 0,0, RIGID_BLOCK, 0, 0, 0, 0, 0, RIGID_BLOCK, 0, 0, RIGID_BLOCK, 0,0, RIGID_BL
13、OCK, 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, RIGID_BLOCK, RIGID_BLOCK, RIGID_BLOCK, 0, RIGID_BLOCK, 0;const int CGameMain:m_i
14、LevelData3GRID_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, 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
15、, 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_BLOCK, 0,0, 0, 0, 0, BLACK_HOLE, RIGID_BLOCK, 0, 0, 0, 0, 0, 0,0, 0, 0, 0, 0, 0,
16、 0, 0, 0, 0, 0, 0;二維數(shù)組中0表示該位置不創(chuàng)建精靈,否則根據(jù)不同的值創(chuàng)建不同精靈,RIGID_BLOCK(值為1)表示創(chuàng)建一個方塊精靈,BLACK_HOLE(值為2)表示創(chuàng)建一個黑洞精靈,GOLF_EXIT(值為3)表示創(chuàng)建一個出口精靈。4) 進入GameInit函數(shù)里面,將球的運動狀態(tài)初始化為靜止,添加下面代碼:m_iMoveState=0;5、 游戲初始化的時候,首先我們需要將前邊添加的精靈全部刪除掉。1) 進入LessonX.h文件的CGameMain類中添加該函數(shù)的聲明:void ClearAllSprite();2) 在LessonX.cpp最后面添加該函數(shù)的定義:
17、void CGameMain: ClearAllSprite()3) 再使用3個循環(huán),分別將上一關卡創(chuàng)建的3種精靈刪除掉。在上邊定義的函數(shù)中添加如下代碼:intiLoop= 0;for( iLoop = 0; iLoop DeleteSprite();for( iLoop = 0; iLoop DeleteSprite();for( iLoop = 0; iLoop DeleteSprite();/ 總數(shù)置0,重新創(chuàng)建m_iRigidBlockCount=0;m_iBlackHoleCount=0;m_iGolfExitCount=0;其中m_vRigidBlock、m_vBlackHole、
18、m_vGolfExit是存儲三種精靈的向量數(shù)組,每一個循環(huán)都遍歷一遍向量數(shù)組并調用數(shù)組中每個精靈的DeleteSprite函數(shù)即可。m_vRigidBlock.size()、m_vBlackHole.size()、m_vGolfExit.size()表示每種精靈的總數(shù)4) 最后在GameInit()中添加調用此函數(shù)的代碼:ClearAllSprite();5) 在GameInit()中,我們對關卡進行選擇初始化。a.選擇關卡我們使用了switch-case結構,程序通過判斷switch中的參數(shù)進入到不同的case中去,每個case就是一種情況的實現(xiàn)。代碼如下:/ 控制球在數(shù)組中的開始位置(出生
19、點),該位置不能為0.根據(jù)關卡數(shù)據(jù)自行指定intiControlStartX = 0, iControlStartY = 0;/ 根據(jù)當前關卡,選擇關卡數(shù)據(jù)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, s
20、izeof(int) * GRID_COUNT * GRID_COUNT );break;/ 如果要新增關卡,在此處增加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函數(shù)作用是從源src所指的內存地址的起始位置開始拷貝n個字節(jié)到目標dest所指的內存地址的起始位置中。因為二維數(shù)組在內存中的存放方
21、式是連續(xù)的,因此我們將源地址拷貝給m_iGridData的起始地址之后,系統(tǒng)后自動根據(jù)m_iGridData的下標來找到正確的值。至此,本實驗結束。實驗三初始化游戲精靈【實驗內容】步驟一、創(chuàng)建精靈步驟二、初始化精靈位置【實驗思路】遍歷二維數(shù)組m_iGridData,根據(jù)數(shù)組值生成對應的精靈實例:值為0的時候不用創(chuàng)建,需要創(chuàng)建的精靈名字前綴為(按照宏定義的1,2,3順序):RigidBlock, BlackHole, GolfExit。每創(chuàng)建一種精靈,將其總數(shù)加1 :m_iRigidBlockCount, m_iBlackHoleCount,m_iGolfExitCount?!緦嶒炛笇А?、 進
22、入LessonX.h,CGameMain類中添加下面成員變量的聲明:CSprite*m_pControlBall;/控制球精靈CSprite*m_pGolfArrow;/指示箭頭精靈在LessonX.cpp中CGameMain類在構造函數(shù)里面添加上面成員變量的初始化:m_pControlBall=new CSprite(ControlBall);m_pGolfArrow=new CSprite(GolfArrow);2、 創(chuàng)建精靈之后需要將精靈移到特定位置,因此我們需要定義一個自定義的函數(shù)MoveSpriteToBlock來實現(xiàn)這個功能。1) 進入LessonX.h中添加該函數(shù)的聲明:void
23、 MoveSpriteToBlock( CSprite* tmpSprite, const int iIndexX, const int iIndexY );2) 在LessonX.cpp最后面添加該函數(shù)的定義:void CGameMain:MoveSpriteToBlock( CSprite* tmpSprite, const int iIndexX, const int iIndexY )3) 傳入該函數(shù)的是精靈實體以及x,y坐標參數(shù)。再通過SetSpritePosition函數(shù)設置精靈位置,在該函數(shù)里面添加如下代碼:floatfPosX=m_fGridStartX + iIndexX *
24、 m_fGridSize;floatfPosY=m_fGridStartY + iIndexY * m_fGridSize;tmpSprite-SetSpritePosition(fPosX, fPosY);3、 這里定義在GameInit函數(shù)中來創(chuàng)建控制球、方塊精靈、出口精靈和黑洞精靈。通過一個函數(shù)來實現(xiàn)CreateAllSprite()。原理是通過兩個for循環(huán)來,判斷m_iGridData的值,如果為0,則不創(chuàng)建,如果為RIGID_BLOCK則創(chuàng)建一個方塊精靈,為 BLACK_HOLE則創(chuàng)建一個黑洞精靈,為GOLF_EXIT則創(chuàng)建一個出口精靈。由于我們預先在地圖中擺放了三個模板精靈,因此
25、只需要使用CloneSprite函數(shù)即可創(chuàng)建新的精靈。然后再調用MoveSpriteToBlock函數(shù)將精靈移動到指定位置。最后每創(chuàng)建一個實現(xiàn)精靈,將它添加到相應的精靈向量數(shù)組中。、1) 進入LessonX.h文件的CGameMain類中添加該函數(shù)的聲明: void CreateAllSprite();2) 在LessonX.cpp最后面添加該函數(shù)的定義:void CGameMain: CreateAllSprite()3) 在定義汗的函數(shù)中添加變量聲明:intiLoopX = 0, iLoopY = 0;CSprite* tmpSprite;char*szName = NULL;4) 實現(xiàn)兩
26、個for循環(huán):for( iLoopY = 0; iLoopY GRID_COUNT; iLoopY+ )for( int iLoopX = 0; iLoopX CloneSprite(RigidBlockTemplate);MoveSpriteToBlock( tmpSprite, iLoopX, iLoopY );m_vRigidBlock.push_back(tmpSprite);m_iRigidBlockCount+;如果是黑洞,則創(chuàng)建黑洞精靈:else if( BLACK_HOLE = m_iGridDataiLoopYiLoopX )szName=CSystem:MakeSprite
27、Name( BlackHole, m_iBlackHoleCount );tmpSprite=new CSprite(szName);tmpSprite-CloneSprite(BlackHoleTemplate);MoveSpriteToBlock( tmpSprite, iLoopX, iLoopY );m_vBlackHole.push_back(tmpSprite);m_iBlackHoleCount+;如果是出口,則創(chuàng)建出口精靈:else if( GOLF_EXIT = m_iGridDataiLoopYiLoopX )szName=CSystem:MakeSpriteName( G
28、olfExit, m_iGolfExitCount );tmpSprite=new CSprite(szName);tmpSprite-CloneSprite(GolfExitTemplate);MoveSpriteToBlock( tmpSprite, iLoopX, iLoopY );m_vGolfExit.push_back(tmpSprite);m_iGolfExitCount+;6) 將控制球和指示箭頭擺放到初始位置,此時球靜止,因此指示箭頭可見。在上面的兩個循環(huán)后面添加下面的代碼:m_pControlBall-SetSpriteLinearVelocity( 0.f, 0.f);M
29、oveSpriteToBlock(m_pControlBall,m_iControlStartX,m_iControlStartY);MoveSpriteToBlock(m_pGolfArrow, m_iControlStartX, m_iControlStartY );m_pGolfArrow-SetSpriteVisible(1);7) 最后在GameInit()中調用此函數(shù):CreateAllSprite();至此,本實驗結束。實驗四 移動球【實驗內容】步驟一、響應鍵盤按鍵按下消息步驟二、球精靈坐標轉換為二維格子數(shù)組索引步驟三、判斷移動方向,使球獲取速度【實驗思路】首先響應系統(tǒng)的按鍵消息
30、函數(shù),然后獲取精靈坐標,并將其轉換為二維格子中的坐標,判斷其旁邊的格子是否是方塊,如果不是則給球一個移動的速度?!緦嶒炛笇А?、 在LessonX.cpp文件的OnKeyDown函數(shù)中添加代碼:a.首先判斷游戲狀態(tài),只有在游戲中已經(jīng)可以移動狀態(tài)才響應按鍵,在上面函數(shù)中添加下面的代碼:if( 2 != m_iGameState | 0 != m_iMoveState )return;2、 獲取控制球精靈坐標轉換到二維格子數(shù)組索引,這里我們需要定義兩個函數(shù)SpritePosXToIndexX和SpritePosXToIndexY分別處理精靈坐標轉換為二維格子的X索引和Y索引:1) 進入Lesson
31、X.h中添加上面兩個函數(shù)的聲明:intSpritePosXToIndexX( const float fPosX );intSpritePosYToIndexY( const float fPosY );2) 進入LessonX.cpp中添加SpritePosXToIndexX的定義:int CGameMain: SpritePosXToIndexX ( const float fPosX )3) 首先得到左右邊界的坐標值。m_fGridStartX是在方塊的中心,所以需要減去半個方塊的寬度才是左邊邊界。在SpritePosXToIndexX函數(shù)定義中添加下面的代碼:constfloatfLe
32、ftSide=m_fGridStartX - m_fGridSize / 2.f;constfloatfRightSide=fLeftSide + m_fGridSize * GRID_COUNT;4) 最后需要判斷坐標是否出了左右邊界,如果沒有則返回X索引值。在上面的函數(shù)里面添加下面的判斷代碼:if( fPosX fRightSide )return -1;intiIndexX=(int)( (fPosX - fLeftSide) / m_fGridSize );return iIndexX;5) 在LessonX.cpp中添加SpritePosYToIndexY函數(shù)的定義:int CGam
33、eMain:SpritePosYToIndexY( const float fPosY )6) 首先獲取上下邊界坐標值。m_fGridStartY是在方塊的中心,所以需要減去半個方塊的寬度才是上邊邊界。在上面的函數(shù)定義中添加下面的代碼:constfloatfTopSide=m_fGridStartY - m_fGridSize / 2.f;constfloatfBottomSide=fTopSide + m_fGridSize * GRID_COUNT;7) 最后判斷是否超過了上下邊界,沒有則返回Y索引值:if( fPosY fBottomSide )return -1;intiIndexY=
34、(int)( (fPosY - fTopSide) / m_fGridSize );return iIndexY;3、 有了上面的兩個函數(shù),我們就可以將控制球精靈坐標轉換到二維格子數(shù)組索引,并判斷坐標是否超出邊界,在OnKeyDown函數(shù)中添加下面的代碼:floatfPosX=m_pControlBall-GetSpritePositionX(); floatfPosY=m_pControlBall-GetSpritePositionY(); intiIndexX=SpritePosXToIndexX( fPosX );intiIndexY=SpritePosYToIndexY( fPosY
35、);if( iIndexX = GRID_COUNT | iIndexY = GRID_COUNT )return;4、 根據(jù)上下左右方向鍵,先判斷控制球旁邊是否是方塊,如果是方塊則不能移動。不是方塊,則給予控制球一個速度。使用iIndexX, iIndexY的時候,注意要判斷是否是邊緣的索引,如果不判斷就進行加1減1,訪問數(shù)組會造成下標溢出。即如果要判斷左邊是否是方塊阻擋,則索引值為 IndexX - 1 。此時必須先判斷iIndexX大于0,才能減一。如果iIndexX為0,代表直接可以移動。1) 如果是按下向上方向鍵:if( KEY_UP = iKey )if( iIndexY 0 &
36、RIGID_BLOCK = m_iGridDataiIndexY - 1iIndexX )return;/ 給予控制球一個方向速度,并設置移動狀態(tài)、隱藏指示箭頭m_iMoveState=1;m_pControlBall-SetSpriteLinearVelocityY(-30.f);m_pGolfArrow-SetSpriteVisible(0);2) 如果是按下向下方向鍵:else if( KEY_DOWN = iKey )if( iIndexY SetSpriteLinearVelocityY(30.f);m_pGolfArrow-SetSpriteVisible(0);3) 如果是按下向
37、左方向鍵:else if( KEY_LEFT = iKey )if( iIndexX 0 & RIGID_BLOCK = m_iGridDataiIndexYiIndexX - 1 )return;/ 給予控制球一個方向速度,并設置移動狀態(tài)、隱藏指示箭頭m_iMoveState=3;m_pControlBall-SetSpriteLinearVelocityX(-30.f);m_pGolfArrow-SetSpriteVisible(0);4) 如果是按下向右方向鍵:else if( KEY_RIGHT = iKey )if( iIndexX SetSpriteLinearVelocityX(
38、30.f);m_pGolfArrow-SetSpriteVisible(0);實驗五球運動情況的處理【實驗內容】步驟一、獲得球所在邊緣格子信息步驟二、不同格子分情況處理【實驗思路】獲取球精靈的當前坐標并將其轉換為二維格子的坐標,判斷在運動中球邊緣的情況,如果已經(jīng)出了邊界則不需要再判斷,否則如果是方塊則球??俊⑹呛诙磩t重新開始關卡、是出口則通關?!緦嶒炛笇А?、 進入LessonX.cpp中的GameRun函數(shù)中,移動狀態(tài)為移動中,時刻監(jiān)測控制球的移動情況,根據(jù)移動方向的下一個方塊,進行對應的處理。添加下面的if判斷:if( 0 != m_iMoveState )2、 先將控制球精靈坐標轉換到二
39、維格子數(shù)組索引,如果控制球已經(jīng)出了邊界,所以不需要再判斷。在上面的判斷里面添加下面的代碼:floatfPosX=m_pControlBall-GetSpritePositionX();floatfPosY=m_pControlBall-GetSpritePositionY();intiIndexX=SpritePosXToIndexX( fPosX );intiIndexY=SpritePosYToIndexY( fPosY );/ 控制球已經(jīng)出了邊界,所以不需要再判斷if( iIndexX = GRID_COUNT | iIndexY = GRID_COUNT )return;3、 根據(jù)當前方向,獲得控制球邊緣所在的格子信息(球在坐標是在中心點,所以加上球的大小的一半)??偣灿?中方向,即上下左右,分別用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 = m_iMoveState )fNextPosX-= m_fGridSize * 0.5f;els
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年幼兒口語類測試題及答案
- 2025年參數(shù)估計測試題及答案
- 2025年注會合同法試題及答案
- 2025年考試試題閱讀理解及答案
- 2025年母嬰保健試題100道及答案
- 2025年召喚與合成測試題及答案
- 2025年北安醫(yī)院面試題型及答案
- 2025年礦區(qū)招聘考試試題及答案
- 2025年利群時代培訓試題及答案
- 2025年物理力的測試題及答案
- 全國河大版(三起)小學信息技術第三冊第1單元第1課《珍藏童年的回憶-文字輸入和格式設置》教學設計
- 主動脈內球囊反搏課件
- 2025年新蘇教版數(shù)學一年級下冊課件 期末復習 第4課時 數(shù)據(jù)分類
- 《新能源汽車技術》課件-第二章 動力電池
- 拘留所被拘留人員管理教育
- 兒童飲食健康指南
- 2024年全國職業(yè)院校技能大賽中職組(嬰幼兒保育賽項)省賽考試題庫(含答案)
- 2025-2030年中國VOC治理催化劑行業(yè)發(fā)展現(xiàn)狀及前景趨勢分析報告
- 2025青海省公路局事業(yè)單位招聘高頻重點提升(共500題)附帶答案詳解
- 第四單元第一課編寫學校百科詞條說課稿 2024-2025學年西交大版(2024)初中信息技術七年級上冊
- 《公路施工機械化》課件
評論
0/150
提交評論