C/C++編程筆記:C語言實現連連看游戲,小白練手項目(源碼分享)

来源:https://www.cnblogs.com/yxy6/archive/2020/06/26/13195491.html
-Advertisement-
Play Games

本篇文章分享看題目就知道是寫給初學者的,學的比較好的小伙伴也可以將自動演算法等一些知識給加進去,希望對大家有幫助! 好了,當我們所有的準備工作做好之後,我們就可以來編寫我們的C語言連連看游戲了! 其實這個游戲設計起來真的是很簡單的一種,本例用到的知識點主要有:數組,結構體,分支結構,圖形庫函數。 游戲 ...


本篇文章分享看題目就知道是寫給初學者的,學的比較好的小伙伴也可以將自動演算法等一些知識給加進去,希望對大家有幫助!

好了,當我們所有的準備工作做好之後,我們就可以來編寫我們的C語言連連看游戲了!

其實這個游戲設計起來真的是很簡單的一種,本例用到的知識點主要有:數組,結構體,分支結構,圖形庫函數。

游戲效果展示


  連連看游戲的效果圖大致就是這樣(之所以沒用本例的,是因為沒用圖形開發還是有點不好看,嘿嘿~)

編寫準備:編譯軟體(VS2013),連連看圖片素材,easyX圖形庫插件,有需要可以關註筆者微信公眾號:C語言編程學習基地,領取相關圖片素材可以回覆關鍵字【連連看】即可。

那麼接下來就給大家展示我們本期的連連看游戲C語言代碼,自己寫之前,請一定要獲取到相關的必備資料哦!不然你就無法根據代碼示例寫出來了!

源代碼示例

/*
    課程內容:練練看,很簡單
    開發環境:vs2013+easyx圖形庫
    知識點:
    數組,結構體,分支結構,圖形庫函數
*/
#include<stdio.h>
#include<graphics.h>
#define IMG_SIZE 39 //隔一個動物圖片的寬度
#define MAX_ANIMAL_NUM 42 //總共的動物數量
#define MAP_SIZE 10  //每行動物的數量
#define WIN_SIZE (MAP_SIZE*IMG_SIZE+2*IMG_SIZE)

