您当前所在位置: > 单机游戏 > 游戏攻略

我的世界函数系统的模块调用攻略 1.12版本函数命令系统教程

时间:2018-04-13 10:02:03  来源:  作者:网络

  我的世界1.12版本中,函数与进度系统的出现,让命令脱离命令方块——这句曾经说过的玩笑般的预言,正式成为可能。下面99小编就给大家带来我的世界函数系统的模块调用攻略。

我的世界函数系统的模块调用攻略 1.12版本函数命令系统教程

  函数系统的模块调用

  对于一个完整的命令系统而言,模块一般可以分为三类:对执行顺序先后有要求的高频模块、对执行顺序先后无要求的高频模块、非高频模块。在函数系统中,我们同样可以将模块分成这三类。为了方便后续讲解。我们作这样的设定:

  将 system:_main设为 glf ,并称之为主进程或者主时钟

  对于上面讲到的三类模块,我们通过三种不同的方式去调用。

  对执行顺序先后有要求的高频模块,在主进程中按照需要的顺序排列好来调用。对执行顺序先后没有要求的高频模块,在主进程中可以比较随意放置位置,但是一般不会考虑优先执行。特别地,如果这个模块是针对每一个玩家独立执行的,可以使用进度系统中的"tick"触发器来调用,而不需要放在主进程中。仅在特定情况下触发的非高频模块,在主进程中调用,但是辅以execute、scoreboard和选择器参数去控制其在合适的时候被调用,这里的选择器,包括了在1.12 pre-4中新增的if/unless的部分。

  非高频模块在特定条件下激活,也在很大程度上减少了模块中大量重复出现execute的现象,并完全杜绝了超长的Conditional链,因为function中并不直接支持Conditional。不直接支持,说明可以间接支持,对吧。我们来看一个例子。

  假设有红蓝两队,在开始前考虑到互殴问题不进行分队,而是采用挂tag的方式。

  红队以tag=redTeam为标记,蓝队则以tag=blueTeam为标记,准备观战的玩家以tag=specTeam为标记

  当玩家站在相应区域(红蓝两队的所有玩家还需要选择了职业)添加Ready的标记,视为准备就绪。

  如果玩家不在相应区域时就移除Ready的标记。

  选择了职业的玩家,其记分板项selectClass数值大于等于1

  全部玩家准备就绪后,游戏进入倒计时,倒计时结束时游戏开始

  倒计时未结束,有玩家脱离准备就绪的状态,则倒计时中断

  条件比较多,我们先来看看怎么写这个模块,再进行分析。在这里,我们准备了一个名为gameStat的aec实体作为标记,所有游戏进程会以tag或者score的形式挂载到该实体上。请看指令部分

  execute @p[tag=redTeam,score_selectClass_min=1] ~ ~ ~ execute @p[tag=blueTeam,score_selectClass_min=1] ~ ~ ~ scoreboard players tag @e[type=area_effect_cloud,name=gameStat,tag=notGaming] add allReady

  execute @p[tag=!Ready,m=2] ~ ~ ~ scoreboard players tag @e[name=gameStat,type=area_effect_cloud,tag=notGaming] remove allReady

  execute @p[tag=!Ready,m=2] ~ ~ ~ execute @e[name=gameStat,type=area_effect_cloud,tag=notGaming] ~ ~ ~ execute @s[tag=!allReady,score_waitTime_min=1] ~ ~ ~ title @a clear

  execute @p[tag=!Ready,m=2] ~ ~ ~ execute @e[name=gameStat,type=area_effect_cloud,tag=notGaming] ~ ~ ~ execute @s[tag=!allReady,score_waitTime_min=1] ~ ~ ~ title @a reset

  execute @p[tag=!Ready,m=2] ~ ~ ~ execute @e[name=gameStat,type=area_effect_cloud,tag=notGaming] ~ ~ ~ scoreboard players reset @s[tag=!allReady] waitTime

  scoreboard players add @e[name=gameStat,tag=allReady] waitTime 1

  execute @e[name=gameStat,score_waitTime=1,score_waitTime_min=1] ~ ~ ~ title @a times 10 140 10

  execute @e[name=gameStat,score_waitTime=1,score_waitTime_min=1] ~ ~ ~ title @a subtitle [{"color":"aqua","text":"请玩家站在准备区域不要离开"}]

  execute @e[name=gameStat,score_waitTime=1,score_waitTime_min=1] ~ ~ ~ title @a title [{"color":"yellow","text":"游戏即将开始"}]

  execute @e[name=gameStat,score_waitTime=40,score_waitTime_min=40] ~ ~ ~ title @a subtitle [{"color":"aqua","text":"3"}]

  execute @e[name=gameStat,score_waitTime=40,score_waitTime_min=40] ~ ~ ~ execute @a ~ ~ ~ playsound block.note.pling voice @p ~ ~ ~ 1 0

  execute @e[name=gameStat,score_waitTime=60,score_waitTime_min=60] ~ ~ ~ title @a subtitle [{"color":"aqua","text":"2"}]

  execute @e[name=gameStat,score_waitTime=60,score_waitTime_min=60] ~ ~ ~ execute @a ~ ~ ~ playsound block.note.pling voice @p ~ ~ ~ 1 0

  execute @e[name=gameStat,score_waitTime=80,score_waitTime_min=80] ~ ~ ~ title @a subtitle [{"color":"aqua","text":"1"}]

  execute @e[name=gameStat,score_waitTime=80,score_waitTime_min=80] ~ ~ ~ execute @a ~ ~ ~ playsound block.note.pling voice @p ~ ~ ~ 1 0

  execute @e[name=gameStat,score_waitTime_min=100] ~ ~ ~ title @a times 10 30 10

  execute @e[name=gameStat,score_waitTime_min=100] ~ ~ ~ title @a title [{"color":"gold","text":"游戏开始"}]

  scoreboard players set @e[name=gameStat,type=area_effect_cloud,score_waitTime_min=100] gameStat 1

  scoreboard players reset @e[name=gameStat,score_gameStat_min=1,score_gameStat=1] waitTime

  scoreboard players tag @e[name=gameStat,score_gameStat_min=1,score_gameStat=1] remove allReady

  execute @e[type=area_effect_cloud,name=gameStat,score_gameStat_min=1,score_gameStat=1] ~ ~ ~ function system:StartGame

  接下来我们来慢慢分析。

  首先是开始的条件。有红蓝两队,那么这两队都肯定需要有人,才能够开始,考虑到同一选择器中不能重复使用tag的参数,我们保留了区分队伍的参数,而不是区分是否准备就绪的参数。因此,第一条指令的意思是,当存在选了职业并选红队的玩家以及选了职业并选蓝队的玩家,我们给中心实体加上allReady这个标记,以表明可能满足开始条件。

  至于满足条件吗?如果有未准备就绪的玩家,就说明不满足,那我们就让一个没有准备就绪的玩家来去掉allReady这个标记好了。

  对于3~5行,我们放后面点讲。先看后面。满足开始条件以后,我们会给中心实体加分(使用waitTime这个记分板项),在第一刻加分后出现提示文字提示准备开始,然后进入循环计时,最后计时满了,调用system:startgame这个函数来开始游戏(这里不是例子的部分,不作说明)。

  那么回过头来看3~5行,这里明显是打断的部分。打断,就是要清掉提示文字、重置计时器。如果此时都还没有进行过加分,那么我们就不必进行那三条指令,因此可以看到中间有个选择器里有score_waitTime_min=1的参数加以限制。

  重点来了,我们看到这3条指令前面相当长一串execute是重复的。因为在以前用cb写的时候,这里使用了Conditional,而现在函数不直接支持Conditional,所以用了一大堆execute,但是这里我们可以稍作修改,对不对?请看下面

  execute @p[tag=redTeam,score_selectClass_min=1] ~ ~ ~ execute @p[tag=blueTeam,score_selectClass_min=1] ~ ~ ~ scoreboard players tag @e[type=area_effect_cloud,name=gameStat,tag=notGaming] add allReady

  execute @p[tag=!Ready,m=2] ~ ~ ~ scoreboard players tag @e[name=gameStat,type=area_effect_cloud,tag=notGaming] remove allReady

  execute @p[tag=!Ready,m=2] ~ ~ ~ execute @e[name=gameStat,type=area_effect_cloud,tag=notGaming] ~ ~ ~ execute @s[tag=!allReady,score_waitTime_min=1] ~ ~ ~ function system:cond_breakstartcount

  scoreboard players add @e[name=gameStat,tag=allReady] waitTime 1

  execute @e[name=gameStat,score_waitTime=1,score_waitTime_min=1] ~ ~ ~ title @a times 10 140 10

  execute @e[name=gameStat,score_waitTime=1,score_waitTime_min=1] ~ ~ ~ title @a subtitle [{"color":"aqua","text":"请玩家站在准备区域不要离开"}]

  execute @e[name=gameStat,score_waitTime=1,score_waitTime_min=1] ~ ~ ~ title @a title [{"color":"yellow","text":"游戏即将开始"}]

  execute @e[name=gameStat,score_waitTime=40,score_waitTime_min=40] ~ ~ ~ title @a subtitle [{"color":"aqua","text":"3"}]

  execute @e[name=gameStat,score_waitTime=40,score_waitTime_min=40] ~ ~ ~ execute @a ~ ~ ~ playsound block.note.pling voice @p ~ ~ ~ 1 0

  execute @e[name=gameStat,score_waitTime=60,score_waitTime_min=60] ~ ~ ~ title @a subtitle [{"color":"aqua","text":"2"}]

  execute @e[name=gameStat,score_waitTime=60,score_waitTime_min=60] ~ ~ ~ execute @a ~ ~ ~ playsound block.note.pling voice @p ~ ~ ~ 1 0

  execute @e[name=gameStat,score_waitTime=80,score_waitTime_min=80] ~ ~ ~ title @a subtitle [{"color":"aqua","text":"1"}]

  execute @e[name=gameStat,score_waitTime=80,score_waitTime_min=80] ~ ~ ~ execute @a ~ ~ ~ playsound block.note.pling voice @p ~ ~ ~ 1 0

  execute @e[name=gameStat,score_waitTime_min=100] ~ ~ ~ title @a times 10 30 10

  execute @e[name=gameStat,score_waitTime_min=100] ~ ~ ~ title @a title [{"color":"gold","text":"游戏开始"}]

  scoreboard players set @e[name=gameStat,type=area_effect_cloud,score_waitTime_min=100] gameStat 1

  scoreboard players reset @e[name=gameStat,score_gameStat_min=1,score_gameStat=1] waitTime

  scoreboard players tag @e[name=gameStat,score_gameStat_min=1,score_gameStat=1] remove allReady

  execute @e[type=area_effect_cloud,name=gameStat,score_gameStat_min=1,score_gameStat=1] ~ ~ ~ function system:StartGame

  system:cond_breakstartcount.mcfunction

  title @a clear

  title @a reset

  scoreboard players reset @s waitTime

  虽然这个独立出来的子模块只有3条指令,但是如果分离出来的是30条而不是3条呢?能够节省多少功夫想必不需要解释了吧?

  以上是关于函数系统模块调用的部分,当中有提到使用进度系统来调用部分独立模块,我们接下来来可以看看函数系统与进度系统联动>>>。

