Android下SDL2实现五子棋游戏

本文实例介绍了Android下用SDL2实现一个简单的五子棋游戏,分享给大家供大家参考,具体内容如下

1. Five.c

// Five.c

// SDL2 五子棋
// gcc -mwindows -o Five Five.c FiveData.c FiveData.h -lSDL2 -lSDL2main -lSDL2_image -lSDL2_ttf

//#define _DEBUG_

#include <stdio.h>
#include <string.h>
#include <SDL2/SDL.h>
#include <SDL2/SDL_image.h>
#include <SDL2/SDL_ttf.h>
#include "FiveData.c"

// 资源文件
char szBackGroundFile[] = "Resource/BackGround.jpg";  // 棋盘背景图文件
char szBlackFile[]   = "Resource/BlackPiece.jpg";  // 黑棋子图文件(背景色:白色)
char szWhiteFile[]   = "Resource/WhitePiece.jpg";  // 白棋子图文件(背景色:白色)
char szFontFile[]    = "Resource/DroidSansFallback.ttf"; // 字体文件
// 字符串常量
char szTitle[]  = "五子棋";
char szBlack[]  = "黑方";
char szWhite[]  = "白方";
char szGameTips[] = "第 %d 手,轮到 %s 落子";
char szGameOver[] = "%s 取得本局胜利,请按键继续";

_Bool OnKeyUp(int x, int y, int nSpacing);
void DrawBoard(SDL_Renderer *pRenderer, int nSpacing, SDL_Color *pColor);
void DrawPieces(SDL_Renderer *pRenderer, int nSpacing, SDL_Texture *pBlackTexture, SDL_Texture *pWhiteTexture);
void PrintString(SDL_Renderer *pRenderer, int nSpacing, char *szString, TTF_Font *pFont, SDL_Color *pColor);
void FillCircle(SDL_Renderer *pRenderer, int x, int y, int r, SDL_Color *pColor);
SDL_Texture *GetImageTexture(SDL_Renderer *pRenderer, char *szFile, _Bool bTransparent, SDL_Color *pBackGroundColor);
SDL_Texture *GetStringTexture(SDL_Renderer *pRenderer, TTF_Font *pFont, char *szString, SDL_Color *pColor);

