游戲中消除的對象為各種各樣的頭像,包括樹、小車、草莓和酒瓶等一些頭像。玩家通關移動這些頭像位置湊夠一定數量的相同圖標即可消除。
本程序的操作與 Popcap 經典的寶石迷陣(Bejeweled)游戲類似。
當然你自己也可以進一步去完善這個游戲(例如設置關卡,不同圖像的不同分數,障礙物等等)
游戲中使用了大量圖片、音樂、資源文件【https://codebus.cn/f/a/0/0/153/duiduipeng.zip】
本項目編譯環境:Visual Studio 2019/2022,EasyX插件
代碼展示:
#include#include #include #include #include #include #pragma comment(lib, "Winmm.lib") using namespace std; /*******************************定義枚舉類型*****************************/ enum color{blank, red, yellow, blue, green, white, orange, purple, shizijia, zhadan, qicai, alarm}; /*******************************定義全局變量*****************************/ const int MaxT = 12; // 時間上限 const int T = 10 * MaxT;// 時間速度 const int V = 300; // 停留時間 clock_t start, now; // 控制時間 color gem[9][8]; // 地圖 // IMAGE對象 IMAGE img[12], music_img[2], exit_img, jindutiao; int Score, Time; // 成績 時間 bool Flag, Music = true;// 是否加載 音樂 /**********************************函數聲明*****************************/ void load(void); // 加載IMAGE對象 void Blank(void); // 清空 bool soso(void); // 搜索空格 bool baidu(void); // 搜索解法 void New(void); // 更新 void print(void); // 輸出 bool judge(void); // 判斷是否可以消除 void fall(void); // 下落 void draw(void); // 消除 bool quit(void); // 是否重新開始 void play(void); // 游戲過程 /**********************************定義函數*****************************/ void load(void) { char c[20]; int i; // 加載IMAGE對象 for (i = 0; i < 12; i++) { ostrstream strout(c, 50); strout <<"圖片\" <>Flag >>Music; if (Flag) { HWND wnd = GetHWnd(); SetWindowText(wnd, "對對碰"); if (MessageBox(wnd, "是否繼續上次游戲?", "游戲開始", MB_YESNO | MB_ICONQUESTION) == IDYES) { fin >>Score >>Time; for (i = 0; i < 9; i++) for (int j = 0; j < 8; j++) { int t; fin >>t; gem[i][j] = color(t); } } else Flag = false; } fin.close(); } void Blank(void) { for (int i = 1; i < 9; i++) for (int j = 0; j < 8; j++) gem[i][j] = blank; print(); fall(); } bool soso(void) { for (int i = 1; i < 9; i++) for (int j = 0; j < 8; j++) if (gem[i][j] == blank) return true; return false; } bool baidu(void) { int i, j; color t; bool flag = false; // 如果有一個道具則返回真 for (i = 1; i < 9; i++) for (j = 0; j < 8; j++) if (gem[i][j] >= shizijia) return true; // 搜索解法 for (i = 1; i < 9; i++) for (j = 0; j < 7; j++) { t = gem[i][j]; gem[i][j] = gem[i][j + 1]; gem[i][j + 1] = t; if (judge()) flag = true; t = gem[i][j]; gem[i][j] = gem[i][j + 1]; gem[i][j + 1] = t; if (flag) return true; } for (i = 1; i < 7; i++) for (j = 0; j < 8; j++) { t = gem[i][j]; gem[i][j] = gem[i + 1][j]; gem[i + 1][j] = t; if (judge()) flag = true; t = gem[i][j]; gem[i][j] = gem[i + 1][j]; gem[i + 1][j] = t; if (flag) return true; } return false; } void New(void) { static int old_score = -1, old_time = T; bool flag = false; if (Score != old_score) // 更新分數 { if (Score > 999999999) { if (MessageBox(GetHWnd(), "恭喜你達到了最高分! 是否重新開始?", "游戲結束", MB_YESNO | MB_ICONQUESTION) == IDYES) Score = 0; else exit(0); } char s[15]; ostrstream strout(s, 15); strout <<'$' < old_time) putimage(540, 140, &jindutiao); setcolor(BLACK); for (int i = 0; i < T - Time; i++) { line(540, 140 + 2 * i, 580, 140 + 2 * i); line(540, 140 + 2 * i + 1, 580, 140 + 2 * i + 1); } old_time = Time; flag = true; } if (flag) // 寫存檔 { ofstream fout("存檔.dat"); fout < = 1; i--) if (gem[i][j] == blank) { a[j] = i; sign = true; break; } if (sign == false) return; IMAGE im[8]; for (j = 0; j < 8; j++) if (a[j] > 1) getimage(&im[j], 60 * j, 0, 60, 60 * (a[j] - 1)); for (i = 0; i < 60 ; i += 2) for (j = 0; j < 8; j++) if (a[j] > 0) { if (a[j] > 1) putimage(60 * j, i + 2, &im[j]); putimage(60 * j, i + 2 - 60, &img[int(gem[0][j])]); Sleep(1); } for (j = 0; j < 8; j++) if (a[j] > 0) { for (i = a[j]; i > 0; i--) gem[i][j] = gem[i - 1][j]; if (rand() % 50 == 0) gem[0][j] = color(rand() % 4 + 8); else gem[0][j] = color(rand() % 7 + 1); } } // 加對大括號使遞歸時撤銷內存空間 if (soso()) fall(); if (judge()) draw(); } void draw(void) { { int i, j; bool a[9][8] = {false}; for (i = 1; i < 9; i++) for (j = 0; j < 6; j++) if (gem[i][j] == gem[i][j + 1] && gem[i][j] == gem[i][j + 2]) a[i][j] = a[i][j + 1] = a[i][j + 2] = true; for (i = 1; i < 7; i++) for (j = 0; j < 8; j++) if (gem[i][j] == gem[i + 1][j] && gem[i][j] == gem[i + 2][j]) a[i][j] = a[i + 1][j] = a[i + 2][j] = true; for (i = 1; i < 9; i++) for (j = 0; j < 8; j++) if (a[i][j]) { gem[i][j] = blank; Score += 10; } Sleep(V); Time += T / MaxT; if (Time > T) Time = T; print(); } // 加對大括號使遞歸時撤銷內存空間 fall(); } bool quit(void) { char str[50]; ostrstream strout(str, 50); strout <<"得分:" < T) Time = T; print(); Sleep(V); fall(); if (!baidu()) Blank(); break; case zhadan: if (x > 1) { gem[x - 1][y] = blank; Score += 10; if (y > 0) { gem[x - 1][y - 1] =blank; Score += 10; } } if (y > 0) { gem[x][y - 1] = blank; if (x < 8) { gem[x + 1][y - 1] =blank; Score += 10; } } if (x < 8) { gem[x + 1][y] = blank; if (y < 7) { gem[x + 1][y + 1] =blank; Score += 10; } } if (y < 7) { gem[x][y + 1] = blank; if (x > 1) { gem[x - 1][y + 1] =blank; Score += 10; } } gem[x][y] = blank; Time += T / MaxT; if (Time > T) Time = T; print(); Sleep(V); fall(); if (!baidu()) Blank(); break; case qicai: t = color(rand() % 7 + 1); putimage(60 * y, 60 * (x - 1), &img[int(t)]); Sleep(V); for (i = 1; i < 9; i++) for (j = 0; j < 8; j++) if (gem[i][j] == t) { gem[i][j] = blank; putimage(60 * j, 60 * (i - 1), &img[0]); Score += 10; } gem[x][y] = blank; Time += T / MaxT; if (Time > T) Time = T; print(); fall(); if (!baidu()) Blank(); break; case alarm: Time = T; gem[x][y] = blank; print(); fall(); if (!baidu()) Blank(); break; } break; } else if (x1 > 480 && x1 < 560 && y1 > 400 && y1 < 480) { if (Music) mciSendString("stop mymusic", NULL, 0, NULL); else mciSendString("play mymusic from 0 repeat", NULL, 0, NULL); Music = !Music; putimage(480, 400, &music_img[int(Music)]); } else if (x1 > 560 && x1 < 640 && y1 > 400 && y1 < 480) exit(0); } } now = clock(); if (now - start >= CLOCKS_PER_SEC * MaxT / T) { start = now; Time--; New(); if (Time <= 0) return; } } while (m.mkLButton && m.y < 480) { m = GetMouseMsg(); x = m.x; y = m.y; if (x - x1 > 30 || x1 - x > 30 || y - y1 > 30 || y1 - y > 30) { sign = false; break; } now = clock(); if (now - start >= CLOCKS_PER_SEC * MaxT / T) { start = now; Time--; New(); if (Time <= 0) return; } } if(sign) { putimage(x1 - x1 % 60, y1 - y1 % 60, &img[int(gem[y1 / 60 + 1][x1 / 60])], SRCPAINT); continue; } if (y1 - y > 30 && y1 / 60 > 0) fx = 'u'; if (y - y1 > 30 && y1 / 60 < 7) fx = 'd'; if (x1 - x > 30 && x1 / 60 > 0) fx = 'l'; if (x - x1 > 30 && x1 / 60 < 7) fx = 'r'; x = y1 / 60 + 1; y = x1 / 60; x1 = y1 = 0; switch (fx) { case 'u':x1 = -1; break; case 'd':x1 = 1; break; case 'l':y1 = -1; break; case 'r':y1 = 1; break; case '?':continue; } for (i = 0; i < 60;) { putimage(60 * y, 60 * (x - 1), &img[0]); putimage(60 * y, 60 * (x - 1), &img[0]); i += 1; putimage(60 * (y + y1) - i * y1, 60 * (x - 1 + x1) - i * x1, &img[int(gem[x + x1][y + y1])]); putimage(60 * y + i * y1, 60 * (x - 1) + i * x1, &img[int(gem[x][y])]); Sleep(2); } t = gem[x][y]; gem[x][y] = gem[x + x1][y + y1]; gem[x + x1][y + y1] = t; if (judge()) { draw(); if (!baidu()) Blank(); } else { for (i = 0; i < 60;) { putimage(60 * y, 60 * (x - 1), &img[0]); putimage(60 * y, 60 * (x - 1), &img[0]); i += 1; putimage(60 * (y + y1) - i * y1, 60 * (x - 1 + x1) - i * x1, &img[int(gem[x + x1][y + y1])]); putimage(60 * y + i * y1, 60 * (x - 1) + i * x1, &img[int(gem[x][y])]); Sleep(2); } t = gem[x][y]; gem[x][y] = gem[x + x1][y + y1]; gem[x + x1][y + y1] = t; } now = clock(); if (now - start >= CLOCKS_PER_SEC * MaxT / T) { start = now; Time--; New(); if (Time <= 0) return; } }while (true); } /***********************************主函數******************************/ int APIENTRY WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nCmdShow) { try { // 加載素材 load(); } catch (int) { ofstream fout("存檔.dat"); fout <
大家趕緊去動手試試吧!
審核編輯:湯梓紅
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。
舉報投訴
-
游戲
+關注
關注
2文章
736瀏覽量
26283 -
C語言
+關注
關注
180文章
7598瀏覽量
136194 -
編程
+關注
關注
88文章
3592瀏覽量
93596 -
源碼
+關注
關注
8文章
633瀏覽量
29140
原文標題:C語言零基礎項目:對對碰(消除類)游戲!詳細思路+源碼分享
文章出處:【微信號:cyuyanxuexi,微信公眾號:C語言編程學習基地】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
C語言十字消除游戲!詳細思路+源碼分享
十字消除,休閑小游戲,在規定時間內,只要是十字線能連接到的相同顏色的方塊,就能獲得相應的得分,如果點擊后沒有能夠消除的方塊會扣除時間,是一款益智小游戲。
發表于 11-28 10:45
?1046次閱讀
C語言零基礎項目:涂格子(點燈)游戲!詳細思路+源碼分享
點燈游戲是一個十分有趣的智力游戲:有一行N行N列的燈,開始時全部是滅的,當你點擊其中一盞燈時他的上下左右(若存在的話)狀態全部改變,現在要求你在限定的時間內以最少地步數,將全部的燈點亮。
發表于 12-16 09:47
?832次閱讀
七夕緣分對對碰,蓋樓尋找對的TA
`七夕緣分對對碰,蓋樓尋找對的TA!!!一年一度的七夕再一次到來了,雖然不及上半年的雙節合璧那么浪漫熱烈,但這個專屬于中國人的傳統情人節,卻多了份不同的意義,傳說中牛郎織女每年只有這一次才能
發表于 08-01 18:06
C語言零基礎項目:俄羅斯方塊游戲!詳細思路+源碼分享
由小方塊組成的不同形狀的板塊陸續從屏幕上方落下來,玩家通過調整板塊的位置和方向,使它們在屏幕底部拼出完整的一條或幾條。這些完整的橫條會隨即消失,給新落下來的板塊騰出空間,與此同時,玩家得到分數獎勵。沒有被消除掉的方塊不斷堆積起來,一旦堆到屏幕頂端,玩家便告輸,游戲結束。
C語言項目:礦井逃生游戲(密室)!詳細思路+源碼分享
密室逃脫相信大部分都玩過了吧?本游戲就是一種用C語言寫的類似的游戲,因為用手電筒照明找路,所以有點像礦工的樣子,還是叫它礦井逃生吧!(以下是游戲
評論