99danji小编猜你还喜欢

2017-06-09我的世界函数命令怎么用 函数系统的构成介绍2017-06-09我的世界函数系统与进度系统联动 函数系统的基础使用攻略2017-06-09我的世界函数系统与命令方块那个好 函数系统与命令方块对比
相关下载

玩家评论

函数VLOOKUP和函数IF的组合使用!

输入物品名称就能出现单价!这个功能今天我教大家如何制作!攻略对象电脑Excel表格步骤分解1准备好【空白表】和数据源表放在桌面,方便自己查找;不管放哪儿只要自己能找到就好!如图详情>>

阅读: 9
日期: 2019-06-28
IF函数和AND函数的组合用法!

在表格使用中,会遇到选择某个数据和某个数据之间的数值!这个时候就会用到AND函数和IF函数了,接下来教大家如何组合使用!攻略对象电脑Excel表格步骤分解1第一步用AND函数,固定该单详情>>

阅读: 10
日期: 2019-06-25
如何使用php做一个自己的函数

学习一个语言,编写函数是必须要做的事情,因为函数可以降低代码的重写率,今天小编教大家使用php做一个简单的函数。攻略对象个人观点,仅供参考。步骤分解1首先我们新建两个php文详情>>

阅读: 7
日期: 2019-06-25
输入函数后不能输出数据怎么办