#undef main
int main(int argc, char **argv)
{
  int nWindowWidth, nWindowHeight;  // 屏幕尺寸
  int nSpacing;            // 棋盘线距
  SDL_Window  *pWindow    = NULL; // 主窗口
  SDL_Renderer *pRenderer   = NULL; // 主窗口渲染器
  SDL_Texture *pBackTexture = NULL; // 棋盘背景图纹理
  SDL_Texture *pBlackTexture = NULL; // 黑棋子图纹理
  SDL_Texture *pWhiteTexture = NULL; // 白棋子图纹理
  TTF_Font   *pFont     = NULL; // 提示文字字体
  SDL_Event  event;         // 事件
  _Bool bRun = 1;           // 持续等待事件控制循环标识
  char szString[256];

  // 初始化
  if(SDL_Init(SDL_INIT_EVERYTHING)==-1 || IMG_Init(IMG_INIT_JPG)==-1 || TTF_Init()==-1)
  {
#ifdef _DEBUG_
    fprintf(stderr, "%s", SDL_GetError());
#endif
    return 1;
  }
  // 创建主窗口及其渲染器
  if(SDL_CreateWindowAndRenderer(0, 0, SDL_WINDOW_FULLSCREEN, &pWindow, &pRenderer)==-1)
  {
#ifdef _DEBUG_
    fprintf(stderr, "%s", SDL_GetError());
#endif
    goto label_error;
  }
  SDL_SetWindowTitle(pWindow, szTitle);
  SDL_GetWindowSize(pWindow, &nWindowWidth, &nWindowHeight);
  nSpacing = SDL_min(nWindowWidth, nWindowHeight)/(MAX_LINES+2);

  // 加载图片文件
  if(NULL==(pBackTexture = GetImageTexture(pRenderer, szBackGroundFile, 0, NULL))
      || NULL==(pBlackTexture = GetImageTexture(pRenderer, szBlackFile, 1, NULL))
      || NULL==(pWhiteTexture = GetImageTexture(pRenderer, szWhiteFile, 1, NULL)))
  {
#ifdef _DEBUG_
    fprintf(stderr, "%s", SDL_GetError());
#endif
    goto label_error;
  }
  // 加载字体文件
  if(NULL == (pFont = TTF_OpenFont(szFontFile, 20))) // 这个 20 是字体大小
  {
#ifdef _DEBUG_
    fprintf(stderr, "%s", SDL_GetError());
#endif
    goto label_error;
  }

  // 重置棋局数据,等待事件
  Five_ResetData();
  while(bRun && SDL_WaitEvent(&event))
  {
    switch(event.type)
    {
    case SDL_FINGERUP :  // 触摸弹起
      if(g_iWho != NONE)
      {
        if(OnKeyUp(event.tfinger.x*nWindowWidth, event.tfinger.y*nWindowHeight, nSpacing) && Five_isFive())
          g_iWho = NONE;
      }
      else
        Five_ResetData();
      // 这里没有 break; 往下坠落重绘窗口

    case SDL_WINDOWEVENT :   // 有窗口消息需重绘窗口
      SDL_RenderClear(pRenderer);
      SDL_RenderCopyEx(pRenderer, pBackTexture, NULL, NULL, 0, NULL, SDL_FLIP_NONE);
      DrawBoard(pRenderer, nSpacing, NULL);
      DrawPieces(pRenderer, nSpacing, pBlackTexture, pWhiteTexture);
      if(g_iWho == NONE)
        sprintf(szString, szGameOver, g_nHands%2==1 ? szBlack : szWhite);
      else
        sprintf(szString, szGameTips, g_nHands+1, g_iWho==BLACK ? szBlack : szWhite);
      PrintString(pRenderer, nSpacing, szString, pFont, NULL);
      SDL_RenderPresent(pRenderer);
      break;

    case SDL_QUIT :
      bRun = 0;
      break;

    default :
      break;
    }
  }

label_error:
// 清理
  if(pBackTexture != NULL) SDL_DestroyTexture(pBackTexture);
  if(pBlackTexture != NULL) SDL_DestroyTexture(pBlackTexture);
  if(pWhiteTexture != NULL) SDL_DestroyTexture(pWhiteTexture);
  if(pFont != NULL)     TTF_CloseFont(pFont);
  TTF_Quit();
  IMG_Quit();
  SDL_Quit();
  return 0;
}

// 响应落子按键
// 参数:(x,y) = 被点击的窗口坐标,nSpacing = 棋盘线距
_Bool OnKeyUp(int x, int y, int nSpacing)
{
  // 计算落点棋盘坐标
  int m = (x - 0.5*nSpacing)/nSpacing;
  int n = (y - 0.5*nSpacing)/nSpacing;
  // 处理有效落点
  if(m>=0 && m<MAX_LINES && n>=0 && n<MAX_LINES && g_iBoard[m][n]==NONE)
  {
    Five_AddPiece(m, n, g_iWho);
    return 1;
  }
  return 0;
}

// 画棋盘
// 参数:pRenderer = 渲染器,nSpacing = 棋盘线距,pColor = 颜色(默认黑色)
void DrawBoard(SDL_Renderer *pRenderer, int nSpacing, SDL_Color *pColor)
{
  SDL_Color c;
  int r, x, y, z;

  if(pColor == NULL)
    c.r = c.g = c.b = 0;
  else
    c = *pColor;

  // 棋盘线
  SDL_SetRenderDrawColor(pRenderer, c.r, c.g, c.b, SDL_ALPHA_OPAQUE);
  for(int i = 1; i <= MAX_LINES; i++)
  {
    SDL_RenderDrawLine(pRenderer, nSpacing, i*nSpacing, MAX_LINES*nSpacing, i*nSpacing);
    SDL_RenderDrawLine(pRenderer, i*nSpacing, nSpacing, i*nSpacing, MAX_LINES*nSpacing);
  }

  // 星位
  r = nSpacing*0.2;        // 星半径
  x = nSpacing*4;         // 第四线
  y = nSpacing*(MAX_LINES+1)/2;  // 中线
  z = nSpacing*(MAX_LINES-3);   // 倒数第四线
  FillCircle(pRenderer, x, x, r, &c);
  FillCircle(pRenderer, y, x, r, &c);
  FillCircle(pRenderer, z, x, r, &c);
  FillCircle(pRenderer, x, y, r, &c);
  FillCircle(pRenderer, y, y, r, &c);
  FillCircle(pRenderer, z, y, r, &c);
  FillCircle(pRenderer, x, z, r, &c);
  FillCircle(pRenderer, y, z, r, &c);
  FillCircle(pRenderer, z, z, r, &c);
}

