收藏 分销(赏)

校园导游咨询系统课程设计毕业论文.doc

上传人:胜**** 文档编号:2906378 上传时间:2024-06-11 格式:DOC 页数:27 大小:126.50KB
下载 相关 举报
校园导游咨询系统课程设计毕业论文.doc_第1页
第1页 / 共27页
校园导游咨询系统课程设计毕业论文.doc_第2页
第2页 / 共27页
校园导游咨询系统课程设计毕业论文.doc_第3页
第3页 / 共27页
校园导游咨询系统课程设计毕业论文.doc_第4页
第4页 / 共27页
校园导游咨询系统课程设计毕业论文.doc_第5页
第5页 / 共27页
点击查看更多>>
资源描述

1、湖南人文科技学院课程设计湖南人文科技学院数据结构课程设计课程名称:数据结构课程设计题 目:校园导游咨询系统年级/专业/班:14级信工系网工二班组长姓名(学号):成员姓名(学号) :数据结构课程设计 -校园导游咨询系统设计一、引 言随着现代社会生活节奏的加快,人们外出旅行以寻求放松的时间越来越多。考虑到游客不可能对所有景点都有所了解,因此可能无法找到游玩景点最省时,最高效的路径,而人工导游成本又过高,故使用C+,基于数据结构中图的相关算法与HGE引擎的窗口界面开发了“湖南人文科技学院导游咨询系统”。开发本系统目的在于为来访我校的游客提供一条最短游览路径,本系统从实际出发,通过对校园平面图的分析,

2、将其转化为数据并保存在系统中,因此系统提供的路径具有较大的可信性。而且本系统使用引擎创建窗口,更加方便,更加美观,更加易懂。本系统界面友好,提示信息充分,在实际使用过程中运行良好。二、设计目的与任务1、设计目的:通过本课程设计教学所要求达到的目的是:巩固和加深对数据结构的理解,通过上机实验、调试程序,加深对课本知识的理解;能熟练掌握几种基本数据结构的基本操作;能针对给定题目,选择相应的数据结构,分析并设计算法,进而给出问题的正确求解过程并编写代码实现。能简单的运用HGE引擎创建窗口,更好地实现校园导游咨询功能。2、设计任务:校园导游程序:用窗口界面实现以下功能:(1)景点信息的查询和简介;(2

3、)两景点间路径的查询;(3)增加、删除、更新有关景点和道路的信息。三、设计方案与实施(小三号、黑体、加粗) (一级标题)1、总体设计/写总体的设计思想根据题目要求,程序需要实现校园景点的信息查询和修改。首先使用HGE引擎创建基本的窗口界面,定义一个二维数组(40X40)来表示地图的属性,然后从文件中加载一张图片并用纹理句柄保存,再创建一个精灵,并绑定一张纹理图片等来将图片设置进窗口界面。再建立更新函数和渲染函数来进行逻辑处理(获取鼠标位置,获取图片的矩形区域,判断一个点是否在矩形中,判断鼠标是否在增加删除选项框内,判断鼠标是否在增加删除选项框内)和显示(背景,颜色,景点名字,景点坐标,景点简介

4、等)在窗口查询中,全是用鼠标来实现景点简介、景点间路径、景点和道路的增加、删除、更新等操作,方便易懂又美观。景点简介的查询是:将鼠标放在景点上就会实现;景点间路径的查询是:用鼠标在已有道路上点出起点和终点,就会自动计算出最短路径并且显示在右边的路径框上;景点和道路的增加、删除、更新:用鼠标点击已有的两个编辑按钮来实现对地图上的修改。2、详细设计(1)HGE的应用HGE *hge = 0;/定义一个全局变量:hge引擎指针hgeFont* pFont;hgeSprite *sprite = NULL;/精灵指针:(指向一张图片)HTEXTURE tex = NULL;/纹理句柄(对应一张图片)h

5、geSprite *sprite_1 = NULL;/精灵指针:(指向一张图片)HTEXTURE tex_1 = NULL;/纹理句柄(对应一张图片)hgeSprite *sprite_2 = NULL;/精灵指针:(指向一张图片)HTEXTURE tex_2 = NULL;/纹理句柄(对应一张图片)hgeSprite *sprite_menu = NULL;/精灵指针:开始按钮HTEXTURE tex_menu = NULL;/纹理句柄(开始)hgeSprite *sprite_3 = NULL;HTEXTURE tex_3 = NULL;hgeSprite* sprite_4 = NULL

