基于c-+-+-的2048游戏设计

上传人:F****n 文档编号:98812678 上传时间:2019-09-14 格式:DOC 页数:14 大小:380.50KB
返回 下载 相关 举报
基于c-+-+-的2048游戏设计_第1页
第1页 / 共14页
基于c-+-+-的2048游戏设计_第2页
第2页 / 共14页
基于c-+-+-的2048游戏设计_第3页
第3页 / 共14页
基于c-+-+-的2048游戏设计_第4页
第4页 / 共14页
基于c-+-+-的2048游戏设计_第5页
第5页 / 共14页
点击查看更多>>
资源描述

《基于c-+-+-的2048游戏设计》由会员分享,可在线阅读,更多相关《基于c-+-+-的2048游戏设计(14页珍藏版)》请在金锄头文库上搜索。

1、学号: 实习论文(本科)学 院 数学与统计学院 专 业 统计学 年 级 2013级 姓 名 论文题目 基于C + + 的2048游戏设计 指导教师 职称 讲师 成 绩 2016年10月16日村民建房委员会应建立村级农房建设质量安全监督制度和巡查制度,选聘有责任心和具有一定施工技术常识的村民作为义务巡查监督员,开展经常性的巡查和督查。目 录摘 要1关键词1Abstract1Key words1前言11 实习前的准备12 实习目的23 实习任务24 实习内容24.1 2048游戏简介24.2 2048模块需求分析34.3 UI界面的规划设计34.4 头文件的需求分析44.5 随机数的生成44.6

2、图片资源的导入和加载54.7 主体算法的分析和实现64.8 游戏结束的判断84.9 游戏最终运行成果95 个人总结10参考文献10基于C + + 的2048游戏设计学生姓名: 学号: 学 院:数学与统计学院 专业:统计学指导教师: 职称:讲师摘 要:专业实习,是教学计划中的一门重要的必修课和综合实践课程,是培养学生的专业素质和实际能力的重要实践环节。通过此次的C + + 实习,掌握了程序设计的基本理论与方法,能够运用基本代码进行简单的程序设计,运行基本的游戏程序。关键词:C + + ;设计;程序The Game Design of 2048 Based on C + +Abstract:The

3、 important required course in the teaching plan and comprehensive practice curriculum, professional internships, is to cultivate the students professional quality and practical ability of the important link of practice. Through the C + + practice, we grasp the basic theory and method of program desi

4、gn, be able to use basic code to build simple program and run it.Key words:C + + ;Design;Program 前言这次实习是我们毕业前的一次实践性实习。为了拓展我们的知识面,增强我们对所学知识的应用能力,增加我们在社会竞争中的经验,锻炼和提高我们的综合素质,以便在以后毕业后能真正走入社会,并且能够在生活和工作中很好地处理各方面的问题,学校特地从北京达内科技集团聘请了专业的C + + 工程师讲师来对我们进行专业实训,进一步运用所学知识分析和解决实际专业问题,从而为就业打下良好的基础。 1 实习前的准备学校对我们的

5、实习非常重视,本着通过实习来检验本专业教学中存在的问题,改进教学工作的目的,提前就为我们联系好了与专业相关的单位来做实习培训。在正式进入机房实训前,讲师还专门做了一场关于实习内容的分享会,介绍了实习的基本情况、基本要求、实习项目的基本情况,学习和了解实习项目的相关文件和资料,帮助我们更系统地了解和熟悉接下来的实习课程内容。2 实习目的1培养理论联系实际的思想作风和工作作风;2培养作为计算机类工作人员的专业素质;3培养独立或与团队一起开展信息处理工作的基本业务能力。3 实习任务1通过实际操作,了解并逐步熟悉掌握C + +;2掌握常用软件的熟练操作,为今后所期望的专业方向做准备;3在教师指导下,利