//定義變數 int  a;
IMAGE img_total[2];
IMAGE img_animal[MAX_ANIMAL_NUM][2];
//地圖
int map[MAP_SIZE+2][MAP_SIZE+2];
//存儲兩次點擊的數組的下標
POINT begin = { -1, -1 }, end = { -1, -1 };
enum STATE
{
    BEGIN,
    END,
};
int flag = BEGIN;
//游戲初始化
void GameInit()
{
    //創建一個圖形視窗,貼圖片
    initgraph(WIN_SIZE, WIN_SIZE,SHOWCONSOLE);
    //設置隨機數種子
    srand(GetTickCount());
    //載入圖片,如果現實沒有重載的函數,就是字元集的問題
    loadimage(&img_total[0], "./res/animal.bmp");
    loadimage(&img_total[1], "./res/bk.jpg", WIN_SIZE, WIN_SIZE);
    //把整個圖片進行分割,保存到新的數組
    SetWorkingImage(&img_total[0]);
    for (int i = 0; i < MAX_ANIMAL_NUM; i++)
    {
        for (int k = 0; k < 2; k++)
        {
            getimage(&img_animal[i][k], k*IMG_SIZE, i*IMG_SIZE, IMG_SIZE, IMG_SIZE);
        }
    }
    SetWorkingImage();
    //11111  222 3333
    //每張圖片來10張
    int temp = 1,_count=1;
    for (int i = 1; i <= MAP_SIZE; i++)
    {
        for (int k = 1; k <= MAP_SIZE; k++)
        {
            map[i][k] = temp;
            if (_count % 10 == 0)
            {
                temp++;
            }
            _count++;

        }
    }
    //打亂圖片,實際上就是打亂數組數據
    for (int i = 1; i <= MAP_SIZE; i++)
    {
        for (int k = 1; k <= MAP_SIZE; k++)
        {
            int temp=map[i][k];
            int row = rand() % 10 + 1;
            int col = rand() % 10 + 1;
            map[i][k] = map[row][col];
            map[row][col] = temp;
        }
    }
}
//游戲的繪製
void GameDraw()
{
    putimage(0, 0, &img_total[1]);
    for (int i = 1; i <= MAP_SIZE; i++)
    {
        for (int k = 1; k <= MAP_SIZE; k++)
        {
            if (map[i][k]>0)
            {
                //用透明貼圖,使圖片背景透明
                putimage(k*IMG_SIZE, i*IMG_SIZE, &img_animal[map[i][k]][1],SRCAND);
                putimage(k*IMG_SIZE, i*IMG_SIZE, &img_animal[map[i][k]][0],SRCPAINT);
            }
        }
    }
    
}
//滑鼠控制消除,獲取滑鼠消息
void GameMouse()
{
    //檢測是否有滑鼠操作
    if (MouseHit())
    {
        MOUSEMSG msg = GetMouseMsg();
        if (msg.uMsg == WM_LBUTTONDOWN )
        {
            if (flag==BEGIN)
            {
                begin.x = msg.y / IMG_SIZE;
                begin.y = msg.x / IMG_SIZE;
                flag = END;
            }
            else if (flag == END)
            {
                end.x = msg.y / IMG_SIZE;
                end.y = msg.x / IMG_SIZE;
                flag = BEGIN;
            }
            printf("begin(%d,%d),end(%d,%d)\n", begin.x, begin.y, end.x, end.y);
        }
    }
}
void show()
{
    for (int i = 0; i <= MAP_SIZE+2; i++)
    {
        for (int k = 0; k <= MAP_SIZE+2; k++)
        {
            printf("%2d ",map[i][k]);

        }
        printf("\n");
    }

}
//判斷某一點是否有圖片,沒有為0
int isBlocked(int x,int y)
{
    return map[x][y];
}
//水平方向是否能夠消除
bool horizon(POINT begin, POINT end)
{
    //不能點擊同一個
    if (begin.x == end.x &&begin.y == end.y)
    {
        return false;
    }
    //檢測是否在同一水平方向
    if (begin.x != end.x)
    {
        return false;
    }
    //求出大小
    int m_min = min(begin.y, end.y);
    int m_max = max(begin.y, end.y);
    for (int i = m_min + 1; i < m_max; i++)
    {
        if (isBlocked(begin.x, i))
        {
            return false;
        }
    }
    return true;
}
//垂直方向是否能夠消除
bool vertical(POINT begin, POINT end)
{
    //不能點擊同一個
    if (begin.x == end.x &&begin.y == end.y)
    {
        return false;
    }
    //檢測是否在同一垂直方向
    if (begin.y != end.y)
    {
        return false;
    }
    //求出大小
    int m_min = min(begin.x, end.x);
    int m_max = max(begin.x, end.x);
    for (int i = m_min + 1; i < m_max; i++)
    {
        if (isBlocked(i,begin.y))
        {
            return false;
        }
    }
    return true;
}
//一個拐點
bool turn_ocne(POINT begin, POINT end)
{
    //不能點擊同一個
    if (begin.x == end.x &&begin.y == end.y)
    {
        return false;
    }
    //保存兩個拐點信息
    POINT temp1 = { begin.x, end.y }, temp2 = { end.x, begin.y };
    if (!isBlocked(begin.x, end.y))
    {
        if (horizon(begin, temp1) && vertical(end, temp1))
        {
            return true;
        }

    }
    if (!isBlocked(end.x, begin.y))
    {
        if (horizon(end, temp2) && vertical(temp2, begin))
        {
            return true;
        }

    }
    return false;
}
int main()
{
    GameInit();
    show();
    BeginBatchDraw();
    while (1)
    {
        GameDraw();
        FlushBatchDraw();
        GameMouse();
        //消除操作,消除就是讓數組的值等於0
        if (map[begin.x][begin.y] == map[end.x][end.y])
        {
            if (horizon(begin, end))
            {
                map[begin.x][begin.y] = 0;
                map[end.x][end.y] = 0;
            }
            else if (vertical(begin, end))
            {
                map[begin.x][begin.y] = 0;
                map[end.x][end.y] = 0;
            }
            else if (turn_ocne(begin, end))
            {
                map[begin.x][begin.y] = 0;
                map[end.x][end.y] = 0;
            }

        }
    }
    return 0;
}

以上就是分享給大家的全部的C語言代碼,希望能夠對大家有幫助~

自學C/C++編程難度很大,不妨和一些志同道合的小伙伴一起學習成長!

C語言C++編程學習交流圈子,【點擊進入】微信公眾號:C語言編程學習基地

