基于c++ ege图形库实现五子棋游戏

本文分享的五子棋实例,制作基于ege图像库, 首先需要安装配置ege环境 就可以编写小游戏了. 用到的ege库函数不多 , 主要是基于c++的.

先看界面效果:

输入界面:(就是控制台)

游戏胜利界面:

文档如下:

关于五子棋的构思:

实现人人对战的五子棋游戏.使用面向对象的c++ 和 ege库实现.
ege的安装过程不在说明 , 在添加编译链接时去掉 -mwindows 选项.
dev c++ 的运行环境设置为 TDM-GCC 4.8.1.32-bit Debug
为保险起见,编译时选择菜单栏里的  运行-全部重新编译(F12)

需要3个对象 :

1:棋盘对象
2:黑方棋手对象
3:白方棋手对象

需要说明,对五子棋的实现来说,棋子的数据结构和游戏使用界面相互分离.对棋子的操作基于二维数组,棋盘和棋子的显示用单独的方法实现.

棋盘对象名: chessboard 

属性:

1:所有棋子-allchessman  二维数组,用来存放整个棋盘上棋子的分布和选手信息  
数组元素值为0 表示该位置无子   值为1表示该位置为白方落子  值为-1表示该位置为黑方落子
二维数组元素以结构体来表示 , 存X, Y坐标和身份标识.要注意的是 ,标识值为2标识是棋盘边界.不能落子

方法:

1:添加棋子 - bool  addchessman(int , int , int message)   //message指示落子黑白方身份识别
 2:画棋盘 - void  drawchessboard()
 3:判胜  - int bunko(int , int , int message)
 4:void  playchess()  运行代码的总程序

黑方对象:

属性:
 1: 棋子横向位置  int chessman_X 
 2: 棋子纵向位置  int chessman_Y
 3: 落子总个数    black_chessman_count
 4: 身份标识      int black_chessplayer
方法:
 1: 提交棋子  submit_chessman(int , int)

白方对象:

属性:
1:棋子横向位置  int chessman_X
2:棋子纵向位置  int chessman_Y
3:落子总个数    white_chessman_count
4:身份标识      int white_chessplayer
方法:
1: 提交棋子     submit_chessman(int ,int )

三个头文件对应三个对象:

黑棋选手:

#include<iostream>
using namespace std;

class black
{
 int chessman_X; //横向位置
 int chessman_Y; //纵向位置
 int black_chessman_count ; //落子总数
 int black_chessmanplayer ;

 public:

 black()
 {
 black_chessman_count=0;
 black_chessmanplayer=-1;
 }

 bool submit_chessman(int chessman_X , int chessman_Y )
 {
 if(chessman_X>15 || chessman_X<1 || chessman_Y>15 ||chessman_Y<1)
 {
 return false;
 }
 else
 {
 this->chessman_X = chessman_X;
 this->chessman_Y = chessman_Y;
 black_chessman_count++;
 return true;
 }
 } 

 int getIdentity()
 {
 return black_chessmanplayer;
 }
 int getChessman_X()
 {
 return chessman_X-1; //这里设置减一是因为画图从0位置开始
 }

 int getChessman_Y()
 {
 return chessman_Y-1;
 }

 int getChessmanCount()
 {
 return black_chessman_count ;
 }
};

白棋选手:

#include<iostream>
using namespace std;

class white
{
 int chessman_X; //横向位置
 int chessman_Y; //纵向位置
 int white_chessman_count; //落子总数
 int white_chessmanplayer;

 public:

 white()
 {
 white_chessman_count=0;
 white_chessmanplayer=1;
 }

 bool submit_chessman(int chessman_X , int chessman_Y )
 {
 if(chessman_X>15 || chessman_X<1 || chessman_Y>15 || chessman_Y<1)
 {
 return false;
 }
 else
  {
  this->chessman_X = chessman_X;
 this->chessman_Y = chessman_Y;
 white_chessman_count++;
 return true;
 }
 } 

 int getIdentity()
 {
 return white_chessmanplayer;
 }

 int getChessman_X()
 {
 return chessman_X-1;
 }

 int getChessman_Y()
 {
 return chessman_Y-1;
 }

