C/C++編程筆記:C語言打造中國象棋游戲,項目源代碼分享!

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

中國象棋是起源於中國的一種棋,屬於二人對抗性游戲的一種,在中國有著悠久的歷史。由於用具簡單,趣味性強,成為流行極為廣泛的棋藝活動。 它是中國棋文化,也是中華民族的文化瑰寶,它源遠流長,趣味濃厚,基本規則簡明易懂。中國象棋在中國的群眾中基礎遠遠超過圍棋,是普及最廣的棋類項目,中國象棋已流傳到十幾個國家 ...


中國象棋是起源於中國的一種棋,屬於二人對抗性游戲的一種,在中國有著悠久的歷史。由於用具簡單,趣味性強,成為流行極為廣泛的棋藝活動。

它是中國棋文化,也是中華民族的文化瑰寶,它源遠流長,趣味濃厚,基本規則簡明易懂。中國象棋在中國的群眾中基礎遠遠超過圍棋,是普及最廣的棋類項目,中國象棋已流傳到十幾個國家和地區。它使用方形格狀棋盤,圓形棋子共有32個,紅黑二色各有16個棋子,擺放和活動在交叉點上。雙方交替行棋,先把對方的將(帥)“將死”的一方獲勝。(摘取自百度百科)


假的效果圖

那麼我們今天,將用C語言來實現我們中國象棋游戲程式的開發,覺得對你有幫助的小伙伴記得先關註一波哦!

實現思路

我們可以用繪圖技術繪製棋盤,枚舉定義各種棋子,然後結構體數組,用來保存每一個點的信息。

重點是棋盤的繪製以及判斷棋子是否可移動到目標位置,移動有兩種可能,一是單純移動,二是吃子移動。主要飛將的特殊規則。廢話不多說,貼源碼!

源碼分享

