ImageVerifierCode 换一换
格式:DOCX , 页数:26 ,大小:89.20KB ,
资源ID:30572773      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/30572773.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(课程设计五子棋设计.docx)为本站会员(b****8)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

课程设计五子棋设计.docx

1、课程设计五子棋设计郑州工业应用技术学院课程设计说明书题目: 五子棋 姓 名: 田鹏 院 (系): 信息工程学院 专业班级: 计算机科学与技术一般 学 号: 1401110105 指导教师: 张吉同 成 绩: 时间: 2015 年 11 月 14 日至 2015 年 12 月 4 日郑州工业应用技术学院课程设计任务书题目 五子棋 专业、班级 计算机科学与技术一班 学号 1401110105 姓名 田鹏 五子棋:又名五子连珠棋,是一项有趣、益智的棋类游戏,易学难精,但妙趣横生。下一局棋所费时间不多,工余饭后“杀上一盘”,开发智力,勤于动脑,调剂感情,有利于开发智商居家必备。 故此利用已学知识在Vi

2、sual c+6.0上写出五子棋程序。完 成 期 限:2015年12月4日 指导教师签名: 课程负责人签名: 2015年 12 月 4 日1. 设计目标与内容.12. 设计要求.2 2.1新建工程game_wzq.3 2.2资源编辑.4 2.3变量函数.5 2.4具体实现.6 2.5文件保存和读取.223.附录.274.参考文献.29 第一章 设计目标与内容1. 了解Windows编程的基础知识,掌握MFC应用程序的基本知识;2. 基本掌握面向对象程序设计的基本思路和方法;3. 掌握用VC+开发应用程序的的一般步骤和方法;4. 能够利用所学的基本知识, 设计一个简单的五子棋游戏,具有以下功能:

3、数据结构的设计;五子棋棋盘的绘制。两人下棋时,两人下棋算法的设计。两人下棋时,判断任一方获胜的算法的设计。 第二章 设计要求 用VC进行编码,实现应用程序的功能。注重编码质量,代码要有适当的注释;提交设计报告一份(课程设计任务书、目录、主要的数据结构、设计的基本思路、设计的步骤及主要代码、心得体会、参考文献)。总体设计 运行时效果如下: 图1 这个程序只能进行两个人之间的对弈,不能进行人机对弈,由于时间和个人能力的原因所以人机对弈的算法就没有写出。同时程序中也存在着很多漏洞,但基本的功能都已经实现,还有待继续改进。 详细设计第一节 新建工程game_wzq 选择单文档应用程序,在Step 4

4、of 6中先中Windows Sockets复选框。如下图: 图2 第二节 资源编辑 黑白位图Bitmap以表示棋盘上面的棋子: IDB_BLACK DB_WHITE 黑白鼠标Cursor以替换当前鼠标: IDC_CURSOR1 黑棋子 IDC_CURSOR2 白棋子黑白图标Icon以显示在状态栏供以提示 IDI_BLACK IDI_WHITE菜单以供操作:开始: ID_START 保存: ID_SAVE打开: ID_OPEN如下图所示: 图3第三节 变量函数首先,为了实现状态栏的应用,我们必须更改它的变量: 在MainFrm.h文件里面,把CStatusBar m_wndStatusBar

5、为public 接着是在game_wzqView.h文件里面添加变量函数: /两个鼠标 HCURSOR hcursorwhite;HCURSOR hcursorblack;/棋盘数组 int wzq1919; / colorwhite TRUE时白棋下,否则黑棋下 bool colorwhite;/棋子位图CBitmap m_bmblack;CBitmap m_bmwhite; /保存文件void Save();/检查是否结束void over(CPoint point);/鼠标操作afx_msg void OnLButtonUp(UINT nFlags, CPoint point);/鼠标图

6、形更换 afx_msg BOOL OnSetCursor(CWnd* pWnd, UINT nHitTest, UINT message);/菜单的开始afx_msg void OnStart();/菜单的保存 afx_msg void OnSave(); /菜单的打开 afx_msg void OnOpen();第四节 具体实现1、由于我们的游戏的棋盘大小是一定的,不能改变大小的,是应该符合要求的。在如下函数添加设置窗口大小的语句:BOOL CMainFrame:PreCreateWindow(CREATESTRUCT& cs) if( !CFrameWnd:PreCreateWindow(

7、cs) ) return FALSE; / TODO: Modify the Window class or styles here by modifying / the CREATESTRUCT cs cs.dwExStyle=cs.dwExStyle|WS_EX_TOPMOST; cs.style=WS_SYSMENU|WS_OVERLAPPED|WS_MINIMIZEBOX; /设置窗口大小:400*340 cs.cx=450; cs.cy=500; return TRUE;2、初始化变量: 在构造函数里添加初始代码:CGame_wzqView:CGame_wzqView() /Load