// 画棋子
// 参数:pRenderer = 渲染器,nSpacing = 棋盘线距,pBlackTexture = 黑子纹理,pWhiteTexture = 白子纹理
void DrawPieces(SDL_Renderer *pRenderer, int nSpacing, SDL_Texture *pBlackTexture, SDL_Texture *pWhiteTexture)
{
  int r = 0.4*nSpacing; // 棋子半径
  SDL_Rect rt = {0, 0, 2*r, 2*r};

  if(g_nHands <= 0)
    return;

  for(int i=0; i<MAX_LINES; i++)
  {
    for(int j=0; j<MAX_LINES; j++)
    {
      rt.x = (i+1)*nSpacing - r;
      rt.y = (j+1)*nSpacing - r;
      if(g_iBoard[i][j] == BLACK)
        SDL_RenderCopyEx(pRenderer, pBlackTexture, NULL, &rt, 0, NULL, SDL_FLIP_NONE);
      else if(g_iBoard[i][j] == WHITE)
        SDL_RenderCopyEx(pRenderer, pWhiteTexture, NULL, &rt, 0, NULL, SDL_FLIP_NONE);
    }
  }
}

// 提示文字
// 参数:szString = 文字内容,pFont = 字体,pColor = 文字颜色(默认黑色)
void PrintString(SDL_Renderer *pRenderer, int nSpacing, char *szString, TTF_Font *pFont, SDL_Color *pColor)
{
  SDL_Texture *pTextTexture;
  SDL_Rect rt;

  rt.x = nSpacing;
  rt.y = nSpacing*(MAX_LINES+1);
  rt.w = nSpacing*strlen(szString)/4;   // 这个 4 和字体大小有关
  rt.h = nSpacing;

  if((pTextTexture = GetStringTexture(pRenderer, pFont, szString, pColor)) != NULL)
  {
    SDL_RenderCopyEx(pRenderer, pTextTexture, NULL, &rt, 0, NULL, SDL_FLIP_NONE);
    SDL_DestroyTexture(pTextTexture);
  }
}

// 取得图片文件纹理
// 参数:szFile = 图片文件名,bTransparent = 是否透明处理,pBackGroundColor = 背景色(默认白色)
// 返回值:纹理指针
SDL_Texture *GetImageTexture(SDL_Renderer *pRenderer, char *szFile, _Bool bTransparent, SDL_Color *pBackGroundColor)
{
  SDL_Texture *pTexture;
  SDL_Surface *pSurface;
  int r, g, b;

  if((pSurface = IMG_Load(szFile)) == NULL)
    return NULL;
  if(bTransparent)
  {
    if(pBackGroundColor == NULL)
    {
      r = g = b = 255;
    }
    else
    {
      r = pBackGroundColor->r;
      g = pBackGroundColor->g;
      b = pBackGroundColor->b;
    }
    SDL_SetColorKey(pSurface, 1, SDL_MapRGB(pSurface->format, r, g, b));
  }
  pTexture = SDL_CreateTextureFromSurface(pRenderer, pSurface);

  SDL_FreeSurface(pSurface);
  return pTexture;
}

// 取得字符串纹理
// 参数:szString = 字符串内容,pFont = 字体,pColor = 文字颜色(默认黑色)
// 返回值:纹理指针
SDL_Texture *GetStringTexture(SDL_Renderer *pRenderer, TTF_Font *pFont, char *szString, SDL_Color *pColor)
{
  SDL_Texture *pTexture;
  SDL_Surface *pSurface;
  SDL_Color c;

  if(pColor == NULL)
    c.r = c.g = c.b = 0;
  else
    c = *pColor;

  if((pSurface = TTF_RenderUTF8_Blended(pFont, szString, c)) == NULL)
    return NULL;
  pTexture = SDL_CreateTextureFromSurface(pRenderer, pSurface);

  SDL_FreeSurface(pSurface);
  return pTexture;
}

// 画圆(SDL2 没有画圆的函数,先用矩形框代替吧)
// 参数:pRenderer = 渲染器,(x,y) = 圆心坐标,r = 半径, pCOlor = 填充色
void FillCircle(SDL_Renderer *pRenderer, int x, int y, int r, SDL_Color *pColor)
{
  SDL_Rect rt = {x-r, y-r, 2*r, 2*r};

  SDL_SetRenderDrawColor(pRenderer, pColor->r, pColor->g, pColor->b, SDL_ALPHA_OPAQUE);
  SDL_RenderFillRect(pRenderer, &rt);
}