#include<stdio.h>
#include<graphics.h>
#define INTERVAL 50  //前面的間隔
#define CHESS_GRID_SIZE 70  //格子寬度
#define ROW  10
#define COL  9
enum PIECES//枚舉棋子
{
    車,馬,象,士,將,砲,卒,
    俥,馬,相,仕,帥,炮,兵,
    SPACE,BEGIN,END
};
//紅黑方棋子、
int redChess[] = { 車, 馬, 象, 士, 將, 砲, 卒};
int blackChess[] = { 俥, 馬, 相, 仕, 帥, 炮, 兵 };
const char*chessName[] = { "", "", "", "", "", "", "", "", "", "", "", "", "", "" };
struct Chess//棋子屬性
{
    int x;
    int y;
    int id;//哪個棋子
    int type;//是哪一方的棋子 紅,黑?
    bool river;//判斷小兵是否過了河
};
struct Chess  map[ROW][COL];//結構體數組,用來保存每一個點的信息
POINT begin = { -1, -1 }, end = { -1, -1 };//保存前後兩次點擊的數組下標
int state = BEGIN;
//初始化游戲數據
void GameInit()
{
    for (int i = 0; i < ROW; i++)
    {
        for (int k = 0; k < COL; k++)
        {
            int chessname = SPACE;
            int mcolor = BLACK;
            //黑棋
            if (i <= 4)
            {
                mcolor = BLACK;
                //初始化第一行的棋子,
                if (i == 0)
                {
                    if (k <= 4)
                    {
                        chessname = blackChess[k];
                    }
                    else
                    {
                        chessname = blackChess[8-k];
                    }
                }
                //設置炮
                if (i == 2 && (k == 1 || k == 7))
                {
                    chessname = blackChess[砲];
                }
                //設置小兵
                if (i == 3 && k % 2 == 0)
                {
                    chessname = blackChess[卒];
                }

            }
            //紅棋
            else 
            {
                mcolor = RED;
                //初始化第一行的棋子,
                if (i == 9)
                {
                    if (k <= 4)
                    {
                        chessname = redChess[k];
                    }
                    else
                    {
                        chessname = redChess[8 - k];
                    }
                }
                //設置炮
                if (i == 7 && (k == 1 || k == 7))
                {
                    chessname = redChess[炮];
                }
                //設置小兵
                if (i == 6 && k % 2 == 0)
                {
                    chessname = redChess[兵];
                }
            }
            map[i][k].id = chessname;
            map[i][k].river = false;
            map[i][k].type = mcolor;
            map[i][k].x = k*CHESS_GRID_SIZE + INTERVAL;
            map[i][k].y = i*CHESS_GRID_SIZE + INTERVAL;
        }
    }
}
//游戲的繪製函數
void GameDraw()
{
    //設置背景顏色 red black 
    setbkcolor(RGB(252, 215, 162));
    cleardevice();

    //繪製棋盤
    setlinecolor(BLACK);
    setlinestyle(PS_SOLID, 2);
    for (int i = 0; i < 10; i++)
    {
        //畫橫線
        line(INTERVAL, i*CHESS_GRID_SIZE + INTERVAL, 8 * CHESS_GRID_SIZE + INTERVAL, i*CHESS_GRID_SIZE + INTERVAL);
        //畫豎線
        if (i < 9)
        {
            line(i*CHESS_GRID_SIZE + INTERVAL, INTERVAL, i*CHESS_GRID_SIZE + INTERVAL, 9 * CHESS_GRID_SIZE + INTERVAL);
        }
    }
    rectangle(INTERVAL - 5, INTERVAL - 5, 8 * CHESS_GRID_SIZE + INTERVAL+5, 5+9 * CHESS_GRID_SIZE + INTERVAL);
    //楚河漢界顯示
    setfillcolor(RGB(252, 215, 162));
    fillrectangle(INTERVAL, 4 * CHESS_GRID_SIZE + INTERVAL, 8 * CHESS_GRID_SIZE + INTERVAL, 5 * CHESS_GRID_SIZE + INTERVAL);
    //顯示文字
    char river[20] = "楚河        漢界";
    settextstyle(50, 0, "楷體");
    settextcolor(BLACK);
    setbkmode(TRANSPARENT);
    outtextxy(INTERVAL+100, 4 * CHESS_GRID_SIZE + INTERVAL+10, river);
    //畫九宮格
        //畫上面
    line(3 * CHESS_GRID_SIZE + INTERVAL, INTERVAL, 5 * CHESS_GRID_SIZE + INTERVAL, 2 * CHESS_GRID_SIZE + INTERVAL);
    line(3 * CHESS_GRID_SIZE + INTERVAL, 2 * CHESS_GRID_SIZE + INTERVAL, 5 * CHESS_GRID_SIZE + INTERVAL, INTERVAL);
       //畫下麵
    line(3 * CHESS_GRID_SIZE + INTERVAL, 7 * CHESS_GRID_SIZE + INTERVAL, 5 * CHESS_GRID_SIZE + INTERVAL, 9 * CHESS_GRID_SIZE + INTERVAL);
    line(3 * CHESS_GRID_SIZE + INTERVAL, 9 * CHESS_GRID_SIZE+INTERVAL,5*CHESS_GRID_SIZE+INTERVAL,7*CHESS_GRID_SIZE+INTERVAL);
    //畫棋子
    settextstyle(30, 0, "楷體");
    for (int i = 0; i < ROW; i++)
    {
        for (int k = 0; k < COL; k++)
        {
            if (map[i][k].id != SPACE)
            {
                setlinecolor(map[i][k].type);
                fillcircle(map[i][k].x, map[i][k].y, 30);
                fillcircle(map[i][k].x, map[i][k].y, 25);
                settextcolor(map[i][k].type);
                outtextxy(map[i][k].x-10, map[i][k].y-10, chessName[map[i][k].id]);
            }
            
        }
    }
}
void MouseControl()
{
    if (MouseHit())
    {
        MOUSEMSG msg = GetMouseMsg();
        if (msg.uMsg == WM_LBUTTONDOWN)
        {
            //獲取滑鼠點擊的數組的下標
            int row = (msg.y-INTERVAL)/CHESS_GRID_SIZE;
            int col = (msg.x-INTERVAL)/CHESS_GRID_SIZE;
            if (state == BEGIN)
            {
                state = END;
                begin.x = row;
                begin.y = col;
            }
            else if (state == END)
            {
                state = BEGIN;
                begin.x = row;
                begin.y = col;
            }
            printf("%d,%d  %d\n", row, col, state);
        }
    }
}
void chessMove()
{
    if (begin.x != -1 && end.x != -1 && !(begin.x == end.x &&begin.y == end.y))
    {
        map[end.x][end.y].id = map[begin.x][begin.y].id;
        map[end.x][end.y].type = map[begin.x][begin.y].type;
        map[end.x][end.y].river = map[begin.x][begin.y].river;
        map[begin.x][begin.y].id = SPACE;
    }

}
int main555()
{    
    //創建一個圖形視窗
    initgraph(800,800,SHOWCONSOLE);
    GameInit();
    printf("歡迎來到頑石老師課堂,中國象棋");
    BeginBatchDraw();
    while (1)
    {
        GameDraw();
        FlushBatchDraw();
        MouseControl();
        chessMove();
    }
    return 0;
}

以上就是分享的全部內容,希望對大家有所幫助!

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

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

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

 


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

