我的世界1.12版本新增了函数命令这一内容,很多玩家觉得非常复杂,也有玩家发现这个命令可以完全脱离命令方块而存在,今天小编就为大家带来我的世界1.12版函数命令系统教学详解,感兴趣的盆友们快来看看吧!
1.12版函数命令系统教学详解
1.9的更新为我们带来了三色命令方块,让命令方块脱离了红石成为独立的体系,我们因此可以更好实现一些想法;时隔3个版本,MOJANG再次为我们带来惊人的变革。
1.12中,函数与进度系统的出现,让命令脱离命令方块——这句曾经说过的玩笑般的预言,正式成为可能。
函数系统的构成
函数系统的由来
函数(function)系统,是 MC 1.12 Pre-1 版本中新增的一个功能,它将原来进度系统中返回指令的部分单独提取出来,做成了现在的函数系统。
函数系统的形式
函数系统由命名空间和函数文件组成,这些文件保存在存档目录/data/functions/下。functions目录下的文件夹,称为命名空间,各个命名空间下存放不同的函数文件。实际上,命名空间就是方便我们编写者分类并管理各种函数文件。
函数文件是以.mcfunction为后缀名的文本文件,建议采用utf-8无BOM编码以防显示错乱。简单来讲,一个函数等价于一个多行命令方块,函数文件里面每一行写一条指令,当执行这个函数时,里面的指令会按行依次执行。如果在一个函数中调用其它函数,那么在同一游戏刻,被调用的函数中所有指令先执行完,再继续当前函数中后续的指令,就像插队一样,我们在后面对比命令方块时还会说到这个。
请注意:在 1.12 Pre-3 版本中存在一个严重漏洞,即命令执行体不能正确地通过execute传递到被调用的函数中去,这个漏洞有望在后续版本以及正式版修复。
以下是本文用到的一个函数系统的目录,带有"+"的表示为目录
+ functions
+ say
hi.mcfunction
bye.mcfunction
Text1.mcfunction
text2.mcfunction
+ system
+ process
_process.mcfunction
_main.mcfunction
player_tick.mcfunction
如何调用函数
在 1.12 中,MOJANG新增了function指令和一条名为gameLoopFunction的游戏规则来辅助我们使用函数系统。function指令的格式如下:
function <命名空间:函数名>
function <命名空间:函数名>
这两条都是可行的。其中,if|unless是在1.12 pre-4加入的功能,后面我会解释到这个。我们先来说说第一种形式。例如上面的目录中,要调用system这个命名空间下的_main文件,就是输入这样的指令:
function system:_main
现在,我们来看一个例子例如say命名空间下的Text1.mcfunction和text2.mcfunction,里面分别写上这些内容
Text1.mcfunction
#这是一个范例,在function文件中可以用#来注释行。请注意,不能够使用//来注释!
say 1
function say:text2
say 2
text2.mcfunction
say 3
say 4
当我在系统后台输入function say:text1时,聊天框会出现这些内容:
[server] 1
[server] 3
[server] 4
[server] 2
也就是说,执行function指令的人,会把函数里面的指令依次执行——我在系统后台输入function指令,就是系统在执行,我自己输入function指令,就是我本人在执行。大家可能注意到了,函数中支持使用#进行注释(旧版本支持//注释,当前版本已经不再支持),也就是说被注释行不会作为指令而执行,这一点有多方便相比不比我再说了。同时需要大家注意:函数中所有指令不能够以/开头。例如,你可以这样写:
say @s
但是不能这样写:
/say @s
最后有一点需要注意的是,在function指令中调用函数时,不区分大小写。例如前面say命名空间下的Text1.mcfunction,我在调用的时候写的是say:text1
然后是第二种形式,也就是带有if|unless的。我简单举两个例子,大家就知道是什么意思了。
say:tellraw.mcfunction
scoreboard objectives add timer dummy 计时器
scoreboard players add @s timer 1
function random:title if @s[score_timer_min=1200]
scoreboard players reset @s[score_timer_min=1200] timer
random:title.mcfunction
summon area_effect_cloud ~ ~ ~ {Tags:["rnd_title","rnd_title1"]}
summon area_effect_cloud ~ ~ ~ {Tags:["rnd_title","rnd_title2"]}
summon area_effect_cloud ~ ~ ~ {Tags:["rnd_title","rnd_title3"]}
summon area_effect_cloud ~ ~ ~ {Tags:["rnd_title","rnd_title4"]}
summon area_effect_cloud ~ ~ ~ {Tags:["rnd_title","rnd_title5"]}
entitydata @r[r=0,type=area_effect_cloud,tag=rnd_title] {CustomName:"rnd_title"}
execute @e[name=rnd_title,tag=rnd_title1] ~ ~ ~ tellraw @a[r=0,c=1] ["1"]
execute @e[name=rnd_title,tag=rnd_title2] ~ ~ ~ tellraw @a[r=0,c=1] ["2"]
execute @e[name=rnd_title,tag=rnd_title3] ~ ~ ~ tellraw @a[r=0,c=1] ["3"]
execute @e[name=rnd_title,tag=rnd_title4] ~ ~ ~ tellraw @a[r=0,c=1] ["4"]
execute @e[name=rnd_title,tag=rnd_title5] ~ ~ ~ tellraw @a[r=0,c=1] ["5"]
将say:tellraw放到主进程中
execute @a ~ ~ ~ function say:tellraw
则每位玩家每分钟将会看到1~5中随机一个数字出现在聊天框。也就是说,只有计时器分数满1200的人会执行后面的随机部分。那么很显然,带有if的意思就是,如果能找到后面的选择器,就执行这个函数,否则不执行。相当于testfor。
那么unless的意思也就很明显了:在找不到后面的选择器的时候,执行这个函数,相当于testfor+非门。
gameLoopFunction
讲完调用,就该讲讲高频了。玩命令方块的人都知道高频是实现许多功能的前提。在函数系统中,MOJANG 为我们提供了一条名为gameLoopFunction的游戏规则来实现高频。它的格式是
gamerule gameLoopFunction <命名空间:函数>
也就是说,你可以指定一个函数来高频执行,这个高频是20Hz的,也就是每一个游戏刻都会执行一遍。新建的存档如果没有执行过这条指令,而是用gamerule gameLoopFunction来查询的话,得到的返回值是-
为了方便,我们将这个规则简称为glf。在旧版本中,glf指定的函数,由系统(server)作为执行体;而在新的版本中,MOJANG 引入了虚拟执行体,例如将 say:text2 指定为glf时,每一个游戏刻得到的结果是这样的
[say:text2] 3
[say:text2] 4
也就是说,系统不再作为执行体,而是由虚拟的执行体代为执行。
关于 glf 多说两句。使用 glf 去高频执行一个函数,和使用 RCB(循环型命令方块,紫色那种)去执行,是不一样的。区别主要在于其更新顺序先后。一般而言不会造成严重影响,但是在某些情况会不一样。比如,使用 CB 能检测到生物的{HurtTime:10s}这个 NBT,而使用 glf 执行函数只能检测到的是{HurtTime:9s},检测不到10,这是因为关于函数的更新,都放在了生物更新之后,而 CB 的更新则是在生物更新之前。详情可以看这里。按照 Searge 的说法,函数并不是命令方块的完全替代。这个说法,大家就见仁见智了。对我个人而言这个影响不大。
以上是函数系统的相关构成,以及如何调用函数。接下来我们来了解一下函数系统的模块分类。
相关下载 |
输入物品名称就能出现单价!这个功能今天我教大家如何制作!攻略对象电脑Excel表格步骤分解1准备好【空白表】和数据源表放在桌面,方便自己查找;不管放哪儿只要自己能找到就好!如图详情>>
在表格使用中,会遇到选择某个数据和某个数据之间的数值!这个时候就会用到AND函数和IF函数了,接下来教大家如何组合使用!攻略对象电脑Excel表格步骤分解1第一步用AND函数,固定该单详情>>
学习一个语言,编写函数是必须要做的事情,因为函数可以降低代码的重写率,今天小编教大家使用php做一个简单的函数。攻略对象个人观点,仅供参考。步骤分解1首先我们新建两个php文详情>>
输入函数后不能输出数据怎么办?步骤分解1用MID取值,准考证前3位为部门代码,可是发现并不能显示出来,怎么办呢?2选中‘部门代码’列3鼠标右键,单击“设置单元格格式”4在对话框的分详情>>
如何确定某个区域内,满足条件的单元格个数; 下面我就来教你们如何操作!攻略对象电脑Excel表格步骤分解1打开表格准备好要筛选的资料;①为了方便使用函数我们可以在表格外先详情>>
在EXCEL中如何指定文本的特定格式呢?我经常使用TEXT函数来实现,如图中,把序号统一为四位数可以用=TEXT(A1,"0000")来实现。攻略对象EXCEL步骤分解1=TEXT(A1,"0000") 可以把文本详情>>
你遇到过吗?表格中在前面一个单元格输入算式,在后面一个单元格就自动计算;例如:在A1单元格输入5*5,在B1单元格自动得出25;.今天教你怎么操作!跟我学,不需要动脑,动手即可!完成操作!关注详情>>
Excel表格中,用date函数合并日期;实际工作中,有些情况下需要对分散的年月日合并到一个单元格中,使用常规对的符号( & )合并,合并后并不会显示为日期格式,需要设置格式;今天教大家如何详情>>
Excel函数计算包含数字的单元格个数以及参数列表中数字的个数,使用 COUNT 函数获取区域中或一组数字中的数字字段中条目的个数。下面将从三个方面对count进行讲解:①count函数详情>>
Excel求考试学生数,COUNTIFS()函数的使用步骤分解1如图,求出考试学生数一列的数值2选定单元格,在输入框中输入“=COUNTIFS()”3调出函数公式,在公式中选中单元格“成绩单!A2:A95详情>>
使用函数有条件求等级步骤分解1根据每个客户的销售总额计算其对应的客户等级(不要改变原来的数据排序),等级评定参照右侧的“客户等级”表2首先求出销售额,在单元格G2中输入“=S详情>>
函数是学习excel过程中绕不过去的一道门,只有进了这道门才能得以窥见excel强大功能的一面,而不是停留在原来手算的狭隘中,学习excel必须学习函数,函数不必全部掌握,但是掌握一定详情>>
excel巧用函数重复计算步骤分解1复制单元格F2中的函数2粘贴到单元格G2中3调出函数公式,看第三个参数所对应的列中的值4客户信息表中,城市在F列中,输入第5列5于是将参数6改成数详情>>
python为了方便用户的一些操作,将一些常用的功能封装成了函数,这里小编就带大家一起看一下如何查看python3.6的内置函数。攻略对象安装python3.6的电脑一台步骤分解1首先先打详情>>
在用Excel处理数据时,有时候我们需要根据某个判断来得到一个值,或另外一个值,那么这个时候就需要用到if函数了。攻略对象Excel步骤分解1本例子中,需要根据分数的情况来判断是否详情>>
Game234问答中心有网友提出了一个比较有代表性的问题【函数的极大值不一定大于函数的极小值怎样理解】,小编觉得可能对其他网友也有帮助,所以将此问答整理出来了,希望对您有帮助。小编为您搜罗的答案1极详情>>
Game234问答中心有网友提出了一个比较有代表性的问题【Lingo中的@qrand和@rand函数有什么区别?】,小编觉得可能对其他网友也有帮助,所以将此问答整理出来了,希望对您有帮助。小编为您搜详情>>
游戏类型:环境组件文件大小:248KB软件语言:多国语言/简体中文运营:软件授权:免费版应用平台:WinXP/Win2003/Vista/Win7/Win8安全认证:DLL函数查看器viewd详情>>
小编为您搜罗的答案:等号右边完整应写作:regress(Y,X,alpha)bint是回归系数的区间估计,r是残差,rint是置信区间,stats是用于检验回归模型的统计量,有三个数值:相关系数r^2详情>>
小编为您搜罗的答案: matlab中的regress函数等号右边完整为:regress(Y,X,alpha) bint是回归系数的区间估计,r是残差,rint是置信区间,stats是用于检验回归模详情>>
在日常工作中,统计函数整体使用率都很高,而其中最常用的莫过于下面7个!可以说的最基础的函数应用,不会真的说不过去。一、LARGE函数(=LARGE(B2:B9,1))可以用来计算区域中从大往小数排名详情>>
Excel是我们在日常办公中最长用到的办公软件,然而你对Excel了解多少呢?小编今天整理一些Excel办公常用的函数公式,希望可以帮你提高工作效率!1、忽略0分,求平均分2、统计大于平均分的人数3详情>>
EXCEL中经常会遇到这样一个问题,有一张表格是原始数据,另外一张表格需要在第一张表格中寻找部分匹配的数据,如果一个个核对,那就太复杂了,本节讲解的VLOOKUP函数可以精准的进行两个表格之间的数据详情>>
在Excel表格中,我们经常会用到函数公式来帮助我们更方便更快捷的完成工作,可是,用了这么久,你们知道它们具体是干嘛的吗?一、SUM函数我想这个函数大家应该都不陌生吧,这个函数的作用是求和,在你指定详情>>
小编为您搜罗的答案:菜单栏,工具,选项,重新计算,勾选“迭代计算”,最多迭代次数设为1次 在A1输入公式 =IF(B1="","",IF(A1="",TODAY(),A1))&nb详情>>
小编为您搜罗的答案:一、VLOOKUP函数要求第一参数的查找值必须要存在于第二参数的被查找区域的第一列中,如提问中的公式,C5的值必须要存在于 机械维修记录表!B3:C43的第一列,即B详情>>
在Excel中最常用到的函数之一就是IF函数。IF函数使用语法:=IF(logical_test,[value_if_true],[value_if_false])=IF(A,B,C),表详情>>
一、什么是sumif函数?sumif函数可以对报表范围中符合指定条件的值进行求和。Excel中sumif函数的用法是根据指定条件对若干单元格、区域或引用求和。二、sumif函数的语法是什么?SUM详情>>
vlookup函数教程很多,都是介绍它的用法。但在实际应用过程中,一些小的操作细节还是很容易让大家忽视的,小编在这里整理了一些问题的解决方式。1、查找的值为空时【例】如下表所示,上表中李飞的职务未填详情>>
背景PyODPSDataFrame提供了类似pandas的接口,来操作ODPS数据,同时也支持在本地使用pandas,和使用数据库来执行。PyODPSDataFrame除了支持类似详情>>
Excel中,Large、Small、Choose函数的主要作用是在指定范围中获取特定的值,如果稍加变通,Large、Small、Choose函数就可以发挥出意想不到的神奇作用。一、Large函数。详情>>
函数是Python内建支持的一种封装,我们通过把大段代码拆成函数,通过一层一层的函数调用,就可以把复杂任务分解成简单的任务,这种分解可以称之为面向过程的程序设计。函数就是面向过程的程序设计的基本单元详情>>
日常必用的Excel作为办公软件之一,使用范围极广,前面小编介绍了不少表格数据的处理方法,今天想介绍一下针对单元格字符的处理方法!保证超级简单,也很方便!一、多单元格字符合并除了一般常用的&连字符,详情>>
小编为您搜罗的答案:(Ⅰ)由题意可知T=2πan=n(n+1),∴an=2πn(n+1),∵an=2πn(n+1)=2π(1n?1n+1),∴Sn=2π[(1?12)+(12?13)+…+(1n?1n详情>>
小编为您搜罗的答案:在表格或数值数组的首列查找指定的数值,并由此返回表格或数组当前行中指定列处的数值。当比较值位于数据表首列时,可以使用函数VLOOKUP代替函数HLOOKUP。 在详情>>
?excel使用技巧大全上一节咱们讲了怎样把数据并合在一起,现在咱们看下怎样把合并后的数据给拆分开来。请详情>>