2.FiveData.c   

// FiveData.c

// 五子棋:数据处理模块

#include "FiveData.h"

// 公共变量
int g_nHands;      // 总手数
int g_nLastCrossing;  // 100*x+y,(x,y)为最后一手的坐标
enum en_COLOR g_iWho;  // 轮到哪方落子:0 不可落子状态,1 黑方,2 白方
int g_iBoard[MAX_LINES][MAX_LINES];  // 棋盘交叉点数据:0 无子,1 黑子,2 白子

// 判断最后一手棋是否形成五子连珠
// 返回值:1 = 形成五子连珠, 0 = 未形成五子连珠
_Bool Five_isFive(void)
{
  int i, j, nCount, x, y;

  if(g_nLastCrossing < 0)
    return 0;
  x = g_nLastCrossing/100;
  y = g_nLastCrossing%100;

  // 横线计数
  nCount = 1;
  i = x - 1;   // 左
  while(i>=0 && g_iBoard[x][y]==g_iBoard[i][y])
  {
    nCount++;
    i--;
  }
  i = x + 1;   // 右
  while(i<MAX_LINES && g_iBoard[x][y]==g_iBoard[i][y])
  {
    nCount++;
    i++;
  }
  if(nCount >= 5)
    return 1;

  // 竖线计数
  nCount = 1;
  j = y - 1;   // 上
  while(j>=0 && g_iBoard[x][y]==g_iBoard[x][j])
  {
    nCount++;
    j--;
  }
  j = y + 1;   // 下
  while(j<MAX_LINES && g_iBoard[x][y]==g_iBoard[x][j])
  {
    nCount++;
    j++;
  }
  if(nCount >= 5)
    return 1;

  // 左斜线计数
  nCount = 1;
  i = x - 1;   // 左上
  j = y - 1;
  while(i>=0 && j>=0 && g_iBoard[x][y]==g_iBoard[i][j])
  {
    nCount++;
    i--;
    j--;
  }
  i = x + 1;   // 右下
  j = y + 1;
  while(i<MAX_LINES && j<MAX_LINES && g_iBoard[x][y]==g_iBoard[i][j])
  {
    nCount++;
    i++;
    j++;
  }
  if(nCount >= 5)
    return 1;

  // 右斜线计数
  nCount = 1;
  i = x + 1;   // 右上
  j = y - 1;
  while(i<MAX_LINES && j>=0 && g_iBoard[x][y]==g_iBoard[i][j])
  {
    nCount++;
    i++;
    j--;
  }
  i = x - 1;   // 左下
  j = y + 1;
  while(i>=0 && j<MAX_LINES && g_iBoard[x][y]==g_iBoard[i][j])
  {
    nCount++;
    i--;
    j++;
  }
  if(nCount >= 5)
    return 1;

  return 0;
}

// 重置对局数据
void Five_ResetData(void)
{
  for(int i=0; i<MAX_LINES; i++)
    for(int j=0; j<MAX_LINES; j++)
      g_iBoard[i][j] = NONE;
  g_nHands = 0;
  g_nLastCrossing = -1;
  g_iWho = BLACK;
}

// 记录一个落子数据
// 参数:x,y = 棋子坐标,c = 棋子颜色
void Five_AddPiece(int x, int y, enum en_COLOR c)
{
  g_iBoard[x][y] = c;
  g_nHands++;
  g_nLastCrossing = 100*x + y;
  g_iWho = (g_iWho == BLACK ? WHITE : BLACK);
}

3.FiveData.h  

// FiveData.h

// 五子棋:数据处理模块对外接口

#ifndef _FIVE_DATA_H
#define _FIVE_DATA_H

enum en_COLOR  // 棋子颜色
{
  NONE = 0,    // 无子
  BLACK,     // 黑子
  WHITE      // 白子
};

// 棋局
#define MAX_LINES   15    // 棋盘线数
extern int g_nHands;      // 总手数
extern int g_nLastCrossing;  // 100*x+y,(x,y)为最后一手的坐标
extern enum en_COLOR g_iWho;  // 轮到哪方落子:0 不可落子状态,1 黑方,2 白方
extern int g_iBoard[MAX_LINES][MAX_LINES]; // 棋盘交叉点数据:0 无子,1 黑子,2 白子

