前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >玩玩webgame开发(4):游戏数据结构设计[通俗易懂]

玩玩webgame开发(4):游戏数据结构设计[通俗易懂]

作者头像
全栈程序员站长
发布2022-09-05 11:42:00
3980
发布2022-09-05 11:42:00
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

很久没做更新了。最近比较忙碌,手头的webgame也都放下。最近很想念我的小webgame了,回来继续写。

上篇玩玩webgame开发(3):自动战斗实现以及一些游戏细节(下)http://playfish.iteye.com/blog/267275 在高峰期时候发表的,结果被火速沉底了。。。汗

好了,不小心有说了好多废话,言归正传。 ============= 数据结构设计是门高深的学问,而游戏的数据结构设计,那显然,也是一门很高深的学问(–||好废话。。),数据结构应该是整个游戏的骨架所在,而游戏数据平衡,(另一门高深的学问。。)跟这游戏的数据结构息息相关。本文只是从自己做的一个小游戏出发,简要的介绍一下我的一个简单的游戏的数据结构设计思路。

一个游戏几个基本的要素:

  • 地图
  • 游戏角色
  • 怪物
  • 物品
  • 建筑

先从地图说起

游戏都在地图上进行的。地图的基本要素包括:地图元素(即每一个地图坐标格子上的元素),不可进入的位置等。其他的还包括一些基本信息。我的地图数据结构设计如下:

代码语言:javascript
复制
	var defaultMap = {


		mapName	:	'迷雾森林',


		mapLevel:	1,


		mapData	: [


					['f','t','t','t','t','t','w','f','r','f','w','f','r','f','r','f','t','t','r','f','r','t','t'],


					['g','f','f','w','f','r','f','w','f','r','f','f','r','f','r','f','t','t','r','f','r','t','t'],


					['g','f','f','f','f','w','f','r','f','w','f','r','f','r','f','r','t','t','r','f','r','t','t'],


					['g','g','g','g','f','f','w','f','f','w','f','r','f','r','f','r','t','t','r','f','r','t','t'],


					['g','f','f','f','r','f','w','f','r','f','w','f','r','f','f','r','t','t','r','f','r','t','t'],


					['g','f','f','f','r','f','w','f','r','f','w','f','r','f','r','f','t','t','r','f','r','t','t'],


					['g','f','f','f','r','r','f','w','f','f','w','f','r','f','r','f','t','t','r','f','r','t','t'],


					['g','f','f','f','r','f','w','f','r','f','w','f','r','f','f','r','t','t','r','f','r','t','t'],


					['g','f','f','f','f','w','f','r','f','w','f','r','f','r','f','r','t','t','r','f','r','t','t'],


					['g','g','g','g','f','f','w','f','f','w','f','r','f','r','f','r','f','f','f','f','r','t','t'],


					['g','f','f','f','r','f','w','f','r','f','w','f','f','f','f','f','f','f','f','f','r','t','t'],


					['g','f','f','f','r','f','w','f','r','f','w','f','f','f','r','f','t','t','f','f','r','t','t'],


					['g','f','f','f','r','r','f','w','f','f','w','f','r','f','r','f','t','t','r','f','r','t','t'],


					['g','f','f','f','r','f','w','f','r','f','w','f','r','f','f','r','t','t','r','f','r','t','t'],


					['g','f','f','f','f','w','f','r','f','w','f','r','f','r','f','r','t','t','r','f','r','t','t'],


					['g','g','g','g','f','f','w','f','f','w','f','r','f','r','f','r','t','t','r','f','r','t','t'],


					['g','f','f','f','r','f','w','f','r','f','w','f','r','f','f','r','t','t','r','f','r','t','t'],


					['g','f','f','f','r','f','w','f','r','f','w','f','r','f','r','f','t','t','r','f','r','t','t'],


					['g','f','f','f','r','r','f','w','f','f','w','f','r','f','r','f','t','t','r','f','r','t','t'],


					['g','f','f','f','r','f','w','f','r','f','w','f','r','f','f','r','t','t','r','f','r','t','t'],


					['g','f','f','f','r','f','w','f','f','w','f','r','f','r','f','r','t','t','r','f','r','t','t']


				],


		immovable:	['t','r']


	};

