C/C++编程笔记:C语言打造中国象棋游戏,项目源代码分享!
中国象棋是起源于中国的一种棋,属于二人对抗性游戏的一种,在中国有着悠久的历史。由于用具简单,趣味性强,成为流行极为广泛的棋艺活动。
它是中国棋文化,也是中华民族的文化瑰宝,它源远流长,趣味浓厚,基本规则简明易懂。中国象棋在中国的群众中基础远远超过围棋,是普及最广的棋类项目,中国象棋已流传到十几个国家和地区。它使用方形格状棋盘,圆形棋子共有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语言打造中国象棋游戏,项目源代码分享!的更多相关文章
- C#中国象棋+游戏大厅 服务器 + 客户端源码
来源:www.ajerp.com/bbs C#中国象棋+游戏大厅 服务器 + 客户端源码 源码开源 C#版中国象棋(附游戏大厅) 基于前人大虾的修改版 主要用委托实现 服务器支持在线人数,大厅桌数的设 ...
- 基于HTML5实现的中国象棋游戏
棋类游戏在桌面游戏中已经非常成熟,中国象棋的版本也非常多.今天这款基于HTML5技术的中国象棋游戏非常有特色,我们不仅可以选择中国象棋的游戏难度,而且可以切换棋盘的样式.程序写累了,喝上一杯咖啡,和电 ...
- 中国象棋游戏Chess(3) - 实现走棋规则
棋盘的绘制和走棋参看博文:中国象棋游戏Chess(1) - 棋盘绘制以及棋子的绘制,中国象棋游戏Chess(2) - 走棋 现在重新整理之前写的代码,并且对于每个棋子的走棋规则都进行了限制,不像之前那 ...
- 中国象棋游戏Chess(2) - 走棋
之前的文章请看:中国象棋游戏Chess(1) - 棋盘绘制以及棋子的绘制 现在实现走棋的功能. 首先需要获取点击到的棋子,用QWidget中的函数 mouseReleaseEvent 实现函数: vo ...
- GMchess Linux下的中国象棋游戏
gmchess,一款Linux下的中国象棋程序
- 【原创】使用HTML5+canvas+JavaScript开发的原生中国象棋游戏及源码分享
目前已经实现的功能: V1.0 : 实现棋子的布局,画布及游戏场景的初始化V2.0 : 实现棋子的颜色改变V3.0 :实现所有象棋的走棋规则V4.0 : 实现所有棋子的吃子功能 GItHub源码下载地 ...
- 用C语言实现中国象棋
基于五子棋框架上的 象棋 小游戏 本游戏是上各种水课无聊时的产物...不参考现有游戏从零开始实现各项功能. 游戏配置:二维数组,循环系统,wasd基本移动,调整窗台的函数,以及富足的发呆时间.. 完整 ...
- 编程之美 ---> 1.2中国象棋将帅问题
上图,将帅不能碰面,列出将帅不碰面的所有可能情况,要求:程序只能用一个只有8位的变量(#define这样的就不算了) 为了更加符合程序员的口味,给将帅位置编号如下: 0--1--2 | | ...
- cocos2dx 3.2 的中国象棋游戏
改编来源:http://cn.cocos2d-x.org/tutorial/lists?id=103 在cocos2dx官网看到了这么个教程,是cocos2dx 2.x版本的,于是用 cocos2dx ...
随机推荐
- 包含min函数的栈(剑指offer-20)
题目描述 定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数(时间复杂度应为O(1)). 注意:保证测试中不会当栈为空的时候,对栈调用pop()或者min()或者top()方法 ...
- cookie与token
cookie: 登陆后后端生成一个sessionid放在cookie中返回给客户端,并且服务端一直记录着这个sessionid,客户端以后每次请求都会带上这个sessionid, 服务端通过这个ses ...
- order by 注入姿势
order by 注入原理 其实orde by 注入也是sql注入的一种,原理都一样就是mysql语法的区别,order by是用来排序的语法. sql-lab讲解 判断方法 1.通过做运算来判断如: ...
- windows下的包管理器scoop
scoop(传送门) 安装 scoop是一个类似于linux下apt之类包管理器 安装scoop(Powershell 3+ and .NET Framework 4.5+) iex (new-ob ...
- 数据可视化之PowerQuery篇(十三)Power BI总计行错误,这个技巧一定要掌握
https://zhuanlan.zhihu.com/p/102567707 前一段介绍过一个客户购买频次统计的案例: Power BI 数据分析应用:客户购买频次分布. 我并没有在文章中显示总计行 ...
- 爬虫黑科技,我是怎么爬取indeed的职位数据的
最近在学习nodejs爬虫技术,学了request模块,所以想着写一个自己的爬虫项目,研究了半天,最后选定indeed作为目标网站,通过爬取indeed的职位数据,然后开发一个自己的职位搜索引擎,目前 ...
- 聊聊Mysql主从同步读写分离配置实现
Hi,各位热爱技术的小伙伴您们好,好久没有写点东西了,今天写点关于mysql主从同步配置的操作日志同大家一起分享.最近自己在全新搭建一个mysql主从同步读写分离数据库简单集群,我讲实际操作步骤整理分 ...
- 为Dark模拟做出的一些微小的贡献
这几周经过liners大佬的指导,发现自己的代码实现能力确实太过于垃圾,所以根据他的指示,我应该去多多练习一下Dark模拟,但是最近刚刚入手Dark模拟的我感到非常的吃力,所以本人今天写博客一篇来讲述 ...
- SQL : 把特定的数据排前面 & 分别查询几组数据的最大值
把特定的数据排前面 : 比如说,把没有审核身份证的人排最前面,然后再按userId正序排. select case when idcardverified = 1 then 0 else 1 end ...
- 【Floyd算法+贪心】 travel 计蒜客 - 45275
题目: 有 n 个景点,从一个景点 i 旅行到另一个景点 j 要花费 Ai,j=Aj,i(n≤100),现在给出由 m(≤1e5) 个景点的组成序列 A,求:在所有 "有子序列 A 的序列中 ...