// 判断最后一手棋是否形成五子连珠
// 返回值:1 = 形成五子连珠, 0 = 未形成五子连珠
extern _Bool Five_isFive(void);

// 重置对局数据
extern void Five_ResetData(void);

// 记录一个落子数据
// 参数:x,y = 棋子坐标,c = 棋子颜色
extern void Five_AddPiece(int x, int y, enum en_COLOR c);

#endif

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

(0)

相关推荐

  • Android游戏源码分享之2048

    引言 程序猿们,是否还在为你的老板辛辛苦苦的打工而拿着微薄的薪水呢,还是不知道如何用自己的应用或游戏来赚钱呢! 在这里IQuick将教您如何同过自己的应用来赚取自己的第一桶金! 你是说自己的应用还没有做出来? 不,在這里已经为你提供好了一个完整的游戏应用了,在文章的下面有源码的地址哦.你只要稍做修改就可以变成一个完全属于自己的应用了,比如将4*4换成5*5,甚至是其它的.如果你实在是慵懒至极的话,你只要将本应用的包名及广告换成自己的,就可以上传到市场上轻轻松松赚取自己的第一桶金了. 如果你觉得本

  • Android实现中国象棋附源码下载

    象棋,很多人多接触过,学者写了一个,大神可以指点一下~直接上代码: 贴出主要代码,想要Demo的点击下载:中国象棋Demo package wyf.ytl; import android.content.Context; import android.graphics.Bitmap; import android.graphics.BitmapFactory; import android.graphics.Canvas; import android.graphics.Color; impor

  • 解析Android游戏中获取电话状态进行游戏暂停或继续的解决方法

    对智能手机有所了解的朋友都知道其中一个应用广泛的手机操作系统Android 开源手机操作系统.那么在这一系统中想要实现通话的监听功能的话,我们应当如何操作呢?在这里就为大家详细介绍了Android监听通话的相关实现方法. 开发应用程序的时候,我们希望能够监听电话的呼入,以便执行暂停音乐播放器等操作,当电话结束之后,再次恢复播放.在Android平台可以通过TelephonyManager和PhoneStateListener来完成此任务.TelephonyManager作为一个Service接口

  • Unity3D游戏引擎实现在Android中打开WebView的实例

    本文讲述了如何在Unity中调用Android中的WebView组件,实现内部浏览器样式的页面切换.首先打开Eclipse创建一个Android的工程: UnityTestActivity.java 入口Activity ,Unity中会调用这个Activity中的方法从而打开网页. package com.xys; import android.content.Context; import android.content.Intent; import android.os.Bundle; i

  • Android游戏开发学习之引擎用法实例详解

    本文实例讲述了Android游戏开发学习之引擎用法.分享给大家供大家参考.具体如下: 汽车引擎是汽车的心脏,其决定了汽车的性能和稳定性,是人们在购车时相当关注的.而游戏中的物理引擎就如汽车的引擎一样,占据了非常重要的位置.一款好的物理引擎可以非常真实地模拟现实世界,使得游戏更加逼真,提供更好的娱乐体验. 一.JBox2D简介 JBox2D是开源物理引擎Box2D的Java版本,可以直接用于Android.由于JBox2D的图形渲染使用的是Processing库,因此在Android平台上使用JB

  • Android 游戏开发之Canvas画布的介绍及方法

    Canvas,在英语中,这个单词的意思是帆布.在Android中,则把Canvas当做画布,只要我们借助设置好的画笔(Paint类)就可以在画布上绘制我们想要的任何东西:另外它也是显示位图(Bitmap类)的核心类.随用户的喜好,Canvas还可设置一些关于画布的属性,比如,画布的颜色.尺寸等.Canvas提供了如下一些方法:    Canvas(): 创建一个空的画布,可以使用setBitmap()方法来设置绘制具体的画布.    Canvas(Bitmap bitmap): 以bitmap对

  • Android游戏开发实践之人物移动地图的平滑滚动处理

    如图所示为程序效果动画图 地图滚动的原理 在本人之前博客的文章中介绍过人物在屏幕中的移动方式,因为之前拼的游戏地图是完全填充整个手机屏幕的,所以无需处理地图的平滑滚动.这篇文章我着重的向 大家介绍一下控制人物移动后地图滚动的处理方式.举个例子 如上图所示 比如人物向右移动,如果地图贴在屏幕左边边界 将先移动人物在地图的坐标,当人物在屏幕中超过三分之二后 则将地图向人物行走的反方向移动给玩家一种人物还在向右移动的假象,其实这时候人物只是播放向右行走的动画 在屏幕中的坐标不变 ,当地图向人物行走反方

  • Android游戏开发之黑白棋

    黑白棋介绍 黑白棋,又叫苹果棋,最早流行于西方国家.游戏通过相互翻转对方的棋子,最后以棋盘上谁的棋子多来判断胜负.黑白棋非常易于上手,但精通则需要考虑许多因素,比如角边这样的特殊位置.稳定度.行动力等.本游戏取名为黑白棋大师,提供了8种难度等级的选择,从菜鸟.新手.入门.棋手到棋士.大师.宗师.棋圣,助你不断提升棋力. 黑白棋游戏规则 游戏规则见黑白棋大师中的截图. 黑白棋大师游戏截图 游戏启动界面. 游戏过程中的一个截图. 开新局时的选项,选择先后手以及AI的水平. 几个关键的类 Rule R

  • Android五子棋游戏程序完整实例分析

    最近学习了五子棋的课程,感觉挺不错.然后自己写了个关于五子棋的android程序,从中还是能够学习到很多东西的.现在我们开始今天五子棋程序的编写历程.程序的源码请参见友情链接: 好了,我们现在开始一步步的构建出项目来,首先是如下的项目结构图: 运行的效果图: 一些前期做准备的代码 1. 主活动类MainActivity,在菜单中加入了再来一局的功能: public class MainActivity extends AppCompatActivity { private ChessBoardV

  • Android下SDL2实现五子棋游戏

    本文实例介绍了Android下用SDL2实现一个简单的五子棋游戏,分享给大家供大家参考,具体内容如下 1. Five.c // Five.c // SDL2 五子棋 // gcc -mwindows -o Five Five.c FiveData.c FiveData.h -lSDL2 -lSDL2main -lSDL2_image -lSDL2_ttf //#define _DEBUG_ #include <stdio.h> #include <string.h> #includ

  • Android自定义View实现五子棋游戏

    本文实例为大家分享了Android五子棋游戏的具体代码,供大家参考,具体内容如下 1.效果图: 2.GobangPanel棋盘面板: public class GobangPanel extends View { private int mPanelWidth;//棋盘的宽度 private float mLineHeight;//行,高要为float private int MAX_LINE = 15;//棋盘行数 private int MAX_COUNT_IN_LINE = 5;//设置赢

  • Android开发实现的简单五子棋游戏示例

    本文实例讲述了Android开发实现的简单五子棋游戏.分享给大家供大家参考,具体如下: 我刚刚在Android上写的一个五子棋的小程序,在这里跟大家分享一下. 写完以后感觉Android的SDK,虽然也是使用Java的,但是跟Java ME还是有很大不一样. 首先就是Android的SDK没有实现所有的Java ME标准,原来运行在KJava上的应用程序是不能在Android上直接跑的. 另外就是Android的SDK有大量的API是Android自己的,需要开发人员去了解. Android的开

  • Android实现五子棋游戏(局域网版)

    本文实例为大家分享了Android实现五子棋游戏的具体代码,供大家参考,具体内容如下 实现环境:  android studio 3.2.1, 手机分辨率为: 1920 * 1080 局域网采用 Socket 连接分主活动类,主机类,客户端类 代码如下 清单文件要添加的权限: <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /> <uses-permission android:

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

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

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

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

  • 原生JS+Canvas实现五子棋游戏实例

    一.功能模块 先看下现在做完的效果: 线上体验:https://wj704.github.io/five_game.html 主要功能模块为: 1.人机对战功能 2.悔棋功能 3.撤销悔棋功能 二.代码详解 2.1 人机对战功能实现 从效果图可以看到,棋盘的横竖可以放的位置为15*15,通过canvas画棋盘: //绘画棋盘 var drawChessBoard = function(){ for(var i = 0; i < 15; i++){ context.moveTo(15 + i *

  • Android高仿2048小游戏实现代码

    刚开始进入Splash界面: 1.SplashActivity.Java(两秒后进入开始界面,Splash界面的布局只有一个图片,在博客后,会展示给大家看) public class SplashActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.a

  • C++实现五子棋游戏

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

随机推荐