一份比较详细的MCBE村庄机制解析

文章推薦指數: 80 %
投票人數:10人

这篇专栏会较为详细地阐述MCBE中村庄的产生与消亡,村庄范围与中心的变迁,POI的生命周期等过程。

... minecraft 中文wiki--村民. 一份比较详细的MCBE村庄机制解析SAC_Official 关注专栏/游戏/单机游戏/一份比较详细的MCBE村庄机制解析一份比较详细的MCBE村庄机制解析 单机游戏 2020-04-1220:02--阅读· --喜欢· --评论 SAC_Official粉丝:2504文章:8 关注这篇专栏会较为详细地阐述MCBE中村庄的产生与消亡,村庄范围与中心的变迁,POI的生命周期等过程。

POIPOI就是(pointofinterst),也就是村民的兴趣点,POI一共有四类(其实是三类)床集会点(钟)工作方块(讲台等等)未定义一个POI里面存的信息包括但不限于:坐标类型它所属的村庄它所属者的数量它的所属者的数量上限村庄管理器MCBE中单维度的所有村庄都是由一个叫做村庄管理器的东西来管理的。

这个管理器管理着村庄的运行,管理POI的状态,村庄状态的更新,铁傀儡的刷新,劫掠的产生等等等。

一个维度有且仅有一个村庄管理器村庄管理器做的最基本的事情是在你打开(关闭)存档的时候把存档内部的村庄信息加载进游戏(把游戏中的村庄信息写入存档)。

下面是村庄管理器所包含的数据:一个方块位置的列表(BlcokPositionList) 一个村庄列表一个未分配的POI列表(clusterPOIlist)一个已经分配的POI列表(clusterPOIlist)其它信息(如流浪商人的调度器)村庄管理器的结构村庄你在游戏中看到的村庄是一些村民和一些方块的集合,但是游戏内部的的村庄其实也是一坨数据的集合,这些数据包括但不限于:未被绑定的POI列表(unclaimedPOIList)实体列表(包括村民,铁傀儡,猫等)(actorList)村民和POI的绑定列表(claimedPOIList)村庄UID(uid)几个时钟,包括繁殖相关,劫掠相关,自动存档相关其它和劫掠相关数据(略)居民系统(DwellerSystem)居民系统定义了村民的作息和行为,这使得不同状态的村民在不同的时间内做不同的事情minecraft中文wiki--村民对于居民系统,我们仅需要知道,村民会在特定时候寻找以它为中心32*8*32的POI。

村庄管理器的数据更新每个游戏刻(gt)村庄管理器都和区块,和方块实体一样在更新(说白了就是执行tick()函数),比较特殊的一点是,村庄管理器不光要更新自己,还要更新维度内的每一个村庄(执行每一个村庄的tick()函数),下面是村庄相关更新和区块更新之间的一个层级关系:更新层次这里区块更新不是重点,不赘述,但是可以看到村庄管理器的更新是不依托于区块加载的。

那么村庄管理器的更新到底做了什么?每个游戏刻村庄管理器都试图进行如下操作:1.尝试移除村庄下面是操作的步骤遍历村庄列表找到可以移除的村庄,这样的村庄的条件包括但不限于:人口数量过少(0个)床的数量过少其它条件对可以移除的村庄内部的所有POI进行回收(uncluster),也就是把该村庄的所有POI从村庄管理器的已分配POI列表中移除2.受理村民的POI查询请求上文提到村民会在特定时候寻找以它为中心32*8*32的POI,但是村民的工作仅仅是向村庄管理器提出查询请求,查询请求里面装的是村民的坐标,这些坐标会被暂存到村庄管理器的方块位置的列表(BlcokPositionList)中。

而受理村民的POI查询请求要做的就是帮助村民查询:从列表中取出一个坐标遍历以该坐标32*8*32的区域找到合适的方块就根据该方块的信息创建POI并放入村庄管理器的未分配列表需要注意的是,每个游戏刻村庄管理器只受理一个请求(即查询一次),如果这个区域的合适的方块超过1024个会直接停止查询。

这一步就是创建POI的过程,但是这个过程结束的时候新创建的POI还不属于任何村庄,于是下面要做的就是把未分配的POI分配给各个村庄3.尝试分配POI创建的POI一直放着也不是办法,总要分发给村庄,这一步执行的就是这个过程:遍历未分配的POI列表对于每个POI如果这个POI不是床:寻找离该POI最近(64格以内)的村庄,尝试把这个POI塞给这个村庄如果成功了就把该POI移动到已分配列表里面(关于村庄对POI的接收看后面)如果这个POI是床:同样会寻找离该POI最近的村庄如果找到了村庄,就和a一样的操作,把床塞给村庄,成功就移动到已分配的POI列表如果每找到,就会在原地建立一个新村庄,村庄的默认范围是(x-32,y-12,z-32)--(x+32,y+12,z+32)(这里不考虑村民的问题因为居民系统里面除了找POI之外还会有尝试移民等行为(其实是没看相关代码))注意这个64格是和村庄的最近距离,不是中心(这里存疑,如果有玩家能给出准确数据感激不尽)在略去流浪商人的更新问题后当前游戏刻村庄管理器的事情终于做完了,下面是村庄的行为。

村庄更新村庄更新是由村庄管理器调用的,每个游戏刻村庄管理器会遍历当前维度的每一个村庄并依次执行它们的tick函数这里为了阅读方便再写一遍村庄的数据:未被绑定的POI列表(unclaimedPOIList)实体列表(包括村民,铁傀儡,猫等)(actorList)村民和POI的绑定列表(claimedPOIList)村庄UID(uid)几个时钟,包括繁殖相关,劫掠相关,自动存档相关其它和劫掠相关数据(略)下面是tick函数的过程(不包括劫掠相关)1.更新村民的时间戳村庄所属的每个实体都有一个时间戳(应该是方便村民行为的,如繁殖,活动等等),这个行为就是同步村庄里面所有村民的时间戳,把出问题的村民直接移出村庄(暂不清晰) 2.更新已经绑定的POI状态这一步主要是对已经绑定的POI进行检查:具体操作是遍历每个村民绑定的每个POI(也就是遍历绑定的POI列表),对于出现状况的POI会将该POI和村民解绑,并且把该从村庄管理器的已分配列表中移除,可能的条件:该POI的实体方块不存在了该POI的数据出现问题其它如果在上述操作中绑定关系被修改(有POI被移除),就会进行所谓的重新计算POI距离(calPOIdist)的操作,这个操作也是你无法确定村庄中心的罪魁祸首.下面就是calPOIdist操作遍历每一个村民的每一个POI把第一个遍历到的POI作为村庄中心,重置村庄边界为(x-32,y-12,z-32)--(x+32,y+12,z+32),xyz是该POI的坐标对于以后遍到的POI,只会根据它和当前村庄中心的距离对村庄的边界进行调整,如果太远就会适当拓宽村庄范围(因为村庄中心就是范围的中心,这意味着村庄中心也在跟着变化,并不一定是第一个POI的位置,可以是任何方块)其它操作这操作看着没啥毛病,但是最要命的是已绑定的POI列表是一个哈希表,村民在这个表里面的排列顺序和村民自身的唯一实体ID完全相关,和村民的加入顺序的关系并不紧密,由于你无法通过常规手段获取这个ID,因此你无法找到上述操作遍历到的第一个村民,同时无法确定最基础的村庄中心,更何况调整以后的。

3.铁傀儡刷新  当如下条件同时满的时候会尝试进行铁傀儡刷新床的数量大于20居民数量/10(向下取整) 大于当前铁傀儡数量7000里面随机选一个数选到0如果上述条件成立,会在村庄中心前后左右各8格,上下3格的区域内进行10次随机选点,如果每次的选点都能够刷出而且都在村庄范围内,会进行铁傀儡的生成。

上面是每个游戏刻村庄更新做的事情(劫掠除外),当游戏刻是30的倍数的时候(也就是正常情况下的每1.5s)村庄更新还会做如下的事情:4.处理未绑定的POI前排提醒:未绑定的POI是村庄管理器塞给村庄的遍历未绑定的POI列表,执行和已绑定的同样的操作,找出出问题的POI,将其从村庄管理器的已分配POI列表以及当前村庄的未分配POI列表中移除,但是不会重新计算村庄中心(因为村庄中心的计算仅和已分配的列表有关)遍历未被绑定的POI列表,通过特定方法找到一个村民(暂不清楚),尝试将该POI和该村民进行绑定(优先职业,其次权重),如果绑定成功就把该POI移入已绑定的POI列表,当然这里也会执行calPOIDist操作注意:退出游戏的时候会存入存档的只有已经绑定的POI列表,未绑定的POI列表在下次进入游戏就没了最后附上一张POI的生命周期:一个POI的生命周期顺带一提,头图是一个当MCBE中所有随机数都返回1时生成的世界文:_hhhxiao本文为我原创本文禁止转载或摘编 我的世界 村庄 游戏攻略 minecraft mojang MCBE 村庄机制 分享到: 投诉或建议 推荐文章 更多精彩内容你真的玩透希尔薇了吗?——从背景到细节的剖析文:badapple当谈及希尔薇时,有的人会意味深长的一笑,有的人会稍加思索后恍然,哦,那个老游戏啊。

可是,许多人下意识的只是把其单纯的当做一部“启蒙作”,却并没有细究其中一些显而易见的信息。

故事的开始便是平平无奇的一天早上,“可疑的男人”(奸商)将希尔薇送了过来。

中世纪的风格和沉郁的音乐从有画面开始就有一种压抑的感觉。

这时他就对希尔薇的前主人有大概的描述。

这里我们就可以看到部分社会缩影:资本的时代,管你死没死,有钱就行长河AC漫社 单机游戏 4288 127 36 评论目录------58



請為這篇文章評分?