版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p><b> 連連看</b></p><p><b> 問(wèn)題描述</b></p><p> 連連看是一款簡(jiǎn)單有趣的小游戲,曾經(jīng)風(fēng)靡一時(shí),玩家要將相同的兩張牌用三根以內(nèi)的直線連在一起就可以消除,規(guī)則簡(jiǎn)單容易上手,游戲速度節(jié)奏快,畫(huà)面清晰可愛(ài),適合細(xì)心的玩家。游戲勝利條件的判定:將棋盤(pán)上面的格子全部消除掉;失敗的判定:規(guī)定的時(shí)間內(nèi)
2、格子沒(méi)有消除。</p><p><b> 問(wèn)題分析</b></p><p> 連連看需要解決的問(wèn)題包括:</p><p> ?。?)整個(gè)游戲界面和各種圖案的圖形顯示;</p><p> ?。?)如何判斷鼠標(biāo)所點(diǎn)的兩個(gè)圖像能否相消;</p><p> ?。?)如何判斷是否消除完全;</p&
3、gt;<p> ?。?)如何判斷游戲的結(jié)束及如何終止游戲;</p><p> ?。?)游戲難度的設(shè)計(jì)和得分規(guī)則</p><p> 游戲總的流程可以描述如下:首先出現(xiàn)游戲界面,一幅由10*6的小圖片的構(gòu)成的畫(huà)面,玩家需要點(diǎn)擊 2 個(gè)相同圖案的對(duì)子,其連接線不多于 3 根直線,也就是說(shuō)連接相同圖案時(shí),直線只能有兩個(gè)折點(diǎn),就可以成功將對(duì)子消除。</p><p&
4、gt; 此外,需要重點(diǎn)考慮的是游戲面板和各種形狀的方塊的數(shù)據(jù)結(jié)構(gòu)表示。格子面板可以用一個(gè)二維數(shù)組來(lái)表示。</p><p><b> 開(kāi)發(fā)工具的介紹</b></p><p> 【 VS2008 】</p><p> VS2008引入了250多個(gè)新特性,整合了對(duì)象、關(guān)系型數(shù)據(jù)、XML的訪問(wèn)方式,語(yǔ)言更加簡(jiǎn)潔。使用Visual Studio
5、2008可以高效開(kāi)發(fā)Windows應(yīng)用程序。設(shè)計(jì)器中可以實(shí)時(shí)反映變更,XAML中智能感知功能可以提高開(kāi)發(fā)效率。同時(shí)Visual Studio 2008支持項(xiàng)目模板、調(diào)試器和部署程序。Visual Studio 2008可以高效開(kāi)發(fā)Web應(yīng)用,集成了AJAX 1.0,包含AJAX項(xiàng)目模板,它還可以高效開(kāi)發(fā)Office應(yīng)用和Mobile應(yīng)用。VS的開(kāi)發(fā)界面分為兩個(gè)版本:整合模式和孤立模式,分別對(duì)基于語(yǔ)言的開(kāi)發(fā)和基于特別工具的開(kāi)發(fā)作了優(yōu)化。&
6、lt;/p><p><b> 【 EasyX 】</b></p><p> EasyX 是針對(duì) C++ 的圖形庫(kù),可以幫助 C 語(yǔ)言初學(xué)者快速上手圖形和游戲編程。</p><p> 許多學(xué)編程的都是從 C 語(yǔ)言開(kāi)始入門(mén)的,而目前的現(xiàn)狀是:</p><p> 1. 有些學(xué)校以 Turbo C 為環(huán)境講 C 語(yǔ)言,只是
7、Turbo C 的環(huán)境實(shí)在太老了,復(fù)制粘貼都很不方便。</p><p> 2. 有些學(xué)校直接拿 VC 來(lái)講 C 語(yǔ)言,因?yàn)?VC 的編輯和調(diào)試環(huán)境都很優(yōu)秀,并且 VC 有適合教學(xué)的免費(fèi)版本??上г?VC 下只能做一些文字性的練習(xí)題,想畫(huà)條直線畫(huà)個(gè)圓都很難,還要注冊(cè)窗口類、建消息循環(huán)等等,初學(xué)者會(huì)受?chē)?yán)重打擊的。初學(xué)編程想要繪圖就得用 TC,很是無(wú)奈。</p><p> 3. 還有計(jì)算機(jī)圖
8、形學(xué),這門(mén)課程的重點(diǎn)是繪圖算法,而不是 Windows 編程。所以,許多老師不得不用 TC 教學(xué),因?yàn)?Windows 繪圖太復(fù)雜了,會(huì)偏離教學(xué)的重點(diǎn)。新的圖形學(xué)的書(shū)有不少是用的 OpenGL,可是門(mén)檻依然很高。</p><p> 所以,于是就有了EasyX 庫(kù)方便的開(kāi)發(fā)平臺(tái)和 TC 簡(jiǎn)單的繪圖功能。</p><p><b> 設(shè)計(jì)</b></p>
9、<p><b> 【程序總體結(jié)構(gòu)】:</b></p><p><b> 【界面設(shè)計(jì)】:</b></p><p> 界面的設(shè)計(jì)通過(guò)插入背景圖片 beijing.bmp , 在對(duì)每一個(gè)格子的賦圖片,通過(guò)getimage( )從board.bmp中截下所需要的圖,再利用putimage( )放置每一個(gè)小圖。</p><
10、;p><b> 具體算法:</b></p><p> loadimage(&beijing,"D:\\llk\\beijing.bmp");//載入背景圖</p><p> putimage(0,0,&beijing);//放置背景圖</p><p> for(int i = 0 ;i <
11、 ROW; i ++)</p><p> for(int j = 0 ;j < COL ; j++)</p><p><b> {</b></p><p> idy = i * 54 + board_Y ,idx = j * 48+ board_X;</p><p> putimage(idx,idy,&a
12、mp;image[board[i + 1][j + 1]]);//根據(jù)賦的值放置每一個(gè)格子圖</p><p><b> }</b></p><p> beijing.bmp</p><p><b> board.bmp</b></p><p> 【重要數(shù)據(jù)的數(shù)據(jù)結(jié)構(gòu)設(shè)計(jì)】:</p
13、><p> struct BOARD //點(diǎn)擊的格子信息</p><p><b> {</b></p><p> int tx,ty; //格子坐標(biāo)</p><p> int xx,yy; //屏幕坐標(biāo)</p><p> int data;
14、 //圖片類型</p><p><b> };</b></p><p> 定義BOARD型的結(jié)構(gòu)體,里面包含的是鼠標(biāo)點(diǎn)擊以后,所讀取的點(diǎn)擊點(diǎn)在屏幕里的坐標(biāo)(xx,yy)</p><p> 在二維數(shù)組里的坐標(biāo)board[tx][ty],以及在給每一個(gè)二維數(shù)組元素賦的值data(用來(lái)判斷兩個(gè)格子是否相等,相等以后賦值為0,以便判斷是否存在格子
15、,為之后的尋找路徑鋪墊)</p><p> int board[ROW + 2][COL + 2];</p><p> 二維數(shù)組,用來(lái)記錄格子的信息,其值是判定是否有方塊的標(biāo)志。</p><p> MOUSEMSG mouse;</p><p> 鼠標(biāo)的記錄類型struct MOUSEMSG</p><p>
16、;<b> {</b></p><p> UINT uMsg; // 當(dāng)前鼠標(biāo)消息</p><p> bool mkCtrl; // Ctrl 鍵是否按下</p><p> bool mkShift; // Shift 鍵是否按下</p><p> bool mkLButton; // 鼠標(biāo)
17、左鍵是否按下</p><p> bool mkMButton; // 鼠標(biāo)中鍵是否按下</p><p> bool mkRButton; // 鼠標(biāo)右鍵是否按下</p><p> int x; // 當(dāng)前鼠標(biāo) x 坐標(biāo)(物理坐標(biāo))</p><p> int y; // 當(dāng)前鼠標(biāo) y 坐標(biāo)(物理坐標(biāo))
18、</p><p> int wheel; // 鼠標(biāo)滾輪滾動(dòng)值</p><p><b> };</b></p><p> #define board_X 140 //格子區(qū)距左邊框距離</p><p> #define board_Y 140 //格子呢區(qū)距上邊框距離
19、</p><p> #define COL 10 //格子區(qū)列數(shù)</p><p> #define ROW 6 //格子區(qū)行數(shù)</p><p> #define board_number 15 //游戲圖片數(shù)目</p><p><b> 【函數(shù)
20、設(shè)計(jì)】:</b></p><p><b> 函數(shù)的功能列表:</b></p><p> void Init();//初始化界面</p><p> void load_picture (); //加載圖片</p><p> void del(BOARD &rec);//每個(gè)格子賦值為&l
21、t;/p><p> void leftbottondown (MOUSEMSG mouse);//實(shí)現(xiàn)鼠標(biāo)左擊效果</p><p> void frame (int leftx,int lefty);//畫(huà)邊框</p><p> bool judge_mouse(int leftx,int lefty);//判斷鼠標(biāo)是否在游戲區(qū)</p>&
22、lt;p> void select(int leftx,int lefty);//顯示選中效果</p><p> void accurate(int& leftx,int& lefty);//使格子的坐標(biāo)都在邊緣</p><p> void cover(int x1,int y1,int x2,int y2,int x3,int y3,int x4,int
23、 y4); //覆蓋直線</p><p> void line(int x1,int y1,int x2,int y2,int x3,int y3,int x4,int y4) ; //用直線連接</p><p> void exchange(BOARD& pre,BOARD& cur);//交換格子信息</p><p> b
24、ool click(int mousex,int mousey); //判斷單擊是否有效</p><p> void record(int leftx,int lefty,BOARD &rec);//記錄選中的格子</p><p> void mouse_to_board(int mousex,int mousey,int *idx,int *idy
25、);//鼠標(biāo)的坐標(biāo)轉(zhuǎn)為格子的數(shù)組下標(biāo)</p><p> int findpath(BOARD &pre,BOARD &cur);//尋找路徑,判斷是否相等</p><p> void progressbar();//畫(huà)進(jìn)度條</p><p> void updateprogressbar(long t);//更新進(jìn)度條</p>
26、<p> 因?yàn)橛性S多的函數(shù)是執(zhí)行圖像處理以及坐標(biāo)轉(zhuǎn)化的簡(jiǎn)單操作,這里畫(huà)出包含關(guān)鍵算法的主要函數(shù)的流程圖,其他的函數(shù)只做文字的描述介紹。</p><p> findpath(BOARD &pre,BOARD &cur)函數(shù)</p><p> cover(int x1,int y1,int x2,int y2,int x3,int y3,int x4,int y
27、4)函數(shù)</p><p><b> Init()函數(shù)</b></p><p> load_picture ()函數(shù):</p><p> 這是一個(gè)類似于初始圖片的函數(shù),利用 loadimage ,SetWorkingImage,對(duì)含有格子圖片信息的圖進(jìn)行分割讀取,并存入image[]的IMAGE類型的數(shù)組里,同時(shí)還讀入了填充背景的圖(填充線
28、條)。</p><p> del(BOARD &rec)函數(shù):</p><p> 刪除函數(shù),將之前記錄的鼠標(biāo)信息全部賦值為0;</p><p> leftbottondown (MOUSEMSG mouse)函數(shù):</p><p> 記錄鼠標(biāo)的信息,如果鼠標(biāo)是第一次點(diǎn)擊的話,將其信息存入pre里,如果鼠標(biāo)是第二次點(diǎn)擊的話,將其
29、存入cur里,通過(guò)findpath()函數(shù)來(lái)相消與否,如果能相消,則將鼠標(biāo)點(diǎn)的兩塊區(qū)域覆蓋,同時(shí)調(diào)用del函數(shù),來(lái)清除信息,在此過(guò)程中,根據(jù)統(tǒng)計(jì)剩余格子對(duì)數(shù)的變量counter,來(lái)給出分?jǐn)?shù)(用s[]數(shù)組來(lái)存儲(chǔ)分?jǐn)?shù)信息,并在相應(yīng)位置輸出)。</p><p> frame (int leftx,int lefty)函數(shù):</p><p> 根據(jù)導(dǎo)入的參數(shù)畫(huà)一個(gè)格子邊框。</p>
30、<p> judge_mouse(int leftx,int lefty)函數(shù):</p><p> 判斷鼠標(biāo)的點(diǎn)擊區(qū)域是否在規(guī)定的范圍里。</p><p> select(int leftx,int lefty)函數(shù):</p><p> 在鼠標(biāo)點(diǎn)擊選擇以后,顯示frame的效果,并記錄數(shù)據(jù)。</p><p> accu
31、rate(int& leftx,int& lefty)函數(shù):</p><p> 規(guī)范坐標(biāo)的函數(shù),鼠標(biāo)點(diǎn)擊的區(qū)域是在一個(gè)范圍內(nèi)的,此函數(shù)能把屬于一個(gè)區(qū)域的坐標(biāo)歸整為統(tǒng)一的坐標(biāo)。</p><p> line(int x1,int y1,int x2,int y2,int x3,int y3,int x4,int y4) 函數(shù):</p><p> 連
32、線函數(shù),通過(guò)導(dǎo)入的點(diǎn)的坐標(biāo)來(lái)調(diào)用moveto,lineto函數(shù)畫(huà)線。</p><p> exchange(BOARD& pre,BOARD& cur)函數(shù):</p><p> 交換格子信息的函數(shù),在點(diǎn)擊2次后,發(fā)現(xiàn)兩個(gè)格子并不能相消后,將pre取第二次點(diǎn)擊的格子信息。</p><p> click(int mousex,int mousey)函
33、數(shù):</p><p> 判斷點(diǎn)擊的地方是不是有效,即已經(jīng)被消去的格子,點(diǎn)擊時(shí),沒(méi)有像有格子的地方一樣會(huì)出現(xiàn)線框的情況。</p><p> record(int leftx,int lefty,BOARD &rec)函數(shù):</p><p> 將鼠標(biāo)的屏幕坐標(biāo)轉(zhuǎn)化并記錄在BOARD類型的變量里。</p><p> mouse_to
34、_board(int mousex,int mousey,int *idx,int *idy)函數(shù):</p><p> 將鼠標(biāo)的坐標(biāo)轉(zhuǎn)化為格子信息。</p><p> progressbar( )函數(shù):</p><p> 畫(huà)進(jìn)度條,作矩形,并填充相應(yīng)顏色。</p><p> updateprogressbar(long t)函數(shù):&l
35、t;/p><p> 進(jìn)度條的更新函數(shù),讀取當(dāng)前系統(tǒng)時(shí)間與游戲開(kāi)始時(shí)系統(tǒng)時(shí)間的差,來(lái)畫(huà)圖覆蓋進(jìn)度條,從而達(dá)到進(jìn)度條運(yùn)動(dòng)的效果。</p><p> 【程序運(yùn)行整體視圖】</p><p><b> 源程序</b></p><p> #include <stdio.h></p><p>
36、 #include <graphics.h></p><p> #include <conio.h></p><p> #include <time.h></p><p> #include <windows.h></p><p> #include <mmsystem.h>
37、//播放音樂(lè)用的庫(kù)</p><p> #pragma comment(lib, "WINMM.LIB")//播放音樂(lè)用的庫(kù)</p><p> #define ture 1</p><p> #define flase 0</p><p> #define board_X 140 //格子區(qū)距左邊框距
38、離</p><p> #define board_Y 140 //格子呢區(qū)距上邊框距離</p><p> #define COL 10 //格子區(qū)列數(shù)</p><p> #define ROW 6 //格子區(qū)行數(shù)</p><p> #define boa
39、rd_number 15 //游戲圖片數(shù)目</p><p> #define W 48 //格子的長(zhǎng)</p><p> #define H 54 //格子的寬</p><p> #define N 555 //背景的寬</p><p> #define
40、M 797 //背景的長(zhǎng)</p><p> #define max(a,b) a>b?a:b</p><p> #define min(a,b) a<b?a:b</p><p> #define DGREE 2 //時(shí)間條的運(yùn)動(dòng)速度</p><p> struct BOARD
41、 //點(diǎn)擊的格子信息</p><p><b> {</b></p><p> int tx,ty; //格子坐標(biāo)</p><p> int xx,yy; //屏幕坐標(biāo)</p><p> int data; //圖片類型</p><p> }pr
42、e,cur,dur;</p><p> IMAGE image[board_number+ 1]; //圖片庫(kù)</p><p> IMAGE tianchong; //填充圖片</p><p> IMAGE tianchong1; //覆蓋分?jǐn)?shù)的圖片</p><p> IMAGE tianchong2; //覆蓋分?jǐn)?shù)的圖
43、片</p><p> int board[ROW + 2][COL + 2]; //游戲圖紙</p><p> MOUSEMSG mouse;</p><p> int counter=board_number*2;</p><p> void Init();//初始化界面
44、 </p><p> void load_picture ();//加載圖片</p><p> void del(BOARD &rec);//每個(gè)格子賦值為</p><p> void leftbottondown (MOUSEMSG
45、 mouse);//實(shí)現(xiàn)鼠標(biāo)左擊效果</p><p> void frame (int leftx,int lefty);//畫(huà)邊框</p><p> bool judge_mouse(int leftx,int lefty);//判斷鼠標(biāo)是否在游戲區(qū)</p><p> void select(int leftx
46、,int lefty);//顯示選中效果</p><p> void accurate(int& leftx,int& lefty);//使格子的坐標(biāo)都在邊緣</p><p> void cover(int x1,int y1,int x2,int y2,int x3,int y3,int x4,int y4);
47、 //覆蓋直線</p><p> void line(int x1,int y1,int x2,int y2,int x3,int y3,int x4,int y4) ; //用直線連接</p><p> void exchange(BOARD& pre,BOARD& cur);//交換格子信息</p&g
48、t;<p> bool click(int mousex,int mousey); //判斷單擊是否有效</p><p> void record(int leftx,int lefty,BOARD &rec);//記錄選中的格子</p><p> void mouse_to_board(int mousex,in
49、t mousey,int *idx,int *idy);//鼠標(biāo)的坐標(biāo)轉(zhuǎn)為格子的數(shù)組下標(biāo)</p><p> int findpath(BOARD &pre,BOARD &cur);//尋找路徑,判斷是否相等</p><p> void progressbar();//畫(huà)進(jìn)度條</p><p> void updateprogressbar
50、(long t);//更新進(jìn)度條</p><p> int findpath(BOARD &pre,BOARD &cur)</p><p><b> {</b></p><p> int i,j,path,min1,max1,min2,max2,left,right,top,bottom;</p><
51、p><b> int m,n;</b></p><p> if (board[pre.ty][pre.tx]!= board[cur.ty][cur.tx]) //判斷是否點(diǎn)中相同</p><p> return false;</p><p> min1=max1=pre.tx;</p><p> min
52、2=max2=cur.tx;</p><p> while (min1-1>=0 && board[pre.ty][min1-1]==0) min1--;//查找水平方向公共區(qū)域</p><p> while (min2-1>=0 && board[cur.ty][min2-1]==0) min2--;</p><p>
53、; left=max(min1,min2); // 左邊界</p><p> while (max1+1<=11 && board[pre.ty][max1+1]==0) max1++;</p><p> while (max2+1<=11 && board[cur.ty][max2+1]==0) max2++;</p>&
54、lt;p> right=min(max1,max2); // 右邊界</p><p> if (left==0)</p><p><b> { </b></p><p> line(pre.tx,pre.ty,0,pre.ty,0,cur.ty,cur.tx,cur.ty);//左邊緣連通</p><p>
55、 Sleep(300);</p><p> cover(pre.xx,pre.yy,board_X-48,pre.yy,board_X-48,cur.yy,cur.xx,cur.yy);//覆蓋線條</p><p> return true;</p><p><b> }</b></p><p> if (ri
56、ght==11)</p><p><b> {</b></p><p> line(pre.tx,pre.ty,11,pre.ty,11,cur.ty,cur.tx,cur.ty);</p><p> Sleep(300);</p><p> cover(pre.xx,pre.yy,board_X+480,pre
57、.yy,board_X+480,cur.yy,cur.xx,cur.yy);//覆蓋線條</p><p> return true;</p><p><b> }</b></p><p> for (i=left;i<=right;i++)</p><p><b> {</b><
58、/p><p> path=0;//記錄豎直方向上的長(zhǎng)度</p><p> m=min(pre.ty,cur.ty);</p><p> n=max(pre.ty,cur.ty);</p><p> for (j=m+1;j<n;j++)</p><p><b> {</b></p
59、><p> path=path+board[j][i];</p><p> if (path>0) break;</p><p><b> }</b></p><p> if (path==0)</p><p><b> {</b></p><
60、p> line(pre.tx,pre.ty,i,pre.ty,i,cur.ty,cur.tx,cur.ty);</p><p> Sleep(300);</p><p> cover(pre.xx,pre.yy,board_X+(i-1)*48,pre.yy,board_X+(i-1)*48,cur.yy,cur.xx,cur.yy);//覆蓋線條</p><
61、;p> return true;</p><p><b> }</b></p><p><b> }</b></p><p> min1=max1=pre.ty;//查找垂直方向公共區(qū)域</p><p> min2=max2=cur.ty;</p><p>
62、 while (min1-1>=0 && board[min1-1][pre.tx]==0) min1--;</p><p> while (min2-1>=0 && board[min2-1][cur.tx]==0) min2--;</p><p> top=max(min1,min2);</p><p> whi
63、le (max1+1<=7 && board[max1+1][pre.tx]==0) max1++;</p><p> while (max2+1<=7 && board[max2+1][cur.tx]==0) max2++;</p><p> bottom=min(max1,max2);</p><p> if (
64、top==0)</p><p><b> {</b></p><p> line(pre.tx,pre.ty,pre.tx,0,cur.tx,0,cur.tx,cur.ty);//同在頂端消除</p><p> Sleep(300);</p><p> cover(pre.xx,pre.yy,pre.xx,boa
65、rd_Y-54,cur.xx,board_Y-54,cur.xx,cur.yy);//覆蓋線條</p><p> return true;</p><p><b> }</b></p><p> if (bottom==7)</p><p><b> {</b></p><
66、;p> line(pre.tx,pre.ty,pre.tx,7,cur.tx,7,cur.tx,cur.ty);</p><p> Sleep(300);</p><p> cover(pre.xx,pre.yy,pre.xx,board_Y+324,cur.xx,board_Y+324,cur.xx,cur.yy);//覆蓋線條</p><p> r
67、eturn true;</p><p><b> }</b></p><p> for (j=top;j<=bottom;j++)</p><p><b> {</b></p><p> path=0;//記錄水平方向的長(zhǎng)度</p><p> m=min(pr
68、e.tx,cur.tx);</p><p> n=max(pre.tx,cur.tx);</p><p> for (i=m+1; i<n; i++)</p><p><b> {</b></p><p> path+=board[j][i];</p><p> if (path&
69、gt;0) break;</p><p><b> }</b></p><p> if (path==0)</p><p><b> {</b></p><p> line(pre.tx,pre.ty,pre.tx,j,cur.tx,j,cur.tx,cur.ty);</p>
70、<p> Sleep(300);</p><p> cover(pre.xx,pre.yy,pre.xx,board_Y+(j-1)*54,cur.xx,board_Y+(j-1)*54,cur.xx,cur.yy);//覆蓋線條</p><p> return true;</p><p><b> }</b></p&g
71、t;<p><b> }</b></p><p> return false;</p><p><b> }</b></p><p> void Init() //初始化</p><p><b> {</b></p><p>
72、 int ix,iy,jx,jy,idx,idy,temp;</p><p> srand((unsigned)time(NULL));</p><p> load_picture();</p><p> IMAGE beijing;</p><p> for(int i= 0, x = 1; x <= ROW; ++x )&l
73、t;/p><p><b> {</b></p><p> for( int y = 1; y <= COL; ++y )</p><p><b> {</b></p><p> board[x][y] = i++ % board_number + 1;</p><p&
74、gt;<b> }</b></p><p><b> }</b></p><p> loadimage(&beijing,"D:\\llk\\beijing.bmp");//載入背景圖</p><p> putimage(0,0,&beijing);//放置背景圖</p&g
75、t;<p> getimage(&tianchong,3 * 48,2 * 54,49,55);</p><p> getimage(&tianchong1,3 * 48,2 * 54,70,55);</p><p> getimage(&tianchong2,758,150,50,55);</p><p> for(
76、int k = 0; k <60; ++k )</p><p><b> {</b></p><p> ix = rand() % ROW + 1;</p><p> iy = rand() % COL + 1;</p><p> jx = rand() % ROW + 1; </p>
77、<p> jy = rand() % COL + 1;</p><p> if( board[ix][iy] != board[jx][jy]) //使數(shù)據(jù)打亂</p><p><b> {</b></p><p> temp= board[ix][iy];</p><p> board[ix][
78、iy] = board[jx][jy];</p><p> board[jx][jy] =temp;</p><p><b> }</b></p><p><b> }</b></p><p> for(int i = 0 ;i < ROW; i ++)</p><
79、p> for(int j = 0 ;j < COL ; j++)</p><p><b> {</b></p><p> idy = i * 54 + board_Y ,idx = j * 48+ board_X;</p><p> putimage(idx,idy,&image[board[i + 1][j + 1
80、]]);//根據(jù)賦的值放置每一個(gè)格子圖</p><p><b> }</b></p><p> setbkmode(TRANSPARENT);</p><p> setfont(35, 0,"華文琥珀");</p><p> setcolor(YELLOW);</p>&l
81、t;p> outtextxy(700, 100,"分?jǐn)?shù)");</p><p> outtextxy(700, 150,"000");</p><p><b> }</b></p><p> void load_picture()</p><p><
82、;b> {</b></p><p> IMAGE image1,background;</p><p> loadimage(&image1,"D:\\llk\\board.bmp");</p><p> SetWorkingImage(&image1);</p><p> f
83、or(int i = 1 ;i <=board_number;i ++)</p><p> getimage(&image[i],0,i * 54,48, 54);</p><p> loadimage(&background,"IMAGE","bg");</p><p> SetWorkingI
84、mage(&background);</p><p> getimage(&tianchong,3 * 56,2 * 60,56,60);</p><p> SetWorkingImage();</p><p> putimage(0,0,&background);</p><p><b> }<
85、;/b></p><p> void leftbottondown (MOUSEMSG mouse) //單擊左鍵</p><p><b> {</b></p><p> static int click1 = 0,x,y;</p><p> char s[3];</p><p>
86、 int number,i;</p><p><b> click1++;</b></p><p> select(mouse.x,mouse.y);//顯示選中效果</p><p> if(click1 == 1)</p><p><b> {</b></p>
87、<p> record(mouse.x,mouse.y,pre);</p><p><b> }</b></p><p> if(click1 == 2) </p><p><b> {</b></p><p> mouse_to_board(mouse.x,mouse.y,&
88、amp;x,&y);</p><p> if(x != pre.tx||y != pre.ty)</p><p><b> {</b></p><p> record(mouse.x,mouse.y,cur);</p><p> if(findpath(pre,cur))</p><p
89、><b> {</b></p><p> board[pre.ty][pre.tx] = board[cur.ty][cur.tx] =0;</p><p> putimage(pre.xx,pre.yy,&tianchong);</p><p> putimage(cur.xx,cur.yy,&tianchong
90、);</p><p> del(pre); </p><p> del(cur); </p><p> click1 = 0;</p><p> counter--;</p><p> putimage(700,150,&tianchong1);</p><p> num
91、ber=20*(board_number*2-counter);</p><p> for(i=2;i>=0;i--)</p><p><b> {</b></p><p> s[i] = number % 10 + '0';</p><p> number/= 10;</p>
92、<p><b> }</b></p><p> setbkmode(TRANSPARENT);</p><p> setfont(35, 0,"華文琥珀");</p><p> setcolor(YELLOW);</p><p> outtextxy(700, 150,s);&l
93、t;/p><p> putimage(758,150,&tianchong2);</p><p><b> }</b></p><p><b> else</b></p><p><b> {</b></p><p> exchange(d
94、ur,pre); </p><p> exchange(pre,cur); </p><p> del(cur);</p><p> click1 = 1;</p><p> putimage(dur.xx,dur.yy,&image[board[dur.ty][dur.tx]]);</p><p
95、><b> }</b></p><p><b> }</b></p><p> else click1= 1;</p><p><b> }</b></p><p><b> }</b></p><p>
96、void select (int leftx,int lefty)//選中時(shí)效果</p><p><b> {</b></p><p> if(judge_mouse(leftx,lefty))</p><p><b> {</b></p><p><b> int
97、 x,y;</b></p><p> mouse_to_board(leftx,lefty,&x,&y);</p><p> accurate(leftx,lefty);</p><p> frame(leftx,lefty);</p><p><b> }</b></p>
98、<p><b> }</b></p><p> bool judge_mouse(int leftx,int lefty) //判斷鼠標(biāo)是否在游戲區(qū)</p><p><b> {</b></p><p> return leftx >board_X &&a
99、mp; leftx < board_X + W * COL && </p><p> lefty >board_Y && lefty < board_Y+ H * ROW;</p><p><b> }</b></p><p> void mouse_to_board(int mouse
100、x,int mousey ,int *x,int *y) //鼠標(biāo)坐標(biāo)轉(zhuǎn)化為圖紙坐標(biāo)</p><p><b> {</b></p><p> if(judge_mouse(mousex,mousey))</p><p><b> {</b></p><p> *x = (mousex -b
101、oard_X) / 48 + 1;</p><p> *y = (mousey -board_Y) / 54 + 1 ;</p><p><b> }}</b></p><p> void record(int leftx,int lefty,BOARD &rec)//記錄選中的信息</p><p>
102、;<b> {</b></p><p> mouse_to_board(leftx,lefty,&rec.tx,&rec.ty);</p><p> rec.xx = (rec.tx - 1) * 48 +board_X;</p><p> rec.yy = (rec.ty - 1) * 54 +board_Y;<
103、/p><p> rec.data = board[rec.ty][rec.tx];</p><p><b> }</b></p><p> bool click(int mousex,int mousey)//判斷單擊是否有效</p><p><b> {</b></p>&
104、lt;p><b> int x,y;</b></p><p> mouse_to_board(mousex,mousey,&x,&y);//轉(zhuǎn)化為格子坐標(biāo)</p><p> if(judge_mouse(mouse.x,mouse.y) && board[y][x] != 0)</p><p>
105、 return true;</p><p> return false;</p><p><b> }</b></p><p> void frame(int leftx,int lefty)//畫(huà)方框</p><p><b> {</b></p><p>
106、 setcolor(RGB(126,91,68));</p><p> setlinestyle(PS_SOLID,3);</p><p> rectangle(leftx,lefty,leftx+47,lefty+53);</p><p> rectangle(leftx + 2,lefty + 2,leftx+47,lefty+53);</p>
107、;<p> setcolor(RGB(250,230,169));</p><p> rectangle(leftx + 1,lefty + 1,leftx+48,lefty+54);</p><p><b> }</b></p><p> void accurate(int& leftx,int& le
108、fty)</p><p><b> {</b></p><p> leftx = ((leftx -board_X) / 48) *48 +board_X;</p><p> lefty = ((lefty -board_Y) / 54) *54 +board_Y;</p><p><b> }&
109、lt;/b></p><p> void exchange(BOARD &pre,BOARD &cur)//交換格子信息</p><p><b> {</b></p><p> pre.data = cur.data;</p><p> pre.tx = cur.tx;pre.ty =
110、cur.ty;</p><p> pre.xx= cur.xx;pre.yy = cur.yy;</p><p><b> }</b></p><p> void del(BOARD &rec) //每個(gè)格子賦值為</p><p><b> {</b
111、></p><p> rec.data = 0;</p><p> rec.tx= 0; </p><p> rec.ty = 0;</p><p> rec.xx = 0;</p><p> rec.yy = 0;</p><p><b> }<
112、/b></p><p> void line(int x1,int y1,int x2,int y2,int x3,int y3,int x4,int y4)</p><p><b> {</b></p><p> setlinestyle(PS_SOLID,NULL,3);</p><p> setcol
113、or(RGB(252,228,20));</p><p> moveto(board_X+24+48*(x1-1),board_Y+27+54*(y1-1));</p><p> lineto(board_X+24+48*(x2-1),board_Y+27+54*(y2-1));</p><p> lineto(board_X+24+48*(x3-1),boa
114、rd_Y+27+54*(y3-1));</p><p> lineto(board_X+24+48*(x4-1),board_Y+27+54*(y4-1));</p><p><b> }</b></p><p> void cover(int x1,int y1,int x2,int y2,int x3,int y3,int x4,in
115、t y4) </p><p><b> { </b></p><p> int minx,miny,maxx,maxy;</p><p> if(x1 == x2)</p><p><b> {</b></p><p> maxy = y1 >
116、y2? y1:y2;</p><p> miny = y1 < y2? y1:y2;</p><p> for(int i = miny; i <= maxy;i += 54)</p><p> putimage(x1,i,&tianchong);</p><p><b> }</b>&l
117、t;/p><p> else if(y1 == y2)</p><p><b> {</b></p><p> maxx = x1 > x2? x1:x2;</p><p> minx = x1 < x2? x1:x2;</p><p> for(int j = minx; j
118、<= maxx;j += 48)</p><p> putimage(j,y1,&tianchong);</p><p><b> }</b></p><p> if(x2 == x3)</p><p><b> {</b></p><p> max
119、y = y2 > y3? y2:y3;</p><p> miny = y2 < y3? y2:y3;</p><p> for(int i = miny; i <= maxy;i += 54)</p><p> putimage(x2,i,&tianchong);</p><p><b> }
120、</b></p><p> else if(y2 == y3)</p><p><b> {</b></p><p> maxx = x2 > x3? x2:x3;</p><p> minx = x2 < x3? x2:x3;</p><p> for(int
121、j = minx; j <= maxx;j += 48)</p><p> putimage(j,y2,&tianchong);</p><p><b> }</b></p><p> if(x3 == x4)</p><p><b> {</b></p>&l
122、t;p> maxy = y3 > y4? y3:y4;</p><p> miny = y3 < y4? y3:y4;</p><p> for(int i = miny; i <= maxy;i += 54)</p><p> putimage(x3,i,&tianchong);</p><p>&l
123、t;b> }</b></p><p> else if(y3 == y4)</p><p><b> {</b></p><p> maxx = x3 > x4? x3:x4;</p><p> minx = x3 < x4? x3:x4;</p><p&g
124、t; for(int j = minx; j <= maxx;j += 48)</p><p> putimage(j,y3,&tianchong);</p><p><b> }</b></p><p><b> }</b></p><p> void progressb
125、ar()//進(jìn)度條的初始化</p><p><b> {</b></p><p> setcolor(YELLOW);</p><p> rectangle(150,50,530,75);</p><p> setcolor(YELLOW);</p><p> rectangle(153
126、,53,527,72);</p><p> setfillstyle(RED);</p><p> floodfill(151,51,YELLOW);</p><p> setfillstyle(RED);</p><p> floodfill(160,60,YELLOW);</p><p><b>
127、 }</b></p><p> void updateprogressbar(long t)//進(jìn)度條的更新</p><p><b> {</b></p><p> setcolor(WHITE);</p><p> rectangle(524-DGREE*t,54,526,71);</p&g
128、t;<p> setfillstyle(WHITE);</p><p> floodfill(525-DGREE*t,60,WHITE);</p><p><b> }</b></p><p> void main()</p><p><b> {</b></p>
129、;<p> long t_base,t_run,t;</p><p> IMAGE bye,fail;</p><p> initgraph(M,N);</p><p><b> Init();</b></p><p> loadimage(&bye,"d:\\llk\\end.
130、bmp");//成功時(shí)的圖</p><p> loadimage(&fail,"d:\\llk\\fail.bmp");//失敗時(shí)的圖</p><p> PlaySound("d:\\llk\\sound.wav", NULL, SND_FILENAME | SND_ASYNC);//背景音樂(lè)</p><p&
131、gt; progressbar();</p><p> t_base= time(NULL);</p><p><b> while(1)</b></p><p><b> {</b></p><p> t_run=time(NULL);</p><p> t=
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 連連看課程設(shè)計(jì)報(bào)告
- java連連看課程設(shè)計(jì)報(bào)告
- labview連連看課程設(shè)計(jì)報(bào)告
- java連連看課程設(shè)計(jì)報(bào)告
- 連連看課程設(shè)計(jì)
- 連連看課程設(shè)計(jì)
- java連連看課程設(shè)計(jì)
- java連連看課程設(shè)計(jì)
- java課程設(shè)計(jì)—連連看
- 課程設(shè)計(jì)報(bào)告----java實(shí)現(xiàn)游戲連連看
- jav課程設(shè)計(jì)報(bào)告書(shū)——連連看
- java課程設(shè)計(jì)--連連看游戲設(shè)計(jì)
- android課程設(shè)計(jì)連連看小游戲
- java課程設(shè)計(jì)--連連看游戲的開(kāi)發(fā)
- java課程設(shè)計(jì)說(shuō)明書(shū)---連連看
- 連連看游戲開(kāi)題報(bào)告
- 連連看
- 連連看.docx
- 連連看項(xiàng)目
- 基于c#的成語(yǔ)連詞連連看-開(kāi)題報(bào)告
評(píng)論
0/150
提交評(píng)論