8、鼠标图像和棋子位图 hcursorblack=AfxGetApp()-LoadCursor(IDC_CURSOR1); hcursorwhite=AfxGetApp()-LoadCursor(IDC_CURSOR2); m_bmwhite.LoadBitmap(IDB_WHITE); m_bmblack.LoadBitmap(IDB_BLACK); /清理棋盘 /数组值为0表示没有棋子 for(int i=0;i19;i+) for(int j=0;jFillRect(myrect1,&mybrush1); /画棋盘框线 CPen mypen; CPen*myoldPen; mypen.Cre

9、atePen(PS_SOLID,1,RGB(0,0,0); myoldPen=pDC-SelectObject(&mypen); for(int i=0;iMoveTo(40,40+i*20); pDC-LineTo(400,40+i*20); pDC-MoveTo(40+i*20,40); pDC-LineTo(40+i*20,400); /重画时显示存在的棋子 CDC Dc; if(Dc.CreateCompatibleDC(pDC)=FALSE) AfxMessageBox(Cant create DC); for(int n=0;n19;n+) for(int m=0;mBitBlt(

10、n*20+32,m*20+32,160,160,&Dc,0,0,SRCCOPY); else if(wzqnm=-1) /显示黑棋 Dc.SelectObject(m_bmblack); pDC-BitBlt(n*20+32,m*20+32,160,160,&Dc,0,0,SRCCOPY); 4、设置鼠标:棋盘画好了,接下来就是下棋了。但鼠标并没有像我们上面说的那样变成白棋,加函数如下:BOOL CGame_wzqView:OnSetCursor(CWnd* pWnd, UINT nHitTest, UINT message) if(nHitTest=HTCLIENT) /白棋下,显示白棋鼠标

11、 if(colorwhite) /调用主框架里面的状态栏 CMainFrame *pFrm=(CMainFrame*)AfxGetApp()-m_pMainWnd; CStatusBar*pStatus=&pFrm-m_wndStatusBar; if(pStatus) pStatus-GetStatusBarCtrl().SetIcon(0,AfxGetApp()-LoadIcon(IDI_WHITE); pStatus-SetPaneText(0,白棋下); SetCursor(hcursorwhite); /显示黑棋鼠标 else SetCursor(hcursorblack); CMa

12、inFrame*pFrm=(CMainFrame*)AfxGetApp()-m_pMainWnd; CStatusBar*pStatus=&pFrm-m_wndStatusBar; if(pStatus) /显示图像 pStatus-GetStatusBarCtrl().SetIcon(0,AfxGetApp()-LoadIcon(IDI_BLACK); /显示文字 pStatus-SetPaneText(0,黑棋下); return 1; return CView:OnSetCursor(pWnd, nHitTest, message); 5、下棋操作:这就涉及到OnLButtonDown(

13、UINT nFlags, CPoint point)和OnLButtonUp(UINT nFlags, CPoint point)两个函数了。要用哪一个或用两个?用Down函数时是在鼠标按下时放下棋子,可是,要是我们按下后意识到按错了怎么办;那就改用Up函数,表示当鼠标键松开时放下棋子。OK!添加函数如下:void CGame_wzqView:OnLButtonUp(UINT nFlags, CPoint point) CView:OnLButtonUp(nFlags, point); CDC *pDC=GetDC(); CDC Dc; if(Dc.CreateCompatibleDC(pDC

14、)=FALSE) AfxMessageBox(Cant create DC); /是否在棋盘内 if(point.x30&point.x30&point.yBitBlt(px*20+32,py*20+32,160,160,&Dc,0,0,SRCCOPY); /表示存在白棋 wzqpxpy=1; /检查是否结束 over(point); /换黑棋下 colorwhite=false; else if(wzqpxpy=0) Dc.SelectObject(m_bmblack); pDC-BitBlt(px*20+32,py*20+32,160,160,&Dc,0,0,SRCCOPY); wzqpx

15、py=-1; over(point); colorwhite=true; 由上面可以看出,当鼠标键松开时判断,如果那个位置没有棋子,则放下,并把棋盘数组赋相应的值:1或-1 6、是否结束: 接着是用一个over()函数判断是否结束,是则结束并重新开始;否则,接着把鼠标变成对方棋子,表示对方下棋。那over()函数又是怎样的呢? 此函数是利用刚下棋的位置为中心,检查它各个方向上的连续五个棋子是否同色,是则结束并重新开始。然而,我们又是怎样判断一个方向上的五个棋子的同色的?这就涉及地为什么我要把五子棋数组赋值为1和-1的问题。因为这样有一个好处:利用连续五个棋子的值相加,如果它们的值的绝对值等于5

16、,则说明是同色。当然,这只是这样赋值的一点作用,真正的作用将在后面介绍。添加如下:void CGame_wzqView:over(CPoint point) /获取鼠标指向数组位置,即中心位置 int x=(point.x-30)/20; int y=(point.y-30)/20; /计算开始判断的坐标 xx,yy int xx,yy; if(x4) xx=0; else xx=x-4; if(y4) yy=0; else yy=y-4; int i,j,a; /横向判断 for(i=xx;i15;i+) a=0; for(j=i;ji+5;j+) a=a+wzqjy; /五个都是白棋 if

17、(a=5) AfxMessageBox(白棋胜!); /重新开始 OnStart(); return; /五个都是黑棋 if(a=-5) AfxMessageBox(黑棋胜!); OnStart(); return; /竖向判断 for(i=yy;i15;i+) a=0; for(j=i;ji+5;j+) a=a+wzqxj; if(a=5) AfxMessageBox(白棋胜!); OnStart(); return; if(a=-5) AfxMessageBox(黑棋胜!); OnStart(); return; /向右下角 /判断起点位置 if(xy) if(xx=0) yy=y-x;

18、else if(yy=0) xx=x-y; /参数over=1时退出循环 int over=0; do a=0; for(i=0;i5;i+) if(xx+i)19|(yy+i)(18-x) if(x13) yy=y-(18-x); xx=18; else yy=y-4; xx=x+4; else if(y5) xx=x+y; yy=0; else yy=y-4; xx=x+4; over=0; do a=0; for(i=0;i=0|(yy+i)19) a=a+wzqxx-iyy+i; if(a=5) AfxMessageBox(白棋胜!); OnStart(); return; if(a=

19、-5) AfxMessageBox(黑棋胜!); OnStart(); return; /到了边界 else over=1; xx-=1; yy+=1; while(over=0);第五节 文件保存和读取保存文件函数是一个菜单选项。它的作用就是保存当前游戏的状态。首先,我们应该为我们自己的文件定义一个后缀名:.wzq;接着是打开保存文件的公共对话框,如果确定,则表示保存,那么就先获取文件名,然后按照一定的顺序保存各个点的数组的值,最后保存当前是哪种颜色下棋。void CGame_wzqView:OnSave() /设置保存的文件,后缀名wzq CFileDialog dlg(FALSE,wzq

20、,NULL,OFN_HIDEREADONLY|OFN_OVERWRITEPROMPT,(*.WZQ)|*.wzq|All Files|*.*|,this); /如果公共类对话框为确定 if(dlg.DoModal()=IDOK) /获取文件名 dlg.GetFileName(); /否则,退出 else return; /字符串变量 CString str; int i,j; CStdioFile file; /如果有问题,退出 if(file.Open(dlg.GetFileName(),CFile:modeCreate|CFile:modeWrite|CFile:typeText)=0)

21、AfxMessageBox(save error!); return; /循环把棋盘数组的值写进文件 for(i=0;i19;i+) for(j=0;j19;j+) if(wzqij=-1) file.WriteString(-1n); if(wzqij=0) file.WriteString(0n); if(wzqij=1) file.WriteString(1n); /保存当前下棋颜色 if(colorwhite=true) file.WriteString(1n); else file.WriteString(0n); /关闭文件 file.Close(); 读文件就是把我们以前保存的文

22、件打开,读取当前打开文件的内容,并给数组赋值使和文件内容相同,然后可以继续进行游戏。void CGame_wzqView:OnOpen() CFileDialog dlg(TRUE,wzq,NULL,OFN_HIDEREADONLY|OFN_OVERWRITEPROMPT,(*.WZQ)|*.wzq|All Files|*.*|,this); if(dlg.DoModal()=IDOK) dlg.GetFileName(); else return; CString str; int i,j,m; CStdioFile file; if(file.Open(dlg.GetFileName(),CFile:modeRead)=0) AfxMessageBox(open error!); return; CArchive ar(&file,CArchive:load); for(i=0;i19;i+) for(j=0;j19;j+) ar.ReadString(str); sscanf(str,%d,&m); if(m=-1) wzqij=-1; if(m=0) wzqij=0;

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1