 int getChessmanCount()
 {
 return white_chessman_count ;
 }
};

棋盘对象:

#include<iostream>
#include "graphics.h"
#include"black.h"
#include"white.h"
#include <process.h>
#define singleGirdSize 40
#define girdLength 15

using namespace std;
class chessboard
{
 //int allchessman[girdLength][girdLength] = {{0 ,0}};
 struct allchessman
 {
 int point_X; //记录棋子X轴位置
 int point_Y; //记录棋子Y轴位置
 int message; //识别棋子身份 (黑方? 白方 ? 空子? )
 }allchessman[girdLength][girdLength];

public : bool win =false; //玩家输赢的标记
 black b; //定义黑方对象
 white w; //定义白方对象
 //这里b , w 是全局的 ,局部的话会对black_chessman_count这种属性的变化有影响 

 public:

 //在构造方法中初始化所有棋子
 chessboard()
 {
 int x=100 , y=100; //棋盘左上端点100 ,100
 for(int i=0 ; i<15 ; i++ , y+=singleGirdSize)
 {
 for(int u=0; u<15 ; u++ , x+=singleGirdSize)
 {
  allchessman[i][u].point_X = x;
  allchessman[i][u].point_Y = y;
  if(allchessman[i][u].point_X == 100 || allchessman[i][u].point_X == 660 || allchessman[i][u].point_Y == 100 || allchessman[i][u].point_Y == 660)
  {
  allchessman[i][u].message =2; //棋盘边界标识记为2 , 不能落子
  }
  else
  {
  allchessman[i][u].message =0; //初始化为空子
  }
 }
 x=100; //让X重新回到端点位置
 }
 } 

 //添加棋子
 bool addchessman(int chessman_X , int chessman_Y , int message)
 {
 if(message == -1) //黑方落子
 {
 if(allchessman[chessman_X][chessman_Y].message== 0) //预落子位置无子
 {
 allchessman[chessman_X][chessman_Y].message = -1; //落子
 setfillcolor(RED);
 fillellipse(allchessman[chessman_X][chessman_Y].point_X , allchessman[chessman_X][chessman_Y].point_Y , 20 , 20); //界面上显示落子 .半径20
 if(is_run()) delay_fps(10);
 return true; //落子成功
 }
 else return false; //添加棋子失败 重复落子的处理
 }
 else
 {

 if (message == 1)
 {
 if(allchessman[chessman_X][chessman_Y].message == 0 )
 {
  allchessman[chessman_X][chessman_Y].message =1;
  setfillcolor(WHITE);
  fillellipse(allchessman[chessman_X][chessman_Y].point_X , allchessman[chessman_X][chessman_Y].point_Y , 20 , 20); //界面上显示落子 .半径20
  if(is_run()) delay_fps(10);
  return true; //落子成功
 }
 else return false;
 }
 else
 {
 return false; //应对意外情况 --message身份出错时
 }
 }
 } //addchessman

 void drawchessboard()
 {
 setinitmode(INIT_WITHLOGO, CW_USEDEFAULT, CW_USEDEFAULT);
 //画布大小暂定800 ,800
 initgraph(800 , 800);

 setfont(50 ,0 ,"宋体");
 outtextxy(250 , 0 , "简易五子棋");
 setfont(20 , 0 , "宋体");
 //画出棋盘
 //预定棋盘左上端点是100 ,100 像素点
 int startpoint_X =100 , startpoint_Y =100 ;
 char str[10];
 for(int i=0; i<15 ; i++)
 {
 sprintf(str , "%d" , i+1);
 outtextxy(startpoint_X-20 , startpoint_Y-7, str);
 line(startpoint_X , startpoint_Y , startpoint_X+( girdLength*singleGirdSize-singleGirdSize) , startpoint_Y); //线段画出屏幕会出错:什么也画不出来
 startpoint_Y+=singleGirdSize;
 } 

 startpoint_Y = 100; //重置起始点Y

 for(int i=0 ; i<15 ; i++)
 {
 sprintf(str , "%d" , i+1);
 outtextxy(startpoint_X-7, startpoint_Y-20 , str);
 line(startpoint_X , startpoint_Y , startpoint_X , startpoint_Y+(girdLength*singleGirdSize-singleGirdSize) );
 startpoint_X+=singleGirdSize;
 } 

 /*
 for(int i=0 ; i<15 ; i++)
 {
 for(int u=0 ; u<15 ; u++)
 {
 if(allchessman[i][u].message == 2) {}
 else
 {
  circle(allchessman[i][u].point_X , allchessman[i][u].point_Y , 20);
 }
 }
 }
 */ 

 }//drawchessboard 

