Compare commits
10 Commits
v3.0.2-beta.1
...
v3.0.5
| Author | SHA1 | Date | |
|---|---|---|---|
| 2fd72d84de | |||
| 47bd69d3a8 | |||
| 8162a7031a | |||
| 08f73b9b9c | |||
| 2a31e4a2c6 | |||
| e431f13e49 | |||
| 718ed537c4 | |||
| 025d821495 | |||
| 4625636ed4 | |||
| 670ab5514c |
@@ -11,7 +11,7 @@
|
||||
## 安装教程
|
||||
|
||||
1. 兼容性
|
||||
- `数据包 v3.0.x` 支持 `Minecraft 1.19.x`(*由于使用了1.18.x不支持的操作,撤销对MC1.18.x的支持*)
|
||||
- `数据包 v3.0.x` 支持 `Minecraft 1.18.2-1.19.x`
|
||||
- `数据包 v2.2.x` 支持 `Minecraft 1.19.x`
|
||||
- `数据包 v2.1.x` 支持 `Minecraft 1.17.x-1.18.x`
|
||||
- `数据包 v2.0.x` 支持 `Minecraft 1.16.3-1.16.5`
|
||||
@@ -25,7 +25,7 @@
|
||||
|
||||
# FZ生存数据包 3.0
|
||||
|
||||
[](https://gitee.com/harvey-husky/FZ-sDatapack/releases/v3.0-beta.12) [](https://minecraft.net/)
|
||||
[](https://gitee.com/harvey-husky/FZ-sDatapack/releases) [](https://minecraft.net/)
|
||||
|
||||
> 其他版本见[发行页面](https://gitee.com/harvey-husky/FZ-sDatapack/releases)
|
||||
|
||||
@@ -68,13 +68,20 @@
|
||||
- 脚本:
|
||||
- `fzsd_score.sc`(**开发中!此处列举目前已完成的**):
|
||||
- 可避免Carpet假人污染计分板
|
||||
- 执行 `reload` 指令后自动生效
|
||||
- 可以标记哪些玩家是假人
|
||||
- *注:请不要使用为假人名添加“bot”前缀的carpet扩展,本插件不支持此类假人!*
|
||||
- 子命令( `/fzsd_score <子命令>` ):
|
||||
- `updateFrom <version>`:用于从给定的数据包版本恢复计分板数据(需要测试!)
|
||||
- `recalculate`:重新计算所有计分板总分
|
||||
- `recalculate <scoreboardID>`:重新计算该计分板总分
|
||||
- `set <player> <scoreboardID> <score>`:设置该玩家该计分板的分数
|
||||
- `reset <player>`:重置该玩家的所有分数
|
||||
- `reset <player> <scoreboardID>`:重置该玩家该计分板的分数
|
||||
- `restore player <玩家名> <计分板ID>`:恢复该玩家的该计分板分数
|
||||
- `restore player <玩家名>`:恢复该玩家的所有计分板分数
|
||||
- `restore whitelist <玩家名> <计分板ID>`:恢复所有白名单玩家的该计分板分数
|
||||
- `restore whitelist <玩家名>`:恢复所有白名单玩家的所有计分板分数
|
||||
- *副作用:恢复完成后玩家会被放置在出生点,请确保出生点完全安全*
|
||||
- `commandPlayer <permissionType>`:设置player命令权限类型
|
||||
|
||||
### 其他
|
||||
|
||||
@@ -7,7 +7,6 @@
|
||||
"player": [
|
||||
{
|
||||
"condition": "minecraft:reference",
|
||||
"entity": "this",
|
||||
"name": "fzsd:used_tool"
|
||||
}
|
||||
]
|
||||
|
||||
@@ -1 +1 @@
|
||||
data modify storage fzsd:global fzsd.api.dimension.name set value '{"nbt": "fzsd.cache.dimension.id", "storage": "fzsd:global"}'
|
||||
data modify storage fzsd:global fzsd.api.dimension.name set value '{"nbt": "fzsd.api.dimension.id", "storage": "fzsd:global"}'
|
||||
@@ -1,4 +1,4 @@
|
||||
execute store success storage fzsd:version fzsd.need_update int 1 run data merge storage fzsd:version {fzsd: {version: '3.0.0'}}
|
||||
execute store success storage fzsd:version fzsd.need_update int 1 run data merge storage fzsd:version {fzsd: {version: '3.0.5'}}
|
||||
execute if data storage fzsd:version fzsd{need_update: 1} run function fzsd:system/update
|
||||
function fzsd:system/carpet/try_load_fzsd_score
|
||||
function #fzsd:load
|
||||
|
||||
@@ -4,4 +4,4 @@ execute if predicate fzsd:is_real_player run function fzsd:game_event/player/on_
|
||||
|
||||
## 重置事件
|
||||
scoreboard players operation @s fzsd.event.aviating_distance %= 200 fzsd.variable.integer
|
||||
advancement revoke @s only fzsd:game_event/on_aviate_one_meter
|
||||
advancement revoke @s from fzsd:game_event/on_aviate_one_meter
|
||||
@@ -4,4 +4,4 @@ execute if predicate fzsd:is_real_player run function fzsd:game_event/player/on_
|
||||
|
||||
## 重置事件
|
||||
scoreboard players set @s fzsd.event.death_count 0
|
||||
advancement revoke @s only fzsd:game_event/on_dead
|
||||
advancement revoke @s from fzsd:game_event/on_dead
|
||||
@@ -4,4 +4,4 @@ execute if score fzsd.logger.level fzsd.variable.integer matches ..400 run tellr
|
||||
function #fzsd:game_event/player/on_entered_nether_portal
|
||||
|
||||
## 重置事件进度
|
||||
advancement revoke @s only fzsd:game_event/on_entered_nether_portal
|
||||
advancement revoke @s from fzsd:game_event/on_entered_nether_portal
|
||||
@@ -7,4 +7,4 @@ execute if score fzsd.logger.level fzsd.variable.integer matches ..400 run tellr
|
||||
function #fzsd:game_event/player/on_fished
|
||||
|
||||
## 重置事件进度
|
||||
advancement revoke @s only fzsd:game_event/on_fished
|
||||
advancement revoke @s from fzsd:game_event/on_fished
|
||||
@@ -10,4 +10,4 @@ scoreboard players remove @s fzsd.event.used_tool.dig_offset 1
|
||||
function #fzsd:game_event/player/on_hurt_entity_with_tools
|
||||
|
||||
## 重置事件进度
|
||||
advancement revoke @s only fzsd:game_event/on_hurt_entity_with_tools
|
||||
advancement revoke @s from fzsd:game_event/on_hurt_entity_with_tools
|
||||
|
||||
@@ -7,4 +7,4 @@ execute if score fzsd.logger.level fzsd.variable.integer matches ..400 run tellr
|
||||
function #fzsd:game_event/player/on_killed_mob_or_player
|
||||
|
||||
## 重置事件进度
|
||||
advancement revoke @s only fzsd:game_event/on_killed_mob_or_player
|
||||
advancement revoke @s from fzsd:game_event/on_killed_mob_or_player
|
||||
@@ -7,4 +7,4 @@ execute if score fzsd.logger.level fzsd.variable.integer matches ..400 run tellr
|
||||
function #fzsd:game_event/player/on_piglin_trade
|
||||
|
||||
## 重置事件进度
|
||||
advancement revoke @s only fzsd:game_event/on_piglin_trade
|
||||
advancement revoke @s from fzsd:game_event/on_piglin_trade
|
||||
@@ -7,4 +7,4 @@ execute if score fzsd.logger.level fzsd.variable.integer matches ..400 run tellr
|
||||
function #fzsd:game_event/player/on_placed_block
|
||||
|
||||
## 重置事件进度
|
||||
advancement revoke @s only fzsd:game_event/on_placed_block
|
||||
advancement revoke @s from fzsd:game_event/on_placed_block
|
||||
@@ -4,4 +4,4 @@ execute if predicate fzsd:is_real_player run function fzsd:game_event/player/on_
|
||||
|
||||
## 重置事件
|
||||
scoreboard players operation @s fzsd.event.play_ticks %= 72000 fzsd.variable.integer
|
||||
advancement revoke @s only fzsd:game_event/on_play_one_hour
|
||||
advancement revoke @s from fzsd:game_event/on_play_one_hour
|
||||
@@ -10,4 +10,4 @@ scoreboard players remove @s fzsd.event.used_tool.dig_offset 1
|
||||
function #fzsd:game_event/player/on_shears_used_on_entity
|
||||
|
||||
## 重置事件进度
|
||||
advancement revoke @s only fzsd:game_event/on_shears_used_on_entity
|
||||
advancement revoke @s from fzsd:game_event/on_shears_used_on_entity
|
||||
@@ -4,4 +4,4 @@ execute if predicate fzsd:is_real_player run function fzsd:game_event/player/on_
|
||||
|
||||
## 重置事件
|
||||
scoreboard players operation @s fzsd.event.damage_taken %= 10 fzsd.variable.integer
|
||||
advancement revoke @s only fzsd:game_event/on_took_damage
|
||||
advancement revoke @s from fzsd:game_event/on_took_damage
|
||||
@@ -10,5 +10,5 @@ scoreboard players remove @s fzsd.event.used_tool.dig_offset 1
|
||||
function #fzsd:game_event/player/on_tools_used_on_block
|
||||
|
||||
## 重置事件进度
|
||||
advancement revoke @s only fzsd:game_event/on_tool_axes_used_on_block
|
||||
advancement revoke @s only fzsd:game_event/on_tools_exclude_axes_used_on_block
|
||||
advancement revoke @s from fzsd:game_event/on_tool_axes_used_on_block
|
||||
advancement revoke @s from fzsd:game_event/on_tools_exclude_axes_used_on_block
|
||||
@@ -10,4 +10,4 @@ execute if score fzsd.logger.level fzsd.variable.integer matches ..400 run tellr
|
||||
function #fzsd:game_event/player/on_unsneak
|
||||
|
||||
## 重置事件进度
|
||||
advancement revoke @s until fzsd:game_event/on_unsneak
|
||||
advancement revoke @s through fzsd:game_event/on_unsneak
|
||||
@@ -6,4 +6,4 @@ execute if predicate fzsd:is_real_player run function fzsd:game_event/player/on_
|
||||
function #fzsd:game_event/player/on_used_tool/reset_used_tool
|
||||
|
||||
## 重置事件进度
|
||||
advancement revoke @s only fzsd:game_event/on_used_tool
|
||||
advancement revoke @s from fzsd:game_event/on_used_tool
|
||||
@@ -7,4 +7,4 @@ execute if score fzsd.logger.level fzsd.variable.integer matches ..400 run tellr
|
||||
function #fzsd:game_event/player/on_villager_trade
|
||||
|
||||
## 重置事件进度
|
||||
advancement revoke @s only fzsd:game_event/on_villager_trade
|
||||
advancement revoke @s from fzsd:game_event/on_villager_trade
|
||||
-3
@@ -31,6 +31,3 @@ scoreboard players operation fzsd.var.score fzsd.variable.integer += @s fzsd.eve
|
||||
scoreboard players operation fzsd.var.score fzsd.variable.integer += @s fzsd.event.used_tool.wooden_shovel
|
||||
scoreboard players operation fzsd.var.score fzsd.variable.integer += @s fzsd.event.used_tool.wooden_sword
|
||||
scoreboard players operation fzsd.var.score fzsd.variable.integer += @s fzsd.event.used_tool.dig_offset
|
||||
|
||||
## 判断分数
|
||||
execute unless score fzsd.var.score fzsd.variable.integer matches ..0 run function fzsd:game_event/player/on_broke_block_with_tool
|
||||
@@ -0,0 +1,2 @@
|
||||
## 判断分数
|
||||
execute unless score fzsd.var.score fzsd.variable.integer matches ..0 run function fzsd:game_event/player/on_broke_block_with_tool
|
||||
@@ -3,4 +3,4 @@ execute store result storage fzsd:here fzsd.nether.x int 0.125 run data get enti
|
||||
execute store result storage fzsd:here fzsd.nether.z int 0.125 run data get entity @s Pos[2]
|
||||
data modify storage fzsd:global fzsd.api.dimension.id set value "minecraft:the_nether"
|
||||
function #fzsd:api/get_dimension_name
|
||||
data modify storage fzsd:here fzsd.message[2] set value '[{"text": ",对应", "color": "white"}, {"nbt": "fzsd.api.dimension.name", "interpret": true, "storage": "fzsd:global"}, [{"text": "[", "color": "green"}, {"nbt": "fzsd.nether.x", "storage": "fzsd:here"}, {"text": ", "}, {"nbt": "fzsd.nether.z", "storage": "fzsd:here"}, {"text": "]"}]]'
|
||||
data modify storage fzsd:here fzsd.message.append set value '[{"text": ",对应", "color": "white"}, {"nbt": "fzsd.api.dimension.name", "interpret": true, "storage": "fzsd:global"}, [{"text": "[", "color": "green"}, {"nbt": "fzsd.nether.x", "storage": "fzsd:here"}, {"text": ", "}, {"nbt": "fzsd.nether.z", "storage": "fzsd:here"}, {"text": "]"}]]'
|
||||
@@ -3,4 +3,5 @@ execute store result storage fzsd:here fzsd.overworld.x int 8 run data get entit
|
||||
execute store result storage fzsd:here fzsd.overworld.z int 8 run data get entity @s Pos[2]
|
||||
data modify storage fzsd:global fzsd.api.dimension.id set value "minecraft:overworld"
|
||||
function #fzsd:api/get_dimension_name
|
||||
data modify storage fzsd:here fzsd.message[2] set value '[{"text": ",对应", "color": "white"}, {"nbt": "fzsd.api.dimension.name", "interpret": true, "storage": "fzsd:global"}, [{"text": "[", "color": "green"}, {"nbt": "fzsd.overworld.x", "storage": "fzsd:here"}, {"text": ", "}, {"nbt": "fzsd.overworld.z", "storage": "fzsd:here"}, {"text": "]"}]]'
|
||||
data modify storage fzsd:here fzsd.message.append set value '[{"text": ",对应", "color": "white"}, {"nbt": "fzsd.api.dimension.name", "interpret": true, "storage": "fzsd:global"}, [{"text": "[", "color": "green"}, {"nbt": "fzsd.overworld.x", "storage": "fzsd:here"}, {"text": ", "}, {"nbt": "fzsd.overworld.z", "storage": "fzsd:here"}, {"text": "]"}]]'
|
||||
## 恢复用于判断的维度id
|
||||
@@ -1 +1 @@
|
||||
execute if data storage fzsd:global fzsd.api.dimension{id:"minecraft:overworld"} run function fzsd:module/here/get_dimension_message/if_overworld
|
||||
execute if data entity @s {Dimension:"minecraft:overworld"} run function fzsd:module/here/get_dimension_message/if_overworld
|
||||
@@ -1 +1 @@
|
||||
execute if data storage fzsd:global fzsd.api.dimension{id:"minecraft:the_nether"} run function fzsd:module/here/get_dimension_message/if_the_nether
|
||||
execute if data entity @s {Dimension:"minecraft:the_nether"} run function fzsd:module/here/get_dimension_message/if_the_nether
|
||||
@@ -1,8 +1,8 @@
|
||||
## fzsd.cache.pos已在install中初始化
|
||||
|
||||
execute store result storage fzsd:here fzsd.x int 1 run data get entity @s Pos[0]
|
||||
execute store result storage fzsd:here fzsd.y int 1 run data get entity @s Pos[1]
|
||||
execute store result storage fzsd:here fzsd.z int 1 run data get entity @s Pos[2]
|
||||
data modify storage fzsd:here fzsd.message.append set value ''
|
||||
|
||||
data modify storage fzsd:here fzsd.dimension.name set from storage fzsd:global fzsd.api.dimension.name
|
||||
## 调试
|
||||
execute if score fzsd.logger.level fzsd.variable.integer matches ..400 run tellraw @a [{"nbt": "fzsd.level.debug", "interpret": true, "storage": "fzsd:logger"}, {"text": "玩家"}, {"selector": "@s"}, {"text": "获取了位置信息"}]
|
||||
@@ -1 +1 @@
|
||||
tellraw @a [{"selector": "@s"}, [{"text": "说:我在", "color": "white"}, {"nbt": "fzsd.api.dimension.name", "interpret": true, "storage": "fzsd:global"}, [{"text": " [", "color": "green"}, {"nbt": "fzsd.x", "storage": "fzsd:here"}, {"text": ", "}, {"nbt": "fzsd.y", "storage": "fzsd:here"}, {"text": ", "}, {"nbt": "fzsd.z", "storage": "fzsd:here"}, {"text": "]"}], {"nbt": "fzsd.message.append", "interpret": true, "storage": "fzsd:here"}]]
|
||||
tellraw @a [{"text": ""}, [{"selector": "@s"}, {"text": "说:我在", "color": "white"}, {"nbt": "fzsd.dimension.name", "interpret": true, "storage": "fzsd:here"}, [{"text": " [", "color": "green"}, {"nbt": "fzsd.x", "storage": "fzsd:here"}, {"text": ", "}, {"nbt": "fzsd.y", "storage": "fzsd:here"}, {"text": ", "}, {"nbt": "fzsd.z", "storage": "fzsd:here"}, {"text": "]"}], {"nbt": "fzsd.message.append", "interpret": true, "storage": "fzsd:here"}]]
|
||||
@@ -1 +1 @@
|
||||
tellraw @s [{"text": "你在", "color": "white"}, {"nbt": "fzsd.api.dimension.name", "interpret": true, "storage": "fzsd:global"}, [{"text": " [", "color": "green"}, {"nbt": "fzsd.x", "storage": "fzsd:here"}, {"text": ", "}, {"nbt": "fzsd.y", "storage": "fzsd:here"}, {"text": ", "}, {"nbt": "fzsd.z", "storage": "fzsd:here"}, {"text": "]"}], {"nbt": "fzsd.message.append", "interpret": true, "storage": "fzsd:here"}]
|
||||
tellraw @s [{"text": "你在", "color": "white"}, {"nbt": "fzsd.dimension.name", "interpret": true, "storage": "fzsd:here"}, [{"text": " [", "color": "green"}, {"nbt": "fzsd.x", "storage": "fzsd:here"}, {"text": ", "}, {"nbt": "fzsd.y", "storage": "fzsd:here"}, {"text": ", "}, {"nbt": "fzsd.z", "storage": "fzsd:here"}, {"text": "]"}], {"nbt": "fzsd.message.append", "interpret": true, "storage": "fzsd:here"}]
|
||||
@@ -1,2 +1,2 @@
|
||||
execute if score @s fzsd.module.last_nether_portal.dimension matches -2147483648..2147483647 run tellraw @a [{"selector": "@s"}, [{"text": "说:我上次穿出的下界传送门位于", "color": "white"}, {"nbt": "fzsd.api.dimension.name", "interpret": true, "storage": "fzsd:global"}, [{"text": " [", "color": "green"}, {"score": {"name": "@s", "objective": "fzsd.module.last_nether_portal.x"}}, {"text": ", "}, {"score": {"name": "@s", "objective": "fzsd.module.last_nether_portal.z"}}, {"text": ", "}, {"score": {"name": "@s", "objective": "fzsd.module.last_nether_portal.z"}}, {"text": "]"}]]]
|
||||
execute if score @s fzsd.module.last_nether_portal.dimension matches -2147483648..2147483647 run tellraw @a [{"text": ""}, [{"selector": "@s"}, {"text": "说:我上次穿出的下界传送门位于", "color": "white"}, {"nbt": "fzsd.api.dimension.name", "interpret": true, "storage": "fzsd:global"}, [{"text": " [", "color": "green"}, {"score": {"name": "@s", "objective": "fzsd.module.last_nether_portal.x"}}, {"text": ", "}, {"score": {"name": "@s", "objective": "fzsd.module.last_nether_portal.z"}}, {"text": ", "}, {"score": {"name": "@s", "objective": "fzsd.module.last_nether_portal.z"}}, {"text": "]"}]]]
|
||||
execute unless score @s fzsd.module.last_nether_portal.dimension matches -2147483648..2147483647 run tellraw @s {"text": "你从未穿出过下界传送门!"}
|
||||
@@ -2,4 +2,4 @@
|
||||
data modify storage fzsd:install fzsd.global set value 0b
|
||||
|
||||
## 日志
|
||||
execute if score fzsd.logger.level fzsd.variable.integer matches ..500 run tellraw @a [{"nbt": "fzsd.level.info", "interpret": true, "storage": "fzsd:logger"}, {"text": "卸载完成!"}]
|
||||
tellraw @a [{"nbt": "fzsd.level.info", "interpret": true, "storage": "fzsd:logger"}, {"text": "卸载完成!"}]
|
||||
@@ -0,0 +1,6 @@
|
||||
{
|
||||
"replace": false,
|
||||
"values": [
|
||||
"fzsd:game_event/install"
|
||||
]
|
||||
}
|
||||
+6
@@ -0,0 +1,6 @@
|
||||
{
|
||||
"replace": false,
|
||||
"values": [
|
||||
"fzsd:game_event/player/on_broke_block_with_tool/calculate_dig_score"
|
||||
]
|
||||
}
|
||||
@@ -1,6 +1,7 @@
|
||||
{
|
||||
"replace": false,
|
||||
"values": [
|
||||
"fzsd:game_event/player/on_broke_block_with_tool/on_used_tool"
|
||||
"#fzsd:game_event/player/on_broke_block_with_tool/calculate_dig_score",
|
||||
"fzsd:game_event/player/on_broke_block_with_tool/try_trigger"
|
||||
]
|
||||
}
|
||||
@@ -0,0 +1,6 @@
|
||||
{
|
||||
"replace": false,
|
||||
"values": [
|
||||
"fzsd:game_event/uninstall"
|
||||
]
|
||||
}
|
||||
@@ -0,0 +1,6 @@
|
||||
{
|
||||
"replace": false,
|
||||
"values": [
|
||||
"fzsd:logger/install"
|
||||
]
|
||||
}
|
||||
@@ -0,0 +1,6 @@
|
||||
{
|
||||
"replace": false,
|
||||
"values": [
|
||||
"fzsd:logger/uninstall"
|
||||
]
|
||||
}
|
||||
@@ -2,7 +2,7 @@
|
||||
"replace": false,
|
||||
"values": [
|
||||
"fzsd:system/install/install",
|
||||
"fzsd:logger/install",
|
||||
"fzsd:game_event/install"
|
||||
"#fzsd:logger/install",
|
||||
"#fzsd:game_event/install"
|
||||
]
|
||||
}
|
||||
@@ -1,8 +1,8 @@
|
||||
{
|
||||
"replace": false,
|
||||
"values": [
|
||||
"fzsd:game_event/uninstall",
|
||||
"fzsd:logger/uninstall",
|
||||
"#fzsd:game_event/uninstall",
|
||||
"#fzsd:logger/uninstall",
|
||||
"fzsd:system/uninstall/uninstall"
|
||||
]
|
||||
}
|
||||
+77
-14
@@ -1,7 +1,7 @@
|
||||
// 计分板模块扩展插件
|
||||
// 忽略假人分数
|
||||
// **请勿修改文件名!!**
|
||||
global_app_version = '1.0-beta.12';
|
||||
global_app_version = '1.0-beta.13';
|
||||
global_current_scoreboard_list = [
|
||||
'fzsd.module.scoreboard.display.activation',
|
||||
'fzsd.module.scoreboard.display.damage_taken',
|
||||
@@ -103,21 +103,37 @@ __on_player_connects(player) -> (
|
||||
player_type = player ~ 'player_type';
|
||||
player_team = player ~ 'team';
|
||||
player_name = player ~ 'name';
|
||||
if(player_type == 'fake' && player_team != 'fzsd.module.scoreboard.fake',
|
||||
if(player_type == 'fake',
|
||||
(
|
||||
if(player_team != 'fzsd.module.scoreboard.fake',
|
||||
global_team_cache:player_name = player_team;
|
||||
);
|
||||
team_add('fzsd.module.scoreboard.fake', player);
|
||||
print(player('all'), '↑假的');
|
||||
),
|
||||
player_type == 'shadow' && player_team != 'fzsd.module.scoreboard.shadow',
|
||||
player_type == 'shadow',
|
||||
(
|
||||
if(player_team != 'fzsd.module.scoreboard.shadow',
|
||||
global_team_cache:player_name = player_team;
|
||||
);
|
||||
team_add('fzsd.module.scoreboard.shadow', player);
|
||||
print(player('all'), '↑挂机');
|
||||
),
|
||||
try_restore_team_from_cache(player);
|
||||
);
|
||||
);
|
||||
|
||||
__on_player_disconnects(player, reason) -> (
|
||||
player_type = player ~ 'player_type';
|
||||
if(player_type == 'fake' && player_team != 'fzsd.module.scoreboard.fake',
|
||||
(
|
||||
print(player('all'), '↓假的');
|
||||
),
|
||||
player_type == 'shadow' && player_team != 'fzsd.module.scoreboard.shadow',
|
||||
(
|
||||
print(player('all'), '↓挂机');
|
||||
)
|
||||
);
|
||||
try_restore_team_from_cache(player);
|
||||
);
|
||||
|
||||
@@ -377,27 +393,68 @@ display_total_score(scoreboard) -> (
|
||||
// 恢复计分板分数,player == null 时恢复所有玩家分数,scoreboard == null 时恢复所有计分板分数
|
||||
command_restore(player, scoreboard) -> (
|
||||
if(player == null,
|
||||
for(keys(system_info('server_whitelist')), restore_score(_, scoreboard));
|
||||
i = 0;
|
||||
for(keys(system_info('server_whitelist')),
|
||||
i += 1;
|
||||
if(i > 10,
|
||||
game_tick(50);
|
||||
i = 0;
|
||||
);
|
||||
restore_score(_, scoreboard);
|
||||
);
|
||||
if(scoreboard == null,
|
||||
print('已恢复所有玩家的所有分数')
|
||||
(
|
||||
print('重置交易榜会丢失猪灵交易分数,请输入\n“/' + global_app_name + ' restore confirm whitelist fzsd.module.scoreboard.display.trade_count”继续执行');
|
||||
print('无法还原破基岩榜,已忽略');
|
||||
print('已恢复所有玩家的所有分数');
|
||||
),
|
||||
if(scoreboard == 'fzsd.module.scoreboard.display.trade_count',
|
||||
print('重置交易榜会丢失猪灵交易分数,请输入\n“/' + global_app_name + ' restore confirm whitelist fzsd.module.scoreboard.display.trade_count”继续执行');
|
||||
,
|
||||
scoreboard == 'fzsd.module.scoreboard.display.bedrock_broken_count',
|
||||
print('无法还原破基岩榜,已忽略');
|
||||
,
|
||||
print('已恢复所有玩家的' + scoreboard + '分数');
|
||||
);
|
||||
);
|
||||
return();
|
||||
);
|
||||
if(scoreboard == null,
|
||||
for(global_current_scoreboard_list, restore_score(player, _));
|
||||
print('重置交易榜会丢失猪灵交易分数,请输入\n“/' + global_app_name + ' restore confirm player <playerName> fzsd.module.scoreboard.display.trade_count”继续执行');
|
||||
print('无法还原破基岩榜,已忽略');
|
||||
print('已恢复' + player + '的所有分数');
|
||||
return();
|
||||
);
|
||||
if(restore_score(player, scoreboard),
|
||||
print('已恢复' + player + '的' + scoreboard + '分数');
|
||||
,
|
||||
if(scoreboard == 'fzsd.module.scoreboard.display.trade_count',
|
||||
print('重置交易榜会丢失猪灵交易分数,请输入\n“/' + global_app_name + ' restore confirm whitelist fzsd.module.scoreboard.display.trade_count”继续执行');
|
||||
,
|
||||
scoreboard == 'fzsd.module.scoreboard.display.bedrock_broken_count',
|
||||
print('无法还原破基岩榜,已忽略');
|
||||
);
|
||||
);
|
||||
return();
|
||||
);
|
||||
|
||||
// 恢复玩家的计分板分数
|
||||
restore_score(player, scoreboard) -> (
|
||||
restore_score(player_name, scoreboard) -> (
|
||||
require_not_null(player_name);
|
||||
if(scoreboard == null,
|
||||
for(global_current_scoreboard_list, restore_score(player_name, _));
|
||||
return();
|
||||
);
|
||||
player = player(player_name);
|
||||
player_is_offline = false;
|
||||
if(player == null,
|
||||
(
|
||||
run('player ' + player_name + ' spawn at ~ ~ ~ facing 0 0 in minecraft:overworld in survival');
|
||||
player_is_offline = true;
|
||||
player = player(player_name);
|
||||
)
|
||||
);
|
||||
if(scoreboard == 'fzsd.module.scoreboard.display.activation',
|
||||
(
|
||||
play_ticks = statistic(player, 'custom', 'play_time');
|
||||
@@ -405,7 +462,7 @@ restore_score(player, scoreboard) -> (
|
||||
scoreboard(scoreboard, player, play_ticks/72000);
|
||||
),
|
||||
scoreboard == 'fzsd.module.scoreboard.display.damage_taken',
|
||||
restore_from_stat(scoreboard, player, 'custom', 'damage_taken');
|
||||
scoreboard(scoreboard, player, statistic(player, 'custom', 'damage_taken')/10);
|
||||
,
|
||||
scoreboard == 'fzsd.module.scoreboard.display.death_count',
|
||||
restore_from_stat(scoreboard, player, 'custom', 'deaths');
|
||||
@@ -428,15 +485,11 @@ restore_score(player, scoreboard) -> (
|
||||
);
|
||||
),
|
||||
scoreboard == 'fzsd.module.scoreboard.display.trade_count',
|
||||
(
|
||||
print('此操作会丢失猪灵交易分数,请输入\n“/' + global_app_name + ' restore confirm whitelist fzsd.module.scoreboard.display.trade_count”或\n“/' + global_app_name + ' restore confirm player <playerName> fzsd.module.scoreboard.display.trade_count”继续执行');
|
||||
return(false);
|
||||
),
|
||||
,
|
||||
scoreboard == 'fzsd.module.scoreboard.display.bedrock_broken_count',
|
||||
(
|
||||
print('无法还原破基岩榜,已忽略');
|
||||
return(false);
|
||||
),
|
||||
,
|
||||
scoreboard == 'fzsd.module.scoreboard.display.aviating_distance',
|
||||
scoreboard(scoreboard, player, statistic(player, 'custom', 'aviate_one_cm')/200);
|
||||
,
|
||||
@@ -447,10 +500,15 @@ restore_score(player, scoreboard) -> (
|
||||
append_from_stat(scoreboard, player, 'used', _);
|
||||
);
|
||||
),
|
||||
print('未识别的计分板ID!');
|
||||
print('未识别的计分板ID!' + scoreboard);
|
||||
return(false);
|
||||
);
|
||||
recalculate_total_score(scoreboard);
|
||||
if(player_is_offline,
|
||||
world_spawn = system_info('world_spawn_point');
|
||||
run('spreadplayers ' + world_spawn:0 + ' ' + world_spawn:2 + ' 0 10 false ' + player);
|
||||
run('player ' + player + ' kill');
|
||||
);
|
||||
return(true);
|
||||
);
|
||||
|
||||
@@ -504,3 +562,8 @@ debug(msg) -> (
|
||||
logger('debug', msg);
|
||||
return();
|
||||
);
|
||||
|
||||
require_not_null(value) -> (
|
||||
if(value == null, throw('空指针异常!'));
|
||||
return(value);
|
||||
);
|
||||
Reference in New Issue
Block a user