输入函数后不能输出数据怎么办?步骤分解1用MID取值,准考证前3位为部门代码,可是发现并不能显示出来,怎么办呢?2选中‘部门代码’列3鼠标右键,单击“设置单元格格式”4在对话框的分详情>>

阅读: 18
日期: 2019-06-23
Excel函数COUNTIF计算区域内满足条件单元格个数

如何确定某个区域内,满足条件的单元格个数; 下面我就来教你们如何操作!攻略对象电脑Excel表格步骤分解1打开表格准备好要筛选的资料;①为了方便使用函数我们可以在表格外先详情>>

阅读: 37
日期: 2019-06-22
EXCEL中使用TEXT函数指定文本格式

在EXCEL中如何指定文本的特定格式呢?我经常使用TEXT函数来实现,如图中,把序号统一为四位数可以用=TEXT(A1,"0000")来实现。攻略对象EXCEL步骤分解1=TEXT(A1,"0000") 可以把文本详情>>

阅读: 4
日期: 2019-06-22
表格中EVALUATE()函数如何使用?自动计算

你遇到过吗?表格中在前面一个单元格输入算式,在后面一个单元格就自动计算;例如:在A1单元格输入5*5,在B1单元格自动得出25;.今天教你怎么操作!跟我学,不需要动脑,动手即可!完成操作!关注详情>>