6、;HTEXTURE tex_4 = NULL;hgeSprite* sprite_5 = NULL;HTEXTURE tex_5 = NULL;hgeSprite* sprite_6 = NULL;HTEXTURE tex_6 = NULL;GfxFont *g_pGfxFont0 = NULL;/中文显示GfxFont *g_pGfxFont1 = NULL;/中文显示GfxFont* p_Font = NULL; /创建一个字体指针GfxFont* p_Font_1 = NULL;GfxFont* p_Font_2 = NULL;float scaling_1 = 1.0f;/设置按钮缩放

7、比列float scaling_2 = 1.0f;float scaling_3 = 1.0f;(2)更新函数(逻辑处理):bool FrameFunc()hge-Effect_PlayEx(heffect, 20);/播放音效:if (hge-Input_KeyDown(HGEK_ESCAPE)/返回值为true,程序结束:按下ESC键return true;switch (gamestate)case Start:if (hge-Input_KeyDown(HGEK_LBUTTON)hge-Input_GetMousePos(&mouse_x, &mouse_y);/获取鼠标的位置spri

8、te_menu-GetBoundingBox(300, 100, &rect_menu);/获取图片的矩形区域if (rect_menu.TestPoint(mouse_x, mouse_y)/判断一个点是否在矩形中 gamestate = Play;b_state = false;break;case Play:if (hge-Input_KeyDown(HGEK_LBUTTON)if (changestate=Add)hge-Input_GetMousePos(&mouse_x, &mouse_y);x_1 = (int)(mouse_y - 100) / 16;/16表示图片的高y_1

9、= (int)(mouse_x - 100) / 16;/16表示图片的宽nx_1y_1 = 1;n1x_1y_1 = 1;else if (changestate = Del)hge-Input_GetMousePos(&mouse_x, &mouse_y);x_1 = (int)(mouse_y - 100) / 16;/16表示图片的高y_1 = (int)(mouse_x - 100) / 16;/16表示图片的宽nx_1y_1 = 0;n1x_1y_1 = 0;hge-Input_GetMousePos(&mouse_x, &mouse_y);/获取鼠标的位置sprite_5-Get

10、BoundingBox(750, 500, &rect_5);/获取图片的矩形区域sprite_6-GetBoundingBox(750, 550, &rect_6);if (rect_5.TestPoint(mouse_x, mouse_y)/判断鼠标是否在增加删除选项框内scaling_1 = 1.2f;changestate = Add;else if (rect_6.TestPoint(mouse_x, mouse_y)scaling_2 = 1.2f;changestate = Del;if (hge-Input_KeyUp(HGEK_LBUTTON)hge-Input_GetMou

11、sePos(&mouse_x, &mouse_y);/获取鼠标的位置sprite_5-GetBoundingBox(750, 500, &rect_5);/获取图片的矩形区域sprite_6-GetBoundingBox(750, 550, &rect_6);if (rect_5.TestPoint(mouse_x, mouse_y)/判断鼠标是否在增加删除选项框内scaling_1 = 1.0f;else if (rect_6.TestPoint(mouse_x, mouse_y)scaling_2 = 1.0f;hge-Input_GetMousePos(&mouse_x, &mouse_

12、y);if (mouse_x 510 & mouse_x 410 & mouse_y 510 & mouse_x 300 & mouse_y 410 & mouse_x 310 & mouse_y 225 & mouse_x 130 & mouse_y 310 & mouse_x 540 & mouse_y 400 & mouse_x 610 & mouse_y 315 & mouse_x 430 & mouse_y 200 & mouse_x 430 & mouse_y 400 & mouse_x 405 & mouse_y 645 & mouse_x 380 & mouse_y Input

13、_GetKeyState(HGEK_RBUTTON) & b_state = false)/判断鼠标左键是否按下,按下开始导游b_state = TRUE;hge-Input_GetMousePos(&mouse_x, &mouse_y);end_x = (int)(mouse_y - 100) / 16;/16表示图片的高end_y = (int)(mouse_x - 100) / 16;/16表示图片的宽if (hge-Input_GetKeyState(HGEK_SPACE)step = 0;memcpy(n, n1, sizeof(n);x = end_x;y = end_y;poin

14、t *start = (point*)malloc(sizeof(point);/起点start-x = x;start-y = y;nxy = 3;if (x != 1 & y != 1)n11 = 0;q.push(start);if (b_state)while (!q.empty()point *front = q.front();q.pop();/弹出队头 if (front-x = end_x &front-y = end_y)flag = 1;/cout成功找到出路.最少需要xfront-y-2步。如下所示:xfront-y = -6;/cout倒退回去:x,y; point *

15、lastPoint = front;front = front-last;while (front-x != x) | (front-y != y)/coutx,y; if (lastPoint-x - front-x = 1)nfront-xfront-y = -1;else if (lastPoint-x - front-x = -1)nfront-xfront-y = -2;else if (lastPoint-y - front-y = 1)nfront-xfront-y = -3;elsenfront-xfront-y = -4;lastPoint = front;front = f

16、ront-last;/coutx,yendl; nxy = -5;break;elsefor (int i = 0; i x = front-x + aspecti0;temp-y = front-y + aspecti1;if (temp-x = 0 & temp-xy = 0 & temp-yxtemp-y = 0)temp-last = front;q.push(temp);ntemp-xtemp-y = nfront-xfront-y + 1;if (!flag);/cout无路可走!endl; elseb_state = false;for (int i = 0; i 40; +i)

17、for (int j = 0; j 40; +j)if (nijGfx_BeginScene();/通知系统开始绘制hge-Gfx_Clear(0xFFFFFFFF);/ 清屏(屏幕的背景颜色,每两位:红、绿、蓝)switch (gamestate)/自己的绘制:case Start:sprite_4-Render(0, 0);sprite_menu-RenderEx(300, 100,0.0f,1.0f,1.0f);break;case Play:sprite_3-Render(0, 0);/绘制背景sprite_5-RenderEx(795, 515, 0.0f, scaling_1, s

18、caling_1);/绘制按钮sprite_6-RenderEx(795, 565, 0.0f, scaling_2, scaling_2 );/绘制按钮for (int i = 0; i40; +i)/遍历数组的元素并根据其值绘制图形for (int j = 0; jRender(j*16,i*16);break;case 1:/第一个参数表示x坐标,第二参数y坐标sprite-Render(100 + j * 16, 100 + i * 16);break;case 2:/第一个参数表示x坐标,第二参数y坐标sprite_1-Render(100 + j * 16, 100 + i * 1

19、6);break;case 3:/第一个参数表示x坐标,第二参数y坐标sprite_2-Render(100 + j * 16, 100 + i * 16);break;p_Font_2-Render(750, 400, L距离 米);p_Font_2-Print(790, 400, %d, step*10);p_Font_1-Render(200, 50, L湖南人文科技学院导游图);p_Font-Render(248, 150, L阳n光n公n寓); /设置字体的位置p_Font-Render(220, 450, L体n育n馆); /设置字体的位置p_Font-Render(335, 45

20、0, L田n径n场); /设置字体的位置p_Font-Render(525, 425, L海园广场); /设置字体的位置p_Font-Render(530, 320, L致远楼); /设置字体的位置p_Font-Render(430, 330, L图n书n馆); /设置字体的位置p_Font-Render(420, 425, L生活n服务n大楼); /设置字体的位置p_Font-Render(420, 630, L逸n夫n楼); /设置字体的位置p_Font-Render(330, 560, L惠风n篮球场); /设置字体的位置p_Font-Render(670, 360, L毓n师n园);

21、/设置字体的位置if (IsShow)p_Font_2-Render(mouse_x,mouse_y,L休闲散步的最佳场所);if (IsShow_1)p_Font_2-Render(mouse_x, mouse_y, L全校最大的一栋综合教学楼,n各系上课得主要场所);if (IsShow_2)p_Font_2-Render(mouse_x, mouse_y, L学校的心脏,藏有图书上百万册,n三楼为咖啡书吧,环境优雅);if (IsShow_3)p_Font_2-Render(mouse_x, mouse_y, L全校最豪华的学生公寓,共有六栋,n有标准四人寝和豪华两人寝);if (IsS

22、how_4)p_Font_2-Render(mouse_x, mouse_y, L全校最大篮球场,挥洒汗水的赛场);if (IsShow_5)p_Font_2-Render(mouse_x, mouse_y, L学校最具艺术色彩的一栋大楼);if (IsShow_6)p_Font_2-Render(mouse_x, mouse_y, L现在化塑胶标准报道,人造草坪,n适宜锻炼身体的场所);if (IsShow_7)p_Font_2-Render(mouse_x, mouse_y, L举办各种大型比赛和开展大型活动的场所,n能容纳五千多人);if (IsShow_8)p_Font_2-Rende

23、r(mouse_x, mouse_y, L为学生和老师提供生活服务的地方);if (IsShow_9)p_Font_2-Render(mouse_x, mouse_y, L绿树成荫,幽静小道,适宜读书和休息);break;hge-Gfx_EndScene();/通知系统结束绘制return false;(4)主函数(入口函数)int WINAPI WinMain(HINSTANCE, HINSTANCE, LPSTR, int)hge = hgeCreate(HGE_VERSION);/hge指针赋值。hge-System_SetState(HGE_FRAMEFUNC, FrameFunc);

24、/ 设置自己的更新函数/第二个参数是函数的名字hge-System_SetState(HGE_RENDERFUNC, RenderFunc);/设置自己的渲染函数.第二个参数是函数的名字hge-System_SetState(HGE_TITLE, 校园导游系统);/ 设置窗口标题.第二个参数标题名hge-System_SetState(HGE_WINDOWED, true);/设置窗口模式,true为窗口模式,false全屏hge-System_SetState(HGE_SCREENWIDTH,900);/设置窗口宽和高hge-System_SetState(HGE_SCREENHEIGHT,

25、800);hge-System_SetState(HGE_FPS, 60);/设置窗口的刷新率(每一秒钟渲染的次数)hge-System_SetState(HGE_HIDEMOUSE, false);/是否隐藏鼠标hge-System_SetState(HGE_USESOUND, true);/ 设置是否开启声音/系统初始化if (hge-System_Initiate()p_Font = new GfxFont(宋体, 20); /20表示字体大小p_Font-SetColor(0xff000000);/设置颜色p_Font_1 = new GfxFont(华文行楷,40);p_Font_1

26、-SetColor(0xff000000);p_Font_2 = new GfxFont(楷体,20);p_Font_2-SetColor(0xffff0000);/自己的初始化:/从文件中加载一张图片并用纹理句柄保存tex_3 = hge-Texture_Load(wall.jpg);sprite_3 = new hgeSprite(tex_3, 0, 0, 900, 800);tex = hge-Texture_Load(blue.png);sprite = new hgeSprite(tex, 0, 0, 16, 16);/创建一个精灵,并绑定一张纹理图片,蓝色tex_1 = hge-T

27、exture_Load(yellow.png);/从文件中加载一张图片并用纹理句柄保存sprite_1 = new hgeSprite(tex_1, 0, 0, 16, 16);/创建一个精灵,并绑定一张纹理图片tex_5 = hge-Texture_Load(delete.jpg);sprite_5 = new hgeSprite(tex_5, 0, 0, 90, 30);sprite_5-SetHotSpot(45, 15);tex_6 = hge-Texture_Load(add.jpg);sprite_6 = new hgeSprite(tex_6, 0, 0, 90, 30);spr

28、ite_6-SetHotSpot(45, 15);tex_4 = hge-Texture_Load(school.jpg);/从文件中加载一张图片并用纹理句柄保存sprite_4 = new hgeSprite(tex_4, 0, 0, 900, 800);/创建一个精灵,并绑定一张纹理图片tex_2 = hge-Texture_Load(red.png);/从文件中加载一张图片并用纹理句柄保存sprite_2 = new hgeSprite(tex_2, 0, 0, 16, 16);/创建一个精灵,并绑定一张纹理图片tex_menu = hge-Texture_Load(start.jpg)

29、;/从文件中加载一张图片并用纹理句柄保存sprite_menu = new hgeSprite(tex_menu, 0, 0, 260, 80);/创建一个精灵,并绑定一张纹理图片heffect_1 = hge-Effect_Load(button.mp3);memcpy(n1, n, sizeof(n);point *start = (point*)malloc(sizeof(point);/起点 start-x = x;start-y = y;nxy = 3;q.push(start);/启动系统:hge-System_Start();elseMessageBoxA(NULL, hge-S

30、ystem_GetErrorMessage(), Error, MB_OK | MB_ICONERROR | MB_APPLMODAL);/程序结束时,资源的释放:/系统关闭和hge指针的释放hge-System_Shutdown();hge-Release();return 0;3、程序调试与体会/对整个程序在高度过程中的一些体会(二级标题 程序经过调试完成了对景点简介信息,景点之间的路径的查询以及对景点信息的增加,删除和更新。 本次程序设计是对全学期数据结构课程学习的一次实践,通过亲自编写编译调试程序,逐步掌握了编程方法。也说明了一个深刻道理,知识只有在实践中才能充分理解并运用。从传统的被

31、动接受变为主动探索,起初不是很适应,什么也不懂,茫然无措。渐渐地开始自己编写时候,发现了其中之乐趣。我相信,这样的学习坚持到底,必将有所成就。设计过程需要查找各种资料,在百度等搜索工具与指导老师的帮助下,在自己理解的基础上参照方法写出属于自己的程序。虽然过程中出现多次程序报错,在同学的指导和老师的帮助下顺利完成,值得为之欣喜。其中编程过程中显露出来的问题也必须引起高度重视,在今后的学习中必当万分注意绝不再犯。比如细心问题,有次的一个小小的“取地址符”没有添加,导致整个程序无法运行,检查了好久才发现。所以说,编程是个细活,只有严谨的态度,细心的思路以及良好的学习习惯,最终才能收获成功的喜悦。最后

32、感谢在编程过程中给予充分帮助的老师和同学们,这又使我认识到团队力量的强大作用。加强团队协作也是今后程序设计道路上的必备能力。4、运行结果四、结 论经过这次课程设计,我对程序中算法的概念理解的更加透彻。算法是程序中必不可少的部分,它是指解题方案的准确而完整的描述,是一系列解决问题的清晰指令,算法代表着用系统的方法描述解决问题的策略机制。也就是说,能够对一定规范的输入,在有限时间内获得所要求的输出。如果一个算法有缺陷,或不适合于某个问题,执行这个算法将不会解决这个问题。不同的算法可能用不同的时间、空间或效率来完成同样的任务。同时,在选择算法时必须考虑算法的时间复杂度和空间复杂度,这样才能让程序正常

33、高效的运行。在这次的课程设计中,我们认识到了我们的不足和知识的广阔。使我们对我们课本的知识有了新的理解,让我们对C语言,C+和数据结构的理解更深,把我们学到的知识串通起来。对于校园导游咨询系统,让我们把平时古板的知识用在了现实的社会实践中,对我们学习新的知识有了巨大的帮助,提高了我们的积极性。对我们把学到的知识用在生活中起到了作用,打到学以致用。通过这次课程设计,我们学到了很多,有专业的知识,有分析的方法;有新的认识(HGE引擎),有学习的方向;有知识的充实,有心灵的升华。实践是检验真理的唯一方法。五、参考文献1数据结构(C语言版) 严蔚敏 清华大学出版社2数据结构课程设计 舒仕华 机械工业出

34、版社六、附录(源代码)#include hge.h#include #include #include #include#include#includegfxFont.h#includeusing namespace std;bool IsShow = false;bool IsShow_1 = false;/判断是否显示bool IsShow_2 = false;bool IsShow_3 = false;bool IsShow_4 = false;bool IsShow_5 = false;bool IsShow_6 = false;bool IsShow_7 = false;bool I

35、sShow_8 = false;bool IsShow_9 = false;enum ChangeState Del, Add, Usl ;ChangeState changestate = Usl;HGE *hge = 0;/定义一个全局变量:hge引擎指针hgeFont* pFont;hgeSprite *sprite = NULL;/精灵指针:(指向一张图片)HTEXTURE tex = NULL;/纹理句柄(对应一张图片)hgeSprite *sprite_1 = NULL;/精灵指针:(指向一张图片)HTEXTURE tex_1 = NULL;/纹理句柄(对应一张图片)hgeSpri

36、te *sprite_2 = NULL;/精灵指针:(指向一张图片)HTEXTURE tex_2 = NULL;/纹理句柄(对应一张图片)hgeSprite *sprite_menu = NULL;/精灵指针:开始按钮HTEXTURE tex_menu = NULL;/纹理句柄(开始)hgeSprite *sprite_3 = NULL;HTEXTURE tex_3 = NULL;hgeSprite* sprite_4 = NULL;HTEXTURE tex_4 = NULL;hgeSprite* sprite_5 = NULL;HTEXTURE tex_5 = NULL;hgeSprite*

37、 sprite_6 = NULL;HTEXTURE tex_6 = NULL;GfxFont *g_pGfxFont0 = NULL;/中文显示GfxFont *g_pGfxFont1 = NULL;/中文显示GfxFont* p_Font = NULL; /创建一个字体指针GfxFont* p_Font_1 = NULL;GfxFont* p_Font_2 = NULL;float scaling_1 = 1.0f;/设置按钮缩放比列float scaling_2 = 1.0f;float scaling_3 = 1.0f;/定义一个二维数组:表示地图的属性int n14040 = 0 ;int n4040 = 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0,

展开阅读全文
部分上传会员的收益排行 01、路***(¥15400+),02、曲****(¥15300+),
03、wei****016(¥13200+),04、大***流(¥12600+),
05、Fis****915(¥4200+),06、h****i(¥4100+),
07、Q**(¥3400+),08、自******点(¥2400+),
09、h*****x(¥1400+),10、c****e(¥1100+),
11、be*****ha(¥800+),12、13********8(¥800+)。
相似文档                                   自信AI助手自信AI助手
搜索标签

当前位置:首页 > 学术论文 > 毕业论文/毕业设计

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服