有一些源碼和資料分享,歡迎轉行也學習編程的伙伴,和大家一起交流成長會比自己琢磨更快哦!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 交換排序之冒泡排序(java) 博客說明 文章所涉及的資料來自互聯網整理和個人總結,意在於個人學習和經驗彙總,如有什麼地方侵權,請聯繫本人刪除,謝謝! 說明 冒泡排序(Bubble Sorting)的基本思想是:通過對待排序序列從前向後(從下標較小的元素開始),依次比較相鄰元素的值,若發現逆序則交換 ...
  • 頂層類(Top-Level Class),是 Java 中對類的一種定義方式。在 .java 文件中,處於最外層的類就稱為頂層類,在其外部不存在將其包圍起來的任何代碼塊。頂層類只能聲明為 public 或包私有的。在 .java 文件中,只能有一個與其文件名同名的、聲明為 public 的頂層類。 ...
  • 演算法的時間複雜度和空間複雜度 博客說明 文章所涉及的資料來自互聯網整理和個人總結,意在於個人學習和經驗彙總,如有什麼地方侵權,請聯繫本人刪除,謝謝! 演算法的時間複雜度 時間頻度 一個演算法花費的時間與演算法中語句的執行次數成正比例,哪個演算法中語句執行次數多,它花費時間就多。一個演算法中的語句執行次數稱為語 ...
  • 所有操作需要在root用戶下本機測試案例系統信息:ubuntu安裝路徑:/usr/local/php8 解壓縮: wget https://downloads.php.net/~pollita/php-8.0.0alpha1.tar.gz tar -zxvf php-8.0.0alpha1.tar. ...
  • 最近看一些國外程式員的文章,瞭解一下國外的程式員都在研究什麼、使用什麼工具、如何工作、如何掙錢……發現收穫頗豐,瞭解到了不少特有的思維方式及有創意的技術平臺。 本篇是關於如何通過編碼掙錢的文章,作者提供了十種通過編碼掙錢的途徑。在翻譯的同時,也會附帶一些個人的看法。下麵是正文: 知道如何編寫代碼是一 ...
  • 又看到一篇關於方法論的文章,觀點還是不錯的。翻譯出來,分享給大家。如果有一項啟發了你,那恭喜你。以下為正文內容: 就像沒有兩片相同的雪花一樣,程式員也各有不同。每一片雪花都是由不同原子以獨特的結構構成。同樣,對於程式員來說無論學習的途徑如何相似,在開發技能和能力上都會有所不同。 即使具有不同天資水平 ...
  • Session--驗證碼案例(Java) 博客說明 文章所涉及的資料來自互聯網整理和個人總結,意在於個人學習和經驗彙總,如有什麼地方侵權,請聯繫本人刪除,謝謝! 案例 用戶輸入用戶名,密碼以及驗證碼。 如果用戶名和密碼輸入有誤,跳轉登錄頁面,提示:用戶名或密碼錯誤 如果驗證碼輸入有誤,跳轉登錄頁面, ...
  • 一、整體說明 tomcat需要完成兩件事情: 接受外部HTTP請求 載入servlet,並且把請求傳給Servlet進行處理。 整體可以抽象為如下: 二、整體代碼架構 在tomcat的代碼中抽象了以下三個類: Server類,代表tomcat實例 Connector類,代表HTTP監聽器(上圖中的H ...
一周排行
    -Advertisement-
    Play Games
  • C#TMS系統代碼-基礎頁面BaseCity學習 本人純新手,剛進公司跟領導報道,我說我是java全棧,他問我會不會C#,我說大學學過,他說這個TMS系統就給你來管了。外包已經把代碼給我了,這幾天先把增刪改查的代碼背一下,說不定後面就要趕鴨子上架了 Service頁面 //using => impo ...
  • 委托與事件 委托 委托的定義 委托是C#中的一種類型,用於存儲對方法的引用。它允許將方法作為參數傳遞給其他方法,實現回調、事件處理和動態調用等功能。通俗來講,就是委托包含方法的記憶體地址,方法匹配與委托相同的簽名,因此通過使用正確的參數類型來調用方法。 委托的特性 引用方法:委托允許存儲對方法的引用, ...
  • 前言 這幾天閑來沒事看看ABP vNext的文檔和源碼,關於關於依賴註入(屬性註入)這塊兒產生了興趣。 我們都知道。Volo.ABP 依賴註入容器使用了第三方組件Autofac實現的。有三種註入方式,構造函數註入和方法註入和屬性註入。 ABP的屬性註入原則參考如下: 這時候我就開始疑惑了,因為我知道 ...
  • C#TMS系統代碼-業務頁面ShippingNotice學習 學一個業務頁面,ok,領導開完會就被裁掉了,很突然啊,他收拾東西的時候我還以為他要旅游提前請假了,還在尋思為什麼回家連自己買的幾箱飲料都要叫跑腿帶走,怕被偷嗎?還好我在他開會之前拿了兩瓶芬達 感覺感覺前面的BaseCity差不太多,這邊的 ...
  • 概述:在C#中,通過`Expression`類、`AndAlso`和`OrElse`方法可組合兩個`Expression<Func<T, bool>>`,實現多條件動態查詢。通過創建表達式樹,可輕鬆構建複雜的查詢條件。 在C#中,可以使用AndAlso和OrElse方法組合兩個Expression< ...
  • 閑來無聊在我的Biwen.QuickApi中實現一下極簡的事件匯流排,其實代碼還是蠻簡單的,對於初學者可能有些幫助 就貼出來,有什麼不足的地方也歡迎板磚交流~ 首先定義一個事件約定的空介面 public interface IEvent{} 然後定義事件訂閱者介面 public interface I ...
  • 1. 案例 成某三甲醫預約系統, 該項目在2024年初進行上線測試,在正常運行了兩天後,業務系統報錯:The connection pool has been exhausted, either raise MaxPoolSize (currently 800) or Timeout (curren ...
  • 背景 我們有些工具在 Web 版中已經有了很好的實踐,而在 WPF 中重新開發也是一種費時費力的操作,那麼直接集成則是最省事省力的方法了。 思路解釋 為什麼要使用 WPF?莫問為什麼,老 C# 開發的堅持,另外因為 Windows 上已經裝了 Webview2/edge 整體打包比 electron ...
  • EDP是一套集組織架構,許可權框架【功能許可權,操作許可權,數據訪問許可權,WebApi許可權】,自動化日誌,動態Interface,WebApi管理等基礎功能於一體的,基於.net的企業應用開發框架。通過友好的編碼方式實現數據行、列許可權的管控。 ...
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...