阅读: 5
日期: 2019-06-22
Excel表格中,用date函数合并日期;

Excel表格中,用date函数合并日期;实际工作中,有些情况下需要对分散的年月日合并到一个单元格中,使用常规对的符号( & )合并,合并后并不会显示为日期格式,需要设置格式;今天教大家如何详情>>

阅读: 12
日期: 2019-06-21
Excel函数-count怎么用

Excel函数计算包含数字的单元格个数以及参数列表中数字的个数,使用 COUNT 函数获取区域中或一组数字中的数字字段中条目的个数。下面将从三个方面对count进行讲解:①count函数详情>>

阅读: 14
日期: 2019-06-21
Excel求考试学生数-COUNTIFS()函数的使用

Excel求考试学生数,COUNTIFS()函数的使用步骤分解1如图,求出考试学生数一列的数值2选定单元格,在输入框中输入“=COUNTIFS()”3调出函数公式,在公式中选中单元格“成绩单!A2:A95详情>>

阅读: 9
日期: 2019-06-20
如何使用函数有条件求等级

使用函数有条件求等级步骤分解1根据每个客户的销售总额计算其对应的客户等级(不要改变原来的数据排序),等级评定参照右侧的“客户等级”表2首先求出销售额,在单元格G2中输入“=S详情>>

阅读: 7
日期: 2019-06-20
excel怎么使用函数 基础入门

函数是学习excel过程中绕不过去的一道门,只有进了这道门才能得以窥见excel强大功能的一面,而不是停留在原来手算的狭隘中,学习excel必须学习函数,函数不必全部掌握,但是掌握一定详情>>

阅读: 3
日期: 2019-06-19
excel巧用函数重复计算