这是个很简单的地图结构,包括的几个信息:地图名称,地图等级,地图元素,不可移动的位置。最后生成的展示效果如下(实际界面大很多,这里只是部分):

关于地图生成以及战争迷雾的部分,可以参看这个系列文章的前2篇。至于在地图上出现的物品,角色,怪物,建筑,并没有放在地图的数据里面,因为我觉得这是属于不同角色的数据,是应该分开的。这样的数据结构可以满足这样的需求:地图按照数据显示,对于指定的地图元素,角色不能进入。

接下来是游戏角色

代码语言:javascript
复制
	var bobo = {
		pos		:	{X:1,	Y:1},
		name	:	'拉拉',
		money	:	0,		//新增加金钱
		hp		:	100,	//full hp
		curHp	:	100,	//current hp
		level	:	0,			
		exp		:	19,
		ap		:	15,		//attack power
		def		:	1,		//defence
		speed	:	3,		
		luck	:	15,
		eyeshot	:	2,		//视野
		type	:	'bobo',
		file	:	'baozi',
		img		:	$('<img class="bobo" title="拉拉" src="images/bobo/baozi/lv0/common.gif" />')
	};

pos指角色在地图上的坐标,其它的就是一些常见的数据了,包括名称,金钱,满血hp,当前的hp,等级,经验,攻击,防御,速度,幸运,视野,其它的类型,文件,img属于我自己定义的一些结构,用于获得特定状态下的包子的图片。

设计一个这样的数据结构并不难,自己爱怎么设定就怎么设定,呵呵。不过关键的问题在于数据平衡,设置得很bt的数据可以开始玩的时候很爽,但是一结束玩家马上就会失去兴趣,所以,合适的数值以及成长曲线才会保证耐玩度。我个人是喜欢很小的数据,这样玩家自己计算的时候简单,而且数据平衡比较好做。我平时很经常玩一些war3的rpg,只要进去里面的人物或者是物品设定数字都是按百的,alt+q。顺便废话一下我喜欢的元素魔法之战这个。

怪物的数据设计

代码语言:javascript
复制
	var monsters = [
			{	
				id		:	0,
				name	:	'青蛙',
				hp		:	30,
				curHp	:	30,			//记录怪物当前血量,战斗结束后自动回复为hp
			 	level	:	0,
				exp		:	5,	
				ap		:	10,	
				def		:	0,	
				speed	:	5,
				luck	:	15,	
				type	:	'monster',	
				file	:	'qingwa',
				items	:	[					//掉落物品
					{id:0,drop:0.4}
				],
				img		:	$('<img class="monster" title="青蛙" src="images/monster/qingwa/lv0/common.gif" />')
			}
	];

和游戏角色的数据结构不同,它有额外添加1个id以及一个items数组,id表示怪物类型,因为怪物会在地图上出现很多不同种类的怪物,通过id来区分不同的怪物。items数组,表示这个怪物身上有多大的概率会掉那种类型物品。items数组内的id表示物品的id。

一个怪物需要分布在地图上的各个位置,我目前觉得最简单的方式就是:

代码语言:javascript
复制
	var mapMonsters = [
		{	
			pos		:	{	X:1,	Y:8	},
			id		:	0
		},
		{	
			pos		:	{	X:5,	Y:5	},
			id		:	0
		},
		{	
			pos		:	{	X:4,	Y:5	},
			id		:	0
		}
	];

哪个位置上哪个怪物,简单明了。

====未完待续,明晚继续

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/136873.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年6月2,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 先从地图说起
  • 接下来是游戏角色
  • 怪物的数据设计
相关产品与服务
图数据库 KonisGraph
图数据库 KonisGraph(TencentDB for KonisGraph)是一种云端图数据库服务,基于腾讯在海量图数据上的实践经验,提供一站式海量图数据存储、管理、实时查询、计算、可视化分析能力;KonisGraph 支持属性图模型和 TinkerPop Gremlin 查询语言,能够帮助用户快速完成对图数据的建模、查询和可视化分析。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档