 void playchess()
 {
 if(is_run()) delay_fps(10);
 int x ,y ; //接收落子的位置
 int identity=1; // 标识黑方 白方身份 identity取余不为0 则是黑方

 do
 {
 cout<<"       *************先输入竖列 再输入横列*************** "<<endl;
 black_entry(x ,y);
 if(is_run()) delay_fps(10);
 if(!win)
 {
  white_entry(x ,y);
 }
 system("cls");
 } while(!win);
 getch();
 }

 void black_entry(int &x , int &y)
 {
 //bool addchessman(int chessman_X , int chessman_Y , int message);
 cout<<"       请黑方落子(您的棋子颜色是红色):"<<endl;
 cout<<"       请输入横向位置:"<<endl;
 cout<<"       ";
 cin>>x;
 cout<<"       请输入纵向位置:"<<endl;
 cout<<"       ";
 cin>>y; 

 if( ! b.submit_chessman(x ,y) )
 {
 cout<<"      输入位置超出棋盘大小或不合法,请重新输入"<<endl;
 black_entry(x ,y);
 }

 if( !addchessman(b.getChessman_X(), b.getChessman_Y() , b.getIdentity()) )
 {
 cout<<"      落子失败! 该位置已有棋子或棋盘边界不能落子! 请重新输入~~~"<<endl;
 black_entry( x ,y);
 }
 else
 {
 if(bunko( b.getChessman_X(), b.getChessman_Y() , b.getIdentity()) )
 {
  setfont(50 , 0 ,"宋体");
  setfontbkcolor(GREEN);
  outtextxy(300 ,300 ,"黑方胜!");
  setfont(20 ,0 ,"宋体");
 outtextxy(300 ,750 ,"按任意键退出!");
  win = true;
 }
 }
 cout<<"       当前黑方落子总数:"<<b.getChessmanCount()<<endl;
 cout<<"       当前白方落子总数:"<<w.getChessmanCount()<<endl;
 }

 void white_entry(int &x , int &y)
 {
 // bool addchessman(int chessman_X , int chessman_Y , int message);
 cout<<endl<<endl<<endl;
 cout<<"       请白方落子(您的棋子颜色是白色):"<<endl;
 cout<<"       请输入横向位置:"<<endl;
 cout<<"       ";
 cin>>x;
 cout<<"       请输入纵向位置:"<<endl;
 cout<<"       ";
 cin>>y; 

 if( ! w.submit_chessman(x ,y) )
 {
 cout<<"      输入位置超出棋盘大小或不合法,请重新输入"<<endl;
 black_entry(x ,y);
 }

 if( !addchessman(w.getChessman_X() ,w.getChessman_Y() ,w.getIdentity()) )
 {
 cout<<"      落子失败! 该位置已有棋子或棋盘边界不能落子! 请重新输入~~~"<<endl;
 white_entry(x ,y);
 }
 else
 {
 if(bunko( w.getChessman_X(), w.getChessman_Y() , w.getIdentity()) )
 {
  setfont(50 , 0 ,"宋体");
  setfontbkcolor(LIGHTGRAY);
  outtextxy(300 ,300 ,"白方胜!");
  setfont(20 ,0 ,"宋体");
 outtextxy(300 ,720 ,"按任意键退出!");
  win = true;
 }
 }
 }

