中国象棋是起源于中国的一种棋,属于二人对抗性游戏的一种,在中国有着悠久的历史。由于用具简单,趣味性强,成为流行极为广泛的棋艺活动。

它是中国棋文化,也是中华民族的文化瑰宝,它源远流长,趣味浓厚,基本规则简明易懂。中国象棋在中国的群众中基础远远超过围棋,是普及最广的棋类项目,中国象棋已流传到十几个国家和地区。它使用方形格状棋盘,圆形棋子共有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 = { -, - }, end = { -, - };//保存前后两次点击的数组下标
int state = BEGIN;
//初始化游戏数据
void GameInit()
{
for (int i = ; i < ROW; i++)
{
for (int k = ; k < COL; k++)
{
int chessname = SPACE;
int mcolor = BLACK;
//黑棋
if (i <= )
{
mcolor = BLACK;
//初始化第一行的棋子,
if (i == )
{
if (k <= )
{
chessname = blackChess[k];
}
else
{
chessname = blackChess[-k];
}
}
//设置炮
if (i == && (k == || k == ))
{
chessname = blackChess[砲];
}
//设置小兵
if (i == && k % == )
{
chessname = blackChess[卒];
} }
//紅棋
else
{
mcolor = RED;
//初始化第一行的棋子,
if (i == )
{
if (k <= )
{
chessname = redChess[k];
}
else
{
chessname = redChess[ - k];
}
}
//设置炮
if (i == && (k == || k == ))
{
chessname = redChess[炮];
}
//设置小兵
if (i == && k % == )
{
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(, , ));
cleardevice(); //绘制棋盘
setlinecolor(BLACK);
setlinestyle(PS_SOLID, );
for (int i = ; i < ; i++)
{
//画横线
line(INTERVAL, i*CHESS_GRID_SIZE + INTERVAL, * CHESS_GRID_SIZE + INTERVAL, i*CHESS_GRID_SIZE + INTERVAL);
//画竖线
if (i < )
{
line(i*CHESS_GRID_SIZE + INTERVAL, INTERVAL, i*CHESS_GRID_SIZE + INTERVAL, * CHESS_GRID_SIZE + INTERVAL);
}
}
rectangle(INTERVAL - , INTERVAL - , * CHESS_GRID_SIZE + INTERVAL+, + * CHESS_GRID_SIZE + INTERVAL);
//楚河汉界显示
setfillcolor(RGB(, , ));
fillrectangle(INTERVAL, * CHESS_GRID_SIZE + INTERVAL, * CHESS_GRID_SIZE + INTERVAL, * CHESS_GRID_SIZE + INTERVAL);
//显示文字
char river[] = "楚河 汉界";
settextstyle(, , "楷体");
settextcolor(BLACK);
setbkmode(TRANSPARENT);
outtextxy(INTERVAL+, * CHESS_GRID_SIZE + INTERVAL+, river);
//画九宫格
//画上面
line( * CHESS_GRID_SIZE + INTERVAL, INTERVAL, * CHESS_GRID_SIZE + INTERVAL, * CHESS_GRID_SIZE + INTERVAL);
line( * CHESS_GRID_SIZE + INTERVAL, * CHESS_GRID_SIZE + INTERVAL, * CHESS_GRID_SIZE + INTERVAL, INTERVAL);
//画下面
line( * CHESS_GRID_SIZE + INTERVAL, * CHESS_GRID_SIZE + INTERVAL, * CHESS_GRID_SIZE + INTERVAL, * CHESS_GRID_SIZE + INTERVAL);
line( * CHESS_GRID_SIZE + INTERVAL, * CHESS_GRID_SIZE+INTERVAL,*CHESS_GRID_SIZE+INTERVAL,*CHESS_GRID_SIZE+INTERVAL);
//画棋子
settextstyle(, , "楷体");
for (int i = ; i < ROW; i++)
{
for (int k = ; k < COL; k++)
{
if (map[i][k].id != SPACE)
{
setlinecolor(map[i][k].type);
fillcircle(map[i][k].x, map[i][k].y, );
fillcircle(map[i][k].x, map[i][k].y, );
settextcolor(map[i][k].type);
outtextxy(map[i][k].x-, map[i][k].y-, 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 != - && end.x != - && !(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(,,SHOWCONSOLE);
GameInit();
printf("欢迎来到顽石老师课堂,中国象棋");
BeginBatchDraw();
while ()
{
GameDraw();
FlushBatchDraw();
MouseControl();
chessMove();
}
return ;
}

以上就是分享的全部内容,希望对大家有所帮助!

自学C/C++编程难度很大,不妨和一些志同道合的小伙伴一起学习成长!

C语言C++编程学习交流圈子,【点击进入】微信公众号:C语言编程学习基地

有一些源码和资料分享,欢迎转行也学习编程的伙伴,和大家一起交流成长会比自

 

C/C++编程笔记:C语言打造中国象棋游戏,项目源代码分享!的更多相关文章

  1. C#中国象棋+游戏大厅 服务器 + 客户端源码

    来源:www.ajerp.com/bbs C#中国象棋+游戏大厅 服务器 + 客户端源码 源码开源 C#版中国象棋(附游戏大厅) 基于前人大虾的修改版 主要用委托实现 服务器支持在线人数,大厅桌数的设 ...

  2. 基于HTML5实现的中国象棋游戏

    棋类游戏在桌面游戏中已经非常成熟,中国象棋的版本也非常多.今天这款基于HTML5技术的中国象棋游戏非常有特色,我们不仅可以选择中国象棋的游戏难度,而且可以切换棋盘的样式.程序写累了,喝上一杯咖啡,和电 ...

  3. 中国象棋游戏Chess(3) - 实现走棋规则

    棋盘的绘制和走棋参看博文:中国象棋游戏Chess(1) - 棋盘绘制以及棋子的绘制,中国象棋游戏Chess(2) - 走棋 现在重新整理之前写的代码,并且对于每个棋子的走棋规则都进行了限制,不像之前那 ...

  4. 中国象棋游戏Chess(2) - 走棋

    之前的文章请看:中国象棋游戏Chess(1) - 棋盘绘制以及棋子的绘制 现在实现走棋的功能. 首先需要获取点击到的棋子,用QWidget中的函数 mouseReleaseEvent 实现函数: vo ...

  5. GMchess Linux下的中国象棋游戏

    gmchess,一款Linux下的中国象棋程序

  6. 【原创】使用HTML5+canvas+JavaScript开发的原生中国象棋游戏及源码分享

    目前已经实现的功能: V1.0 : 实现棋子的布局,画布及游戏场景的初始化V2.0 : 实现棋子的颜色改变V3.0 :实现所有象棋的走棋规则V4.0 : 实现所有棋子的吃子功能 GItHub源码下载地 ...

  7. 用C语言实现中国象棋

    基于五子棋框架上的 象棋 小游戏 本游戏是上各种水课无聊时的产物...不参考现有游戏从零开始实现各项功能. 游戏配置:二维数组,循环系统,wasd基本移动,调整窗台的函数,以及富足的发呆时间.. 完整 ...

  8. 编程之美 ---> 1.2中国象棋将帅问题

    上图,将帅不能碰面,列出将帅不碰面的所有可能情况,要求:程序只能用一个只有8位的变量(#define这样的就不算了) 为了更加符合程序员的口味,给将帅位置编号如下: 0--1--2 |    |   ...

  9. cocos2dx 3.2 的中国象棋游戏

    改编来源:http://cn.cocos2d-x.org/tutorial/lists?id=103 在cocos2dx官网看到了这么个教程,是cocos2dx 2.x版本的,于是用 cocos2dx ...

随机推荐

  1. 每日一题 - 剑指 Offer 36. 二叉搜索树与双向链表

    题目信息 时间: 2019-06-29 题目链接:Leetcode tag: 二叉搜索树 中序遍历 递归 深度优先搜索 难易程度:中等 题目描述: 输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的循 ...

  2. js 字符串转方法,this域绑定

    闲着没事,开发一个列表页面配置的功能,其中涉及到了按钮点击事件,在页面进行编辑,保存到数据库中.写好的js脚本,function是字符串格式,所以要让生成的脚本生效,还要做一些操作. 1.首先保存在数 ...

  3. Xor_Sum 题解

    题目 You are given a positive integer \(N(1≦N≦10^{18})\). Find the number of the pairs of integers \(u ...

  4. LoadLibraryA与GetProcAddress介绍

    0x00 函数原型 HMODULE LoadLibraryA(     LPCTSTR lpLibFileName//模块的的的名字 ) FARPROC GetProcAddress( HMODULE ...

  5. When Lambo with Howdoo

    原文链接:https://howdoo.io/when-lambo/ 为了庆祝即将推出的革命性新社交媒体平台Howdoo以及我们令人惊喜的合作伙伴关系和社区,我们正在发起一项竞赛,以最终回答“When ...

  6. React当中的路由使用

    React 当中的路由 使用React构建的单页面应用,要想实现页面间的跳转,首先想到的就是使用路由.在React中,常用的有两个包可以实现这个需求,那就是react-router和react-rou ...

  7. CSS(五)- 背景与边框 - 边框圆角与阴影基础用法

    扩展阅读 本文仅仅做border的基础使用,想要深入了解的话可以戳以下几个链接,觉得作者写的很好. CSS Backgrounds and Borders Module Level 3 CSS魔法堂: ...

  8. java 面向对象(七):类结构 方法(四)递归方法

    1.定义:递归方法:一个方法体内调用它自身.2.如何理解递归方法?> 方法递归包含了一种隐式的循环,它会重复执行某段代码,但这种重复执行无须循环控制.> 递归一定要向已知方向递归,否则这种 ...

  9. 矩阵的基本性质 之 对称矩阵,Hermite矩阵,正交矩阵,酉矩阵

    1.对称矩阵 2.Hermite矩阵 3.正交矩阵 4.酉矩阵

  10. ES6的功能简介

    1. let, const, var let: 块级作用域, 不存在变量提升, 值可更改 const:块级作用域, 不能存在变量提升, 值不可更改 var: 函数级作用域, 变量提升, 值可更改 案例 ...