6、用C + + 编程,完成独立的游戏编程任务;4最后在实习指导老师的指导下,参与信息处理与计算工作,完成一篇相关的实习论文(或实习记录)。4 实习内容4.1 2048游戏简介2048游戏是一款简单而流行的数字游戏,属于益智游戏。操作界面上有16个格子,初始时会有两个格子上安放了两个数字2,每次可以选择上下左右其中一个方向去滑动。每滑动一次,所有的数字方块都会往滑动的方向靠拢。两个相同数字方块撞在一起之后合并成为他们的和。每次操作之后会在空白的方格处随机生成一个2或者4(其他模式会有所改变),最终得到一个“2048”的方块就是胜利了。由于规则简单,各种版本和平台上均有该款游戏。相信有不少人都玩过它

7、,但是操作界面只有半个巴掌大的一个游戏,背后却要用到类似随机数的产生、大批量数据的处理、UI设计等任务,真的不算是一个很简单的工作。本次的游戏程序设计任务将运用C + + 来实现。4.2 2048模块需求分析首先分析了这款游戏的功能需求。2048游戏一般由以下几个模块来构成:1.矩阵方块;2.控制模块;3.计算模块;4.输出模块。每个模块来实现2048 游戏的各项功能:方向移动、方块合并、记录当前数据和输出计分结果、游戏胜利或失败后执行结束游戏操作等。4.3 UI界面的规划设计首先进行UI界面的规划设计。创建一个800600的背景模块,在模块左侧这里我们需要16个方块,按照44的规格排列整齐。

8、模块右侧的空白区域需要添加功能键:上、下、左、右、重置、关闭。另外我们还需要再添加一个计分标签,用来计算并输出游戏得分。最后按照模块功能与人的操作习惯,将标签分别排列在合适的位置。最终的UI界面如图1所示:图1UI界面(矩阵方块)设计完成以后,接着来开始程序代码的编写。4.4 头文件的需求分析首先分析需要用到的头文件。第一步需要生成随机数,第二步要为16个矩形模块填充随机数所对应的图片,第三步为操作界面添加背景,第四步在游戏成功或失败时即时输出信息。分析完成以后将所有需要用到的头文件都写入show.cpp文件里:#include show.h#include ui_show.h#include

9、#include#include#include#include QDialog(parent), ui(new Ui:Show)4.5 随机数的生成接下来我们开始写入生成两个随机数和分数从零开始的代码,同时加入图片加载和声明面板对象的代码: ui-setupUi(this); srand(time(NULL); for(int i=0;i4;i+) for(int j=0;jbackgroundRole(),QBrush(pix);/设置画板样式 this-setPalette(palette);/设置到我们的面板上void Show:sui() do int x=rand()%4; int

10、 y=rand()%4; if(mapxy=0) if(rand()%20=4) mapxy=4; else mapxy=2; break; while(1);4.6 图片资源的导入和加载将所有准备好的图片资源载入设计程序,以便后续的图片加载工作。随后我们进入为16个矩形模块和背景加载其各对应随机数图片的设计过程,这个模块以地址形式实现:void Show:paintEvent(QPaintEvent *) QImage img; img.load(:/image/+QString:number(map00)+.png); ui-show_1-setPixmap(QPixmap:fromIma

11、ge(img); img.load(:/image/+QString:number(map01)+.png); ui-show_2-setPixmap(QPixmap:fromImage(img); img.load(:/image/+QString:number(map02)+.png); ui-show_3-setPixmap(QPixmap:fromImage(img); img.load(:/image/+QString:number(map03)+.png); ui-show_4-setPixmap(QPixmap:fromImage(img); img.load(:/image/+

12、QString:number(map10)+.png); ui-show_5-setPixmap(QPixmap:fromImage(img); img.load(:/image/+QString:number(map11)+.png); ui-show_6-setPixmap(QPixmap:fromImage(img); img.load(:/image/+QString:number(map12)+.png); ui-show_7-setPixmap(QPixmap:fromImage(img); img.load(:/image/+QString:number(map13)+.png); ui-show_8-setPixmap(QPixmap:fromImage(img); img.load(:/image/+QString:number(map20)+.png); ui-show_9-setPixmap(QPixmap:fromImage(img); img.load(:/image/+QString:number(map21)+.png); ui-show_10-setPixmap(QPixmap:fromImage(img);

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 办公文档 > 教学/培训

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号