 bool bunko(int x, int y , int message) //判胜
 {
  int xReturnZero =x;
  int yReturnZero =y;
  int accumulative=0; //用来记录黑方或白方累计连在一起的 棋子个数 

  //先以该子位置为基点,向上(X轴不动 ,Y轴反方向) 逐一判断
  while(allchessman[--x][y].message == message)
  {
   accumulative++;
   //cout<<"累计的:"<<accumulative<<endl;
  }
  /*
  if(accumulative == 5)
  {
   accumulative=0; //重置计数为0
   return true;
  }
  else
  {
   return false;
  }
  */
  x = xReturnZero;
  y = yReturnZero;
  //先以该子位置为基点 , 向下( X轴不动 , Y轴正方向) 逐一判断
  while(allchessman[++x][y].message == message)
  {
   accumulative++;
   //cout<<"累计的:"<<accumulative<<endl;
  } 

  if(accumulative == 5)
  {
   accumulative=0; //重置计数为0
   return true;
  }
  else
  {
  // return false;
  }

  x = xReturnZero;
  y = yReturnZero;
  //先以该子位置为基点 , 向左(Y轴不动 , X轴反方向) 逐一判断
  while(allchessman[x][--y].message == message)
  {
   accumulative++;
   //cout<<"累计的:"<<accumulative<<endl;
  } 

  /*
  if(accumulative == 5)
  {
   accumulative=0; //重置计数为0
   return true;
  }
  else
  {
   return false;
  }
  */
  x = xReturnZero;
  y = yReturnZero;
  //先以该子位置为基点, 向右(Y轴不动 , X轴正方向) 逐一判断
  while(allchessman[x][++y].message == message)
  {
   accumulative++;
   //cout<<"累计的:"<<accumulative<<endl;
  } 

  if(accumulative == 5)
  {
   accumulative=0; //重置计数为0
   return true;
  }
  else
  {
  // return false;
  }

  x = xReturnZero;
  y = yReturnZero;
  //右下方
  while(allchessman[++x][++y].message == message)
  {
   accumulative++;
   //cout<<"累计的:"<<accumulative<<endl;
  }
  /*
  if(accumulative == 5)
  {
   accumulative=0; //重置计数为0
   return true;
  }
  else
  {
   return false;
  } */ 

  x = xReturnZero;
  y = yReturnZero;
  //左上方
  while(allchessman[--x][--y].message == message)
  {
   accumulative++;
   //cout<<"累计的:"<<accumulative<<endl;
  } 

  if(accumulative == 5)
  {
   accumulative=0; //重置计数为0
   return true;
  }
  else
  {
   //return false;
  } 

  x = xReturnZero;
  y = yReturnZero;
  //右上方
  while(allchessman[--x][++y].message == message)
  {
   accumulative++;
   //cout<<"累计的:"<<accumulative<<endl;
  }
  /*
  if(accumulative == 5)
  {
   accumulative=0; //重置计数为0
   return true;
  }
  else
  {
   return false;
  } */
  x = xReturnZero;
  y = yReturnZero;
  //左下方
  while(allchessman[++x][--y].message == message)
  {
   accumulative++;
   //cout<<"累计的:"<<accumulative<<endl;
  } 

  if(accumulative == 5)
  {
   accumulative=0; //重置计数为0
   return true;
  }
  else
  {
   return false;
  }
 } 

 //要在界面上显示黑方已下棋子个数
 //这个方法目前没有实现 , 实际运行有bug , 棋子数一直为初始值没有改变 , 所以没有用这个方法
 char* showBlackChessmanCount(black b)
 {
  char str[50];
  sprintf(str , "black role chessman count:%d" , b.getChessmanCount());
  return str;
 }

};

主函数运行:

#include<iostream>
#include"chessboard.h"
using namespace std;
int main()
{
 chessboard chman;
 chman.drawchessboard();
 chman.playchess();
}