excel巧用函数重复计算步骤分解1复制单元格F2中的函数2粘贴到单元格G2中3调出函数公式,看第三个参数所对应的列中的值4客户信息表中,城市在F列中,输入第5列5于是将参数6改成数详情>>

阅读: 5
日期: 2019-06-18
如何查看python3.6的内置函数

python为了方便用户的一些操作,将一些常用的功能封装成了函数,这里小编就带大家一起看一下如何查看python3.6的内置函数。攻略对象安装python3.6的电脑一台步骤分解1首先先打详情>>

阅读: 11
日期: 2019-06-18
Excel怎么根据条件判断得到答案:if函数

在用Excel处理数据时,有时候我们需要根据某个判断来得到一个值,或另外一个值,那么这个时候就需要用到if函数了。攻略对象Excel步骤分解1本例子中,需要根据分数的情况来判断是否详情>>

阅读: 11
日期: 2019-06-17
函数的极大值不一定大于函数的极小值 怎样理解

Game234问答中心有网友提出了一个比较有代表性的问题【函数的极大值不一定大于函数的极小值怎样理解】,小编觉得可能对其他网友也有帮助,所以将此问答整理出来了,希望对您有帮助。小编为您搜罗的答案1极详情>>

阅读: 5
日期: 2019-04-15
Lingo 中的@qrand和@rand函数有什么区别?

Game234问答中心有网友提出了一个比较有代表性的问题【Lingo中的@qrand和@rand函数有什么区别?】,小编觉得可能对其他网友也有帮助,所以将此问答整理出来了,希望对您有帮助。小编为您搜详情>>

阅读: 6
日期: 2019-04-14
DLL函数查看器viewdll绿色版下载

游戏类型:环境组件文件大小:248KB软件语言:多国语言/简体中文运营:软件授权:免费版应用平台:WinXP/Win2003/Vista/Win7/Win8安全认证:DLL函数查看器viewd详情>>

阅读: 7
日期: 2019-04-03
【Egress】MATLAB中regress函数

小编为您搜罗的答案:等号右边完整应写作:regress(Y,X,alpha)bint是回归系数的区间估计,r是残差,rint是置信区间,stats是用于检验回归模型的统计量,有三个数值:相关系数r^2详情>>

阅读: 3
日期: 2018-08-27
【Egress】matlab中的regress函数。。。。

小编为您搜罗的答案:  matlab中的regress函数等号右边完整为:regress(Y,X,alpha)  bint是回归系数的区间估计,r是残差,rint是置信区间,stats是用于检验回归模详情>>

阅读: 3
日期: 2018-08-27
函数太多记不住?那这7个超简单的数据排序统计函数你肯定能记住

在日常工作中,统计函数整体使用率都很高,而其中最常用的莫过于下面7个!可以说的最基础的函数应用,不会真的说不过去。一、LARGE函数(=LARGE(B2:B9,1))可以用来计算区域中从大往小数排名详情>>

阅读: 1
日期: 2018-08-26
最常用的Excel函数小技巧!

Excel是我们在日常办公中最长用到的办公软件,然而你对Excel了解多少呢?小编今天整理一些Excel办公常用的函数公式,希望可以帮你提高工作效率!1、忽略0分,求平均分2、统计大于平均分的人数3详情>>

阅读: 0
日期: 2018-08-25
Excel十大常用函数之Vlookup函数

EXCEL中经常会遇到这样一个问题,有一张表格是原始数据,另外一张表格需要在第一张表格中寻找部分匹配的数据,如果一个个核对,那就太复杂了,本节讲解的VLOOKUP函数可以精准的进行两个表格之间的数据详情>>

阅读: 1
日期: 2018-08-25
Excel办公中常用的五大函数,你知道它们是干嘛的吗?

在Excel表格中,我们经常会用到函数公式来帮助我们更方便更快捷的完成工作,可是,用了这么久,你们知道它们具体是干嘛的吗?一、SUM函数我想这个函数大家应该都不陌生吧,这个函数的作用是求和,在你指定详情>>