-Advertisement-
Play Games
更多相關文章
  • 1.模型管理 :web線上流程設計器、預覽流程xml、導出xml、部署流程 2.流程管理 :導入導出流程資源文件、查看流程圖、根據流程實例反射出流程模型、激活掛起 、自由跳轉 3.運行中流程:查看流程信息、當前任務節點、當前流程圖、作廢暫停流程、指派待辦人 4.歷史的流程:查看流程信息、流程用時、流 ...
  • 一、sentinel的持久化配置 上一章中我們通過Dashboard來為Sentinel客戶端設置各種各樣的規則,但是這些規則預設是存放在記憶體中,極不穩定,無法用於生成環境,所以需要將其持久化。 DataSource 擴展常見的實現方式有: 拉模式:客戶端主動向某個規則管理中心定期輪詢拉取規則,這個 ...
  • 老孟導讀:動畫系統是任何一個UI框架的核心功能,也是開發者學習一個UI框架的重中之重,同時也是比較難掌握的一部分,下麵我們就一層一層的揭開 Flutter 動畫的面紗。 任何程式的動畫原理都是一樣的,即:視覺暫留,視覺暫留又叫視覺暫停,人眼在觀察景物時,光信號傳入大腦神經,需經過一段短暫的時間,光的 ...
  • 1 前言 前面《Springboot整合MongoDB的Docker開發,其它應用也類似》講解瞭如何做Docker開發、如何把Springboot應用打包成一個鏡像,但它是手動的,本文將講解如何通過maven一鍵打包部署。 2 兩個maven插件搞定 可以使用maven插件實現一鍵部署,這兩個插件還 ...
  • 項目描述 Hi,大家好,今天分享的項目是《學生選課系統》,本系統有三種角色,分別為管理員、老師、學生。每種角色可以登錄系統,操作的功能也不一樣。總體功能模塊如下: 個人信息管理 學生信息管理 課程排名 學生成績分析 課表顯示 學生選課 成績查詢 技術棧 Servlet+JSP+JDBC 運行環境 M ...
  • 編寫一個程式,讀人10 個數並且顯示互不相同的數(即一個數出現多次,但僅顯示一次)。(提示,讀人一個數,如果它是一個新數,則將它存儲在數組中。如果該數已經在數組中,則忽略它。)輸入之後,數組包含的都是不同的數。下麵是這個程式的運行示例: Write a program that reads in t ...
  • 一、python解釋器安裝 參考視頻 : https://www.bilibili.com/video/BV1Xz4y1Q7bZ ps: 註意設置環境變數(文件是操作系統的概念,操作系統優先在當前文件夾找,找不到就到環境變數path找) python解釋器不相容 解釋器下載官網:python.org ...
  • thinkphp&laravel&swoft 三個框架的目錄設計: 首先來看下三者根目錄下,有哪些目錄: 一眼望去,根目錄下的文件數量,laravel7(10) > thinkphp6(8)= swoft2(8),直觀上看,三者的複雜程度似乎成正比。 功能的多樣性似乎也成正比。 如果我們將目錄結構理 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 在我們開發過程中基本上不可或缺的用到一些敏感機密數據,比如SQL伺服器的連接串或者是OAuth2的Secret等,這些敏感數據在代碼中是不太安全的,我們不應該在源代碼中存儲密碼和其他的敏感數據,一種推薦的方式是通過Asp.Net Core的機密管理器。 機密管理器 在 ASP.NET Core ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 順序棧的介面程式 目錄順序棧的介面程式頭文件創建順序棧入棧出棧利用棧將10進位轉16進位數驗證 頭文件 #include <stdio.h> #include <stdbool.h> #include <stdlib.h> 創建順序棧 // 指的是順序棧中的元素的數據類型,用戶可以根據需要進行修改 ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • C總結與剖析:關鍵字篇 -- <<C語言深度解剖>> 目錄C總結與剖析:關鍵字篇 -- <<C語言深度解剖>>程式的本質:二進位文件變數1.變數:記憶體上的某個位置開闢的空間2.變數的初始化3.為什麼要有變數4.局部變數與全局變數5.變數的大小由類型決定6.任何一個變數,記憶體賦值都是從低地址開始往高地 ...
  • 如果讓你來做一個有狀態流式應用的故障恢復,你會如何來做呢? 單機和多機會遇到什麼不同的問題? Flink Checkpoint 是做什麼用的?原理是什麼? ...
  • C++ 多級繼承 多級繼承是一種面向對象編程(OOP)特性,允許一個類從多個基類繼承屬性和方法。它使代碼更易於組織和維護,並促進代碼重用。 多級繼承的語法 在 C++ 中,使用 : 符號來指定繼承關係。多級繼承的語法如下: class DerivedClass : public BaseClass1 ...
  • 前言 什麼是SpringCloud? Spring Cloud 是一系列框架的有序集合,它利用 Spring Boot 的開發便利性簡化了分散式系統的開發,比如服務註冊、服務發現、網關、路由、鏈路追蹤等。Spring Cloud 並不是重覆造輪子,而是將市面上開發得比較好的模塊集成進去,進行封裝,從 ...
  • class_template 類模板和函數模板的定義和使用類似,我們已經進行了介紹。有時,有兩個或多個類,其功能是相同的,僅僅是數據類型不同。類模板用於實現類所需數據的類型參數化 template<class NameType, class AgeType> class Person { publi ...
  • 目錄system v IPC簡介共用記憶體需要用到的函數介面shmget函數--獲取對象IDshmat函數--獲得映射空間shmctl函數--釋放資源共用記憶體實現思路註意 system v IPC簡介 消息隊列、共用記憶體和信號量統稱為system v IPC(進程間通信機制),V是羅馬數字5,是UNI ...