用时两天,希望大家喜欢!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • C++语言设计实现五子棋

    本文为大家分享了C++五子棋的设计思路和设计实现,供大家参考,具体内容如下 算法思路: 在结束了对C++的学习之后,准备自己编制一些简单的练习程序.目前初步设想是编制一个人机对战的简易五子棋软件. 以下为个人设计思考的过程. 首先,进行问题分析与设计.计划实现的功能为,开局选择人机或双人对战,确定之后比赛开始.比赛结束后初始化棋盘,询问是否继续比赛或退出.后续可加入复盘.悔棋等功能.整个过程中,涉及到了棋子和棋盘两种对象,同时要加上人机对弈时的AI对象,即涉及到三个对象. 棋盘类的设计. 数据存

  • C++实现五子棋小程序

    这是一个用C++写的五子棋的小程序,关于A若是占据了已经下了的位置处理的不好.改动 hight,与width ,与q[][] 可以将棋盘扩大. #include<iostream> #include<vector> using namespace std; class qipan { public: qipan() {} ~qipan() {}; //向上下左右,斜的方向 char left(int x, int y) {//检查是否合适 if (x >= 1 &&a

  • 基于C++实现五子棋AI算法思想

    今天我想要分享一下我做五子棋AI的思路.因为在做这个之前,我没有接触过任何像这种类似的东西.通过这一次,我也算是有所了解,我的思路也是来自很多网络上的博客,看了很多,最终总结出了自己的这样一个. 那我的五子棋是15*15的大小(一般也就是这样的一个大小).我的AI算法要求每一次落子之后都要去计算每一个空暇的位置的"分值",简单的说,我们需要一个存放棋子的数组,表示是否存放了棋子,还要一个计算每一个空格的数组来记录"分数",这个分数是后期AI用来运算的基础,也是你AI

  • C++程序设计-五子棋

    前言:很多刚刚接触编程的人都不知道怎么下手编写程序,特别是学习了新的知识点,不知道有什么用,那么本文将以简单的存储结构及简单的运算,条件语句,分支语句,循环语句结合,带来一个双人对战版五子棋,这是一个简单的模型,实现了五子棋最最基本的功能,还有好多地方需要补全,如边界问题,设计问题,游戏逻辑问题,希望读者阅读后能够注意,通过自己的努力来完善它,还能扩展各种功能,如悔棋,网络对战等,有时候写程序和小生命一样,慢慢会成长,而我们作为"父母"的看到自己的小宝宝成为有用之才,过程之欣喜特别棒!

  • C++面向对象实现五子棋小游戏

    尽量将面向对象的思想融入进程序中 ChessBoard.h //ChessBoard.h #pragma once #define ROW 15 #define COL 15 #include<iostream> using namespace std; class ChessBoard//棋盘类 { public: char m_cSquare[ROW][COL]; public: ChessBoard(); void show(); }; ChessBoard.cpp //ChessBoa

  • C++简单五子棋的AI设计实现

    本文实例为大家分享了C++五子棋的AI设计实现代码,供大家参考,具体内容如下 设计思路:通过接口获取信息来确定颜色,通过set_chess函数来确定落点. 对每个点位给出两种颜色棋子的打分,分别存在两个15*15的数组里,数组下标代表点的位置. 确定最大值所在数组之后,遍历该数组找出所有最大值对应的位置,然后对这些位置统计另一种颜色的棋子的分数,再选取一次最大值,从而确定要落点的位置. 打分函数的设计:在四个方向分别统计然后相加.对于某一个方向的分数统计,则分为正反两个方向进行,统计的时候如果有

  • C++实现五子棋游戏

    三子棋.五子棋之类的游戏,非常简单,对于初学者来说是一个不错的练手的小项目,以前用C语言写过三子棋游戏.最近在看C++,所以就想到在三子棋的基础上利用C++语言实现五子棋游戏. 主要功能: 有3个模式:0表示退出.1表示电脑vs玩家.2表示玩家vs玩家. 当一局完成之后选择'y'则又会进入选择模式. 源代码(VS2013编译器下写的): #include<iostream> #include<stdio.h> #include<stdlib.h> #include &l

  • 基于c++ ege图形库实现五子棋游戏

    本文分享的五子棋实例,制作基于ege图像库, 首先需要安装配置ege环境 就可以编写小游戏了. 用到的ege库函数不多 , 主要是基于c++的. 先看界面效果: 输入界面:(就是控制台) 游戏胜利界面: 文档如下: 关于五子棋的构思: 实现人人对战的五子棋游戏.使用面向对象的c++ 和 ege库实现. ege的安装过程不在说明 , 在添加编译链接时去掉 -mwindows 选项. dev c++ 的运行环境设置为 TDM-GCC 4.8.1.32-bit Debug 为保险起见,编译时选择菜单栏

  • 基于C语言实现简单五子棋游戏

    本文实例为大家分享了C语言实现简单五子棋游戏的具体代码,供大家参考,具体内容如下 五子棋大家都玩儿过,所以规则就不介绍了 今天遇到一个学弟在实现的时候遇到一些问题,所以将实现的过程记录下 水平有限,仅供参考,互相交流,共同进步. #include<stdio.h> #include<windows.h>   int main() {       int i,j;//表示棋盘横纵坐标     /*********************************************

  • 基于C语言实现五子棋游戏完整实例代码

    本文实例讲述了基于C语言实现五子棋游戏的方法,代码备有比较完整的注释,可以帮助读者更好的加以理解. 五子棋游戏代码如下: /* * 使用键盘的上下左右键移动棋盘,空格键表示下棋,ESC键退出程序 */ #include <stdio.h> #include <stdlib.h> #include <bios.h> #include <graphics.h> #include<malloc.h> /* * 对应键盘键的十六进制数字 */ #defi

  • java基于swing实现的五子棋游戏代码

    本文实例讲述了java基于swing实现的五子棋游戏代码.分享给大家供大家参考. 主要功能代码如下: 复制代码 代码如下: import java.awt.*; import javax.swing.*; import java.awt.event.*; public class Main extends JFrame implements ActionListener{         private static final long serialVersionUID = 1L;      

  • 基于Python实现五子棋游戏

    本文实例为大家分享了Python实现五子棋游戏的具体代码,供大家参考,具体内容如下 了解游戏的规则是我们首先需要做的事情,如果不知晓规则,那么我们肯定寸步难行. 五子棋游戏规则: 1.对局双方各执一色棋子.2.空棋盘开局.3.黑先.白后,交替下子,每次只能下一子.4.棋子下在棋盘的空白点上,棋子下定后,不得向其它点移动,不得从棋盘上拿掉或拿起另落别处.5.黑方的第一枚棋子可下在棋盘任意交叉点上.6.轮流下子是双方的权利,但允许任何一方放弃下子权(即:PASS权). 五子棋对局,执行黑方指定开局.

  • Java基于享元模式实现五子棋游戏功能实例详解

    本文实例讲述了Java基于享元模式实现五子棋游戏功能.分享给大家供大家参考,具体如下: 一.模式定义 享元模式,以共享的方式高效地支持大量的细粒度对象.通过复用内存中已存在的对象,降低系统创建对象实例的性能消耗.享元的英文是Flyweight,表示特别小的对象,即细粒度对象. 二.模式举例 1. 模式分析 我们借用五子棋游戏来说明这一模式. 2. 享元模式静态类图 3. 代码示例 3.1 创建抽象棋子一AbstractChessman package com.demo.flyweight.obj

  • python网络编程之五子棋游戏

    一.本案例基于UDP的socket编程方法来制作五子棋程序,网络五子棋采用C/S架构,分为服务器端和客户端,游戏时服务端首先启动,当客户端启动连接后,服务器端可以走棋,轮到自己棋才可以在棋盘上落子,同时下方标签会显示对方走起信息,服务器端用户可以通过"退出游戏"按钮可以结束游戏: 1.数据通信协议 网络五子棋游戏设计的难点在于对方进行通信,这里使用面向非连接的Socket编程,Socket编程用于C/S开发,在这类应用中,客户端和服务器端通常需要先建立连接,然后发送和接收数据,交互完成

  • VC实现五子棋游戏的一个算法示例

    本文讲述了VC实现五子棋游戏的一个算法示例,该算法采用极大极小剪枝博弈算法,感兴趣的读者可以对程序中不完善的部分进行修改与完善. 该设计主要包括:数据结构.估值函数.胜负判断.搜索算法 程序运行界面如下: 具体实现步骤如下: 1.数据结构 //记录每步棋,可以建立链表用来进行悔棋.后退(本程序没有实现) struct Step { int x,y; //棋子坐标 int ball; //表示下子方{BLACK,WHITE} }; //记录棋盘情况,用于搜索过程 class CBoardSitua

  • jQuery实现的五子棋游戏实例

    本文实例讲述了jQuery实现的五子棋游戏.分享给大家供大家参考.具体如下: 这是一款非常不错的代码,就是人工智能方面差了一点 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999

随机推荐