阅读: 2
日期: 2018-08-25
EXCEL中today函数的时间显示问题?

小编为您搜罗的答案:菜单栏,工具,选项,重新计算,勾选“迭代计算”,最多迭代次数设为1次 在A1输入公式 =IF(B1="","",IF(A1="",TODAY(),A1))&nb详情>>

阅读: 11
日期: 2018-08-20
【oO】VLOOKUP函数显示值不可用

小编为您搜罗的答案:一、VLOOKUP函数要求第一参数的查找值必须要存在于第二参数的被查找区域的第一列中,如提问中的公式,C5的值必须要存在于 机械维修记录表!B3:C43的第一列,即B详情>>

阅读: 2
日期: 2018-08-20
(1)常用十大明星函数之IF

在Excel中最常用到的函数之一就是IF函数。IF函数使用语法:=IF(logical_test,[value_if_true],[value_if_false])=IF(A,B,C),表详情>>

阅读: 0
日期: 2018-08-12
财务函数三板斧:1分钟教您学会sumif函数

一、什么是sumif函数?sumif函数可以对报表范围中符合指定条件的值进行求和。Excel中sumif函数的用法是根据指定条件对若干单元格、区域或引用求和。二、sumif函数的语法是什么?SUM详情>>

阅读: 3
日期: 2018-08-06
vlookup函数常见问题的解决方式,你会吗

vlookup函数教程很多,都是介绍它的用法。但在实际应用过程中,一些小的操作细节还是很容易让大家忽视的,小编在这里整理了一些问题的解决方式。1、查找的值为空时【例】如下表所示,上表中李飞的职务未填详情>>

阅读: 17
日期: 2018-08-05
在PyODPS DataFrame自定义函数中使用pandas、scipy和scikit-learn

背景PyODPSDataFrame提供了类似pandas的接口,来操作ODPS数据,同时也支持在本地使用pandas,和使用数据库来执行。PyODPSDataFrame除了支持类似详情>>

阅读: 2
日期: 2018-08-05
Excel函数公式:函数Large、Small、Choose的经典用法和技巧

Excel中,Large、Small、Choose函数的主要作用是在指定范围中获取特定的值,如果稍加变通,Large、Small、Choose函数就可以发挥出意想不到的神奇作用。一、Large函数。详情>>

阅读: 16
日期: 2018-08-04
「python3入门精品教程」「函数进阶」6.1函数式编程概论

函数是Python内建支持的一种封装,我们通过把大段代码拆成函数,通过一层一层的函数调用,就可以把复杂任务分解成简单的任务,这种分解可以称之为面向过程的程序设计。函数就是面向过程的程序设计的基本单元详情>>

阅读: 3
日期: 2018-07-30
6大单元格字符处理函数,从没用过如此简单的EXCEL!

日常必用的Excel作为办公软件之一,使用范围极广,前面小编介绍了不少表格数据的处理方法,今天想介绍一下针对单元格字符的处理方法!保证超级简单,也很方便!一、多单元格字符合并除了一般常用的&连字符,详情>>

阅读: 9
日期: 2018-07-29
【N+】设函数fn(x)=2sin(anx+π6)(an>0,n∈N*),其周期为n(n+1),Sn是数...

小编为您搜罗的答案:(Ⅰ)由题意可知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详情>>

阅读: 2
日期: 2018-07-24
【oO】EXECL表格中VLOOKUP函数是如何使用的?

小编为您搜罗的答案:在表格或数值数组的首列查找指定的数值,并由此返回表格或数组当前行中指定列处的数值。当比较值位于数据表首列时,可以使用函数VLOOKUP代替函数HLOOKUP。 在详情>>

阅读: 3
日期: 2018-07-09
Excel函数,与数组相关的函数之split,excel使用技巧大全

?excel使用技巧大全上一节咱们讲了怎样把数据并合在一起,现在咱们看下怎样把合并后的数据给拆分开来。请详情>>

阅读: 0
日期: 2018-07-04
精彩推荐