第一百三十二章 生物的共通NBT-2
在上一章的末尾,我们发现玩家和生物其本身的NBT很多是互通的。所以,你能在生物的共通NBT中找到一些玩家身上也有的NBT。
比如:FallFlying(值:布尔值)
FallFlying是个布尔值,一般来说它是0。如果是1,生物(或者是说“非玩家实体”)就会像用鞘翅滑翔般滑翔起来。而如果是玩家,那么玩家当然是在滑翔时这个值才会是1,所以FallFlying被用于检测一个玩家是否在滑翔。
那么这到底有什么用呢?
或许就是让非玩家实体滑翔起来吧,或者是用于服务器防飞行挂的鞘翅飞行检测,防止误判。
这是一个玩家和生物NBT互通的例子,而在生物的共通NBT中,还有很多这样的例子,比如这三个:
Sleebr /ingX(值:数值)
Sleebr /ingY(值:数值)
Sleebr /ingZ(值:数值)
这三个标签并不是时时刻刻都会出现,因为这三个标签的作用是:
记录实体当前正在睡觉的床的坐标
为什么还要记录呢?直接使用实体本身的坐标不行吗?
肯定不行,因为MC是一个充满特性的世界。如果你哪天在MC里睡觉,没想到触发了一个特性,让你飘离床,在飞天神曲的沐浴下经过了流沙河,翻越了火焰山,到达了西天大雷音寺这样子在睡梦中完成了西天取经的十万八千里。然后你醒来了,如果游戏就是采用直接使用实体本身的坐标的话,那么——
“我是谁?我在哪?我在干什么?”
(过了一会)
这时东土大唐边境河州卫,玄奘正要离开驿馆。突然观音菩萨出现在玄奘面前,告诉他有人已经提前一步拿到了大乘佛法了。
玄奘:.........
所以Mojang为了避免这种情况的发生,使用了在玩家睡觉的时候就记录床位置的方法,这样子就算玩家飘离了十万八千里再起来:
“啊~又是新的一天啊。”
“应该给自己的豪宅再升级一下了。”
(于是玩家挖了几块泥土)
“真不错。”
所以这三个标签是极其重要的。
只不过生物会睡觉吗?好像只有村民会哦。
比如现在这里有个村民,他睡在X=564,Y=87,Z=65这个床上,那么他这个时候的这三个值就是:
{
Sleebr /ingX:564,
Sleebr /ingY:87,
Sleebr /ingZ:65
}
——————一个很不华丽的分界线———————
在上一章我们讲到,生命的最大值其实就是一个属性。如果我们要修改这个属性,该怎么办呢?
生物的共通NBT里就有这么个标签:
Attributes(值:列表)
这是一个列表,所以它的值是这样的:
{Attributes:[A,B,C]}
那么这些ABC该填什么?
答案是属性:
{Attributes:[{A属性},{B属性},{C属性}]}
既然是属性,我们就不妨复习一下一百零五章的属性修饰符:
“{AttributeModifiers:[{}]}
在这个文件夹里,有这么几个文件,需要我们修改一下(记得去“*”号):
AttributeName*——要修改的属性id
Name*——要修改的属性名字
Slot*——指定生效的槽位
Obr /eration*——属性数值是怎样运算的
Amount*——属性数值
UUIDMost*——这个属性UUID的高位
UUIDLeast*——这个属性UUID的低位”
可以发现,当时讲到的属性修饰符,里面有很多个标签。
但别忘了,属性修饰符是属性的修饰符啊,我们现在才深入到属性啊,所以我们得先看看一个属性需要几个标签:
Name——属性的名称
Base——属性的基础值
Modifiers——属性的修饰符
只有三个,看起来非常简单。实际上也非常简单,比如我们的生命最大值,它就是这样的:
{Attributes:[{Name:“generic.max_health“,Base:20}]}
我们要修改,除了给这个属性添加修饰符,还可以直接把Base值修改。
那么Base可以修改到什么程度呢?
这个Base值的类型是“双精度浮点型”,比我们上一章提到的“单精度浮点型”高级了一倍。
注意,这里的“高级了一倍”不是作者自己猜的,而是有实际依据的,因为:
单精度浮点型——占用空间:32位(4字节)
双精度浮点型——占用空间:64位(8字节)
占用空间增加了一倍,确实是高级了一倍。
但如果按照这样子说的话,64位系统岂不只是32位系统的两倍?
那肯定是不对的。所以我们的这两个浮点型,它们虽然占用空间是两倍的关系,但实际可储存的数值是:
单精度浮点型——取值范围:-3.4E38~3.4E38
双精度浮点型——取值范围:-1.79769313486232E308~1.79769313486232E308
嗯,确实,是高级了亿倍.......好像还不止
所以,其实你的生命值上限最高并不是2048,也不是60000,而是:
1.79769313486232×308¹⁰!
所以,你还敢说你的创世之刃是能秒杀一切的武器了吗?
剩下的Modifiers就很简单了,因为我们早在第一百零五章就讲到了。只不过这里的Modifiers有些不一样,它只剩下了四个参数(1.16及以上5个):
Name——要修改的属性名字
Obr /eration——属性数值是怎样运算的
Amount——属性数值
UUIDMost——该修饰符的UUID高位
UUIDLeast——该修饰符的UUID低位
(1.16版本UUIDMost和UUIDLeast合并成了UUID)
具体的用法就不再细说了,自己去一百零五章看吧。
(似乎篇幅不够,再来一点吧)
接下来的标签是:
HandItems(值:列表)
HandItems很容易理解,就是生物拿着的东西。又因为MC的生物都是有两只手的(你跟我说史莱姆有手?),所以HandItems的列表是固定两个项目,一个主手,一个副手:
{HandItems:[{主手},{副手}]}
而这个主手和副手内填的就联系到我们的物品共通标签了:
Count——物品数量(值:数值)
id——物品ID(值:字符串)
tag——物品的额外标签(值:复合标签——{})
具体的我就不再讲了,已经讲了很多次了,况且才4个标签(还有一个Slot),非常简单,傻子都能记住。
举个例子,比如村民的主手正拿着一个面包,那么他的HandItems值就是:
{HandItem:[{Count:1,id:“minecraft:bread“}]}
灰常简单是不是?
但如果这个村民拿着这个面包就被杀死了(哦天呐!),掉落这个面包的几率是多少呢?
虽然我们不知道几率是多少,但我们可以更改几率,这样子我们就知道了!
控制村民的手中物品掉落几率的标签是:
HandDrobr /Chances
这也是个列表,也有两个项目,分别代表着主手和副手掉落物品的几率。
这个几率的值是单精度浮点型,所以如果你想更改主手和副手掉落物品的几率为78%的话,那么需要这么改:
{HandDrobr /Chances:[0.78,0.78]}
这样子就可以了,还是灰常简单的。
OK这一章我们就先讲到这,我们下一章再见!
(不知不觉国庆就已经过完一半了啊.......)
现在是中午12点整,王五和赵六正坐在橡木楼梯上刷B站。突然王五像触电似的站了起来:“wǒ cáo?”
“发生了什么事?”赵六瞟了一下王五,继续看敖厂长的新视频。
“wòcào!”王五突然又叫了一声。
“哎你能不能别......”赵六话还没说完,王五又来了第三声:“wòcào太棒了!”
“你老是卧槽卧槽干什么啊?”赵六决定看看王五到底在看什么,于是把头伸了过去。
“wǒ cáo?”
“wòcào!”
“wòcào太棒了!”
只见那个视频的标题是:
《洞穴更新成了!Minecraft 1.17 更新特性汇总!洞穴与峭壁更新!》