程序设计综合实践报告大学论文Word下载.docx
- 文档编号:13729412
- 上传时间:2022-10-13
- 格式:DOCX
- 页数:32
- 大小:26.99KB
程序设计综合实践报告大学论文Word下载.docx
《程序设计综合实践报告大学论文Word下载.docx》由会员分享,可在线阅读,更多相关《程序设计综合实践报告大学论文Word下载.docx(32页珍藏版)》请在冰豆网上搜索。
2.2双缓冲1
3.总体设计与详细设计2
3.1系统模块划分2
3.2主要功能模块2
4.编码实现12
5.实训中遇到的主要问题及解决方法20
6.实训体会20
1.概述
项目:
飞机大战
主要功能:
本款基于MFC平台所制作的游戏,具有极大的休闲娱乐功能。
玩家通过操纵我机,通过发射子弹机会敌机来积分,分数越高说明了玩家坚持的越长。
游戏开始界面向玩家进行了游戏按键的功能说明,游戏中设置暂停按键,可以方便玩家继续游戏。
游戏还自带无敌模式,以及我机大招,极大地提高了游戏的可玩性。
2.相关技术
本程序主要运用了链表和双缓冲的技术。
链表的应用方便了对数据成员的访问和处理,简化了代码,支持插入和移除表中任意位置上的节点;
双缓冲主要用于图像的处理,在内存中重新绘图后复制到前台,同时禁止背景刷新,避免因图像刷新过于频繁导致画面出现闪烁现象。
2.1数据链表
链表是一种物理存储单元上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的。
使用链表结构可以充分利用计算机内存空间,实现灵活的内存动态管理。
由于常规数组排列关联项目的方式可能不同于这些数据项目在记忆体或磁盘上顺序,数据的存取往往要在不同的排列顺序中转换,因此链表最大的优点是允许插入和移除表上任意位置上的节点。
在程序运行过程中,根据游戏对象的种类划分不同的链表,每个链表单一的存储一类数据,在进行处理、绘图时,通过对链表的遍历,实现对数据的访问,再根据所要实现的功能,对不同的对象做出不同的处理,对数据成员的插入和移除也变得轻松了许多。
2.2双缓冲
在图形图象处理编程过程中,双缓冲是一种基本的技术。
窗体在响应WM_PAINT消息的时候要进行复杂的图形处理,那么窗体在重绘时由于过频的刷新会引起闪烁现象。
解决这一问题的有效方法就是双缓冲技术。
因为窗体在刷新时,总要有一个擦除原来图象的过程OnEraseBkgnd,它利用背景色填充窗体绘图区,然后在调用新的绘图代码进行重绘,这样一擦一写造成了图象颜色的反差。
当WM_PAINT的响应很频繁的时候,这种反差也就越发明显。
于是我们就看到了闪烁现象。
双缓冲我们会很自然的想到,避免背景色的填充是最直接的办法。
但是那样的话,窗体上会变的一团糟。
因为每次绘制图象的时候都没有将原来的图象清除,造成了图象的残留,于是窗体重绘时,画面往往会变的乱七八糟。
所以单纯的禁止背景重绘是不够的。
我们还要进行重新绘图,但要求速度很快,于是我们想到了使用BitBlt函数。
它可以支持图形块的复制,速度很快。
我们可以先在内存中作图,然后用此函数将做好的图复制到前台,同时禁止背景刷新,这样就消除了闪烁。
以上也就是双缓冲绘图的基本的思路。
3.总体设计与详细设计
3.1系统模块划分
游戏规则子系统
模块名称
功能简述
人工智能
人机对战规则的实现
游戏子系统
应用程序对象
游戏程序的加载、游戏对象的绘制、游戏规则的调用、玩家的键盘事件获取
游戏对象
各个游戏对象的抽象父类
战机对象
战机类
敌机对象
敌机类、大敌机类
炸弹对象
炸弹1类、炸弹2类
爆炸对象
爆炸类
文字对象
文字类
3.2主要功能模块
功能描述
人机对战规则规则
接口与属性
voidAI(void);
数据结构
与算法
(注:
红色加粗部分为新加代码!
)
voidCPlaneGameView:
:
AI()
{
if(m_pMe==NULL)
return;
//检测四个方向键,移动战机
for(inti=0;
i<
4;
i++)
{
intnMeMotion=0;
m_pMe->
SetVerMotion(0);
SetHorMotion(0);
//初始化
nMeMotion=GetKey(VK_UP);
if(nMeMotion==1)
m_pMe->
SetVerMotion
(1);
nMeMotion=GetKey(VK_DOWN);
SetVerMotion(-1);
nMeMotion=GetKey(VK_RIGHT);
SetHorMotion
(1);
nMeMotion=GetKey(VK_LEFT);
SetHorMotion(-1);
}
//随机产生小敌机
staticintnCreator=rand()%5+10;
if(nCreator<
=0)
nCreator=rand()%5+10;
m_ObjList[enEnemy].AddTail(newCEnemy);
nCreator--;
//产生大敌机
if(m_pMe!
=NULL&
&
score>
=1000&
Booswait<
=0)
CGameObject*pObj;
//PlaySound((LPCTSTR)IDR_WAVE5,AfxGetInstanceHandle(),SND_RESOURCE|SND_ASYNC);
m_ObjList[enBOSS].AddTail(newBOSS);
Booswait=rand()%300+10;
Booswait--;
//产生战机导弹PlaneGame
if(GetKey(VK_SPACE)==1)//按下了空格键
if(m_pMe!
=NULL&
m_pMe->
Fired())
{
//PlaySound((LPCTSTR)IDR_WAVE3,AfxGetInstanceHandle(),SND_RESOURCE|SND_ASYNC);
CPointpt=m_pMe->
GetPoint();
m_ObjList[enBomb].AddTail(newCBomb(pt.x,pt.y-10,3));
m_ObjList[enBomb].AddTail(newCBomb(pt.x+15,pt.y-10,3));
m_ObjList[enBomb].AddTail(newCBomb(pt.x+22,pt.y-40,0));
m_ObjList[enBomb].AddTail(newCBomb(pt.x+37,pt.y-40,0));
m_ObjList[enBomb].AddTail(newCBomb(pt.x+45,pt.y-10,-3));
m_ObjList[enBomb].AddTail(newCBomb(pt.x+60,pt.y-10,-3));
}
}
//无敌模式
if(GetKey('
A'
)==1)
wd++;
//小敌机发射子弹
CPointPlanePt=m_pMe->
for(POSITIONePos=m_ObjList[enEnemy].GetHeadPosition();
ePos!
=NULL;
CEnemy*pEnemy=(CEnemy*)m_ObjList[enEnemy].GetNext(ePos);
if(!
pEnemy->
continue;
CPointePt=pEnemy->
BOOLby=FALSE;
//敌机在战机前面
if(pEnemy->
GetMontion()==1&
ePt.y<
PlanePt.y)
by=TRUE;
//敌机在战机后面
GetMontion()==-1&
ePt.y>
by=TRUE;
if(by&
ePt.x>
=PlanePt.x&
ePt.x<
PlanePt.x+CMyPlane:
PLANE_WIDTH)
m_ObjList[enBall].AddTail(newCBall(ePt.x+10,ePt.y+10,pEnemy->
GetMontion()));
//小敌机子弹炸掉战机
POSITIONbPos1=NULL,bPos2=NULL;
CRectmRect=m_pMe->
GetRect();
for(bPos1=m_ObjList[enBall].GetHeadPosition();
(bPos2=bPos1)!
=NULL;
CBall*pBall=(CBall*)m_ObjList[enBall].GetNext(bPos1);
CRectbRect=pBall->
CRecttmpRect;
if(tmpRect.IntersectRect(&
bRect,mRect))
if(wd%2==0)
{
life-=5;
}
//删除子弹
m_ObjList[enBall].RemoveAt(bPos2);
deletepBall;
//添加爆炸效果
m_ObjList[enExplosion].AddTail(
newCExplosion(mRect.left,mRect.top)
);
if(life<
//添加爆炸效果
m_ObjList[enExplosion].AddTail(
newCExplosion(mRect.left,mRect.top)
);
//删除战机
deletem_pMe;
m_pMe=NULL;
break;
//我机与小敌机相遇互相摧毁
POSITIONcoPos1=NULL,coPos2=NULL;
for(coPos1=m_ObjList[enEnemy].GetHeadPosition();
(coPos2=coPos1)!
CEnemy*pEnemy=(CEnemy*)m_ObjList[enEnemy].GetNext(coPos1);
CRecteRect=pEnemy->
if(tmpRect.IntersectRect(&
eRect,mRect))
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 程序设计 综合 实践 报告 大学 论文