# 时间

# GetLocalDoDayNightCycle

服务端

method in mod.server.component.dimensionCompServer.DimensionCompServer

  • 描述

    获取维度是否打开昼夜更替

  • 参数

    参数名
    数据类型
    说明
    dimension int 维度id
  • 返回值

    数据类型
    说明
    bool 是否打开昼夜更替
  • 备注

    • 维度使用局部时间规则时,返回维度自身的昼夜更替规则;没有使用时返回全局的昼夜更替规则
    • 关于“局部时间规则”,见SetUseLocalTime
  • 示例

import mod.server.extraServerApi as serverApi
comp = serverApi.GetEngineCompFactory().CreateDimension(levelId)
comp.GetLocalDoDayNightCycle(3)

# GetLocalTime

服务端

method in mod.server.component.dimensionCompServer.DimensionCompServer

  • 描述

    获取维度的时间

  • 参数

    参数名
    数据类型
    说明
    dimension int 维度id
  • 返回值

    数据类型
    说明
    int 时间,单位为帧数,表示该存档从新建起经过的时间,而非当前游戏天内的时间。mc中一个游戏天相当于现实的20分钟,即24000帧
  • 备注

    • 维度使用局部时间规则时,返回局部时间;没有使用时返回全局时间
    • 关于“局部时间规则”,见SetUseLocalTime
  • 示例

import mod.server.extraServerApi as serverApi
comp = serverApi.GetEngineCompFactory().CreateDimension(levelId)
# 从游戏开始经过的总帧数
passedTime = comp.GetLocalTime(3)
# 当前游戏天内的帧数
timeOfDay = passedTime % 24000
# 从游戏开始经过的游戏天数
day = passedTime / 24000

# GetTime

服务端客户端

# 服务端接口

method in mod.server.component.timeCompServer.TimeComponentServer

  • 描述

    获取当前世界时间

  • 参数

  • 返回值

    数据类型
    说明
    int 当前时间,单位为帧数,表示该存档从新建起经过的时间,而非当前游戏天内的时间。mc中一个游戏天相当于现实的20分钟,即24000帧
  • 备注

    • 注意关闭昼夜更替后当前世界的时间会暂停
  • 示例

import mod.server.extraServerApi as serverApi
comp = serverApi.GetEngineCompFactory().CreateTime(levelId)
# 从游戏开始经过的总帧数
passedTime = comp.GetTime()
# 当前游戏天内的帧数
timeOfDay = passedTime % 24000
# 从游戏开始经过的游戏天数
day = passedTime / 24000

# 客户端接口

method in mod.client.component.timeCompClient.TimeComponentClient

  • 描述

    获取当前世界时间

  • 参数

  • 返回值

    数据类型
    说明
    int 当前时间,单位为帧数,表示该存档从新建起经过的时间,而非当前游戏天内的时间。mc中一个游戏天相当于现实的20分钟,即24000帧
  • 备注

    • 注意关闭昼夜更替后当前世界的时间会暂停
  • 示例

import mod.client.extraClientApi as clientApi
comp = clientApi.GetEngineCompFactory().CreateTime(levelId)
# 从游戏开始经过的总帧数
passedTime = comp.GetTime()
# 当前游戏天内的帧数
timeOfDay = passedTime % 24000
# 从游戏开始经过的游戏天数
day = passedTime / 24000

# GetUseLocalTime

服务端

method in mod.server.component.dimensionCompServer.DimensionCompServer

  • 描述

    获取某个维度是否设置了使用局部时间规则

  • 参数

    参数名
    数据类型
    说明
    dimension int 维度id
  • 返回值

    数据类型
    说明
    bool 是否使用局部时间规则
  • 备注

  • 示例

import mod.server.extraServerApi as serverApi
comp = serverApi.GetEngineCompFactory().CreateDimension(levelId)
comp.GetUseLocalTime(3)

# SetLocalDoDayNightCycle

服务端

method in mod.server.component.dimensionCompServer.DimensionCompServer

  • 描述

    设置使用局部时间规则的维度是否打开昼夜更替

  • 参数

    参数名
    数据类型
    说明
    dimension int 维度id
    value bool 是否打开昼夜更替
  • 返回值

    数据类型
    说明
    bool 是否设置成功
  • 备注

    • 只有使用局部时间规则维度才能设置
    • 关于“局部时间规则”,见SetUseLocalTime
    • 在pc开发包下,可以在聊天栏键入dmtime cycle ondmtime cycle off来测试开启与关闭当前维度的昼夜更替
  • 示例

import mod.server.extraServerApi as serverApi
comp = serverApi.GetEngineCompFactory().CreateDimension(levelId)
comp.SetLocalDoDayNightCycle(3, False)

# SetLocalTime

服务端

method in mod.server.component.dimensionCompServer.DimensionCompServer

  • 描述

    设置使用局部时间规则维度的时间

  • 参数

    参数名
    数据类型
    说明
    dimension int 维度id
    time int 时间,单位为帧数。表示该存档从新建起经过的时间,而非当前游戏天内的时间。mc中一个游戏天相当于现实的20分钟,即24000帧
  • 返回值

    数据类型
    说明
    bool 是否设置成功
  • 备注

    • 游戏有天数的概念,使用时需要进行考虑。您也可以直接使用SetLocalTimeOfDay设置一天内所在的时间而不用计算天数。
    • 只有使用局部时间规则维度才能设置
    • 关于“局部时间规则”,见SetUseLocalTime
  • 示例

import mod.server.extraServerApi as serverApi
comp = serverApi.GetEngineCompFactory().CreateDimension(levelId)
# 获取当前的时间
passedTime = comp.GetLocalTime(3)
# 获取当前的天数
day = passedTime / 24000
# 设置为当天的正午
comp.SetLocalTime(3, day * 24000 + 6000)
# 设置为次日的日出
comp.SetLocalTime(3, (day + 1) * 24000 + 0)

# SetLocalTimeOfDay

服务端

method in mod.server.component.dimensionCompServer.DimensionCompServer

  • 描述

    设置使用局部时间规则维度在一天内所在的时间

  • 参数

    参数名
    数据类型
    说明
    dimension int 维度id
    timeOfDay int 时间,单位为帧数,表示游戏天内的时间,范围为0到24000。mc中一个游戏天相当于现实的20分钟,即24000帧
  • 返回值

    数据类型
    说明
    bool 设置是否成功
  • 备注

    • 具体的逻辑与time指令相同,若timeOfDay比当前时间晚,则设置到当天的timeOfDay;若timeOfDay比当前时间早,则设置到次日的timeOfDay
    • 在pc开发包下,可以在聊天栏键入dmtime time <int:帧数>来测试设置当前维度的局部时间
  • 示例

import mod.server.extraServerApi as serverApi
comp = serverApi.GetEngineCompFactory().CreateDimension(levelId)
# 设置为正午
comp.SetLocalTimeOfDay(3, 6000)

# SetTime

服务端

method in mod.server.component.timeCompServer.TimeComponentServer

  • 描述

    设置当前世界时间

  • 参数

    参数名
    数据类型
    说明
    time int 时间,单位为帧数,表示该存档从新建起经过的时间,而非当前游戏天内的时间。mc中一个游戏天相当于现实的20分钟,即24000帧
  • 返回值

    数据类型
    说明
    bool 设置是否成功
  • 备注

    • 游戏有天数的概念,使用时需要进行考虑。您也可以直接使用SetTimeOfDay设置一天内所在的时间而不用计算天数。
  • 示例

import mod.server.extraServerApi as serverApi
comp = serverApi.GetEngineCompFactory().CreateTime(levelId)
# 获取当前的时间
passedTime = comp.GetTime()
# 获取当前的天数
day = passedTime / 24000
# 设置为当天的正午
comp.SetTime(day * 24000 + 6000)
# 设置为次日的日出
comp.SetTime((day + 1) * 24000 + 0)

# SetTimeOfDay

服务端

method in mod.server.component.timeCompServer.TimeComponentServer

  • 描述

    设置当前世界在一天内所在的时间

  • 参数

    参数名
    数据类型
    说明
    timeOfDay int 时间,单位为帧数,表示游戏天内的时间,范围为0到24000。mc中一个游戏天相当于现实的20分钟,即24000帧
  • 返回值

    数据类型
    说明
    bool 设置是否成功
  • 备注

    • 具体的逻辑与time指令相同,若timeOfDay比当前时间晚,则设置到当天的timeOfDay;若timeOfDay比当前时间早,则设置到次日的timeOfDay
  • 示例

import mod.server.extraServerApi as serverApi
comp = serverApi.GetEngineCompFactory().CreateTime(levelId)
# 设置为正午
comp.SetTimeOfDay(6000)

# SetUseLocalTime

服务端

method in mod.server.component.dimensionCompServer.DimensionCompServer

  • 描述

    让某个维度拥有自己的局部时间规则,开启后该维度可以拥有与其他维度不同的时间与是否昼夜更替的规则

  • 参数

    参数名
    数据类型
    说明
    dimension int 维度id
    value bool 是否开启局部时间规则
  • 返回值

    数据类型
    说明
    bool 是否设置成功
  • 备注

    • 我们对主世界以及自定义维度新增了“局部时间规则”的概念。在此之前,所有的维度会共享一个“全局时间”,即设置时间或dodaynightcycle规则时,会对所有维度生效。 现在,我们可以将某个维度使用局部时间规则,并且单独设置他的时间(见SetLocalTime)与dodaynightcycle规则(见SetLocalDoDayNightCycle)。 在下文中,我们会将使用局部时间规则的维度称为“局部维度”,而使用全局时间的维度称为“全局维度”。默认情况下,维度都是全局维度。 原版的time指令,gamerule dodaylightcycle指令与开启昼夜更替的设置,daylock指令与终为白日的设置,均不会对局部维度生效。 当世界上同时存在局部维度与全局维度时,只有以下两种情况可以睡觉来跳过黑夜:
      1. 所有玩家都在全局维度睡觉。这时会将全局时间跳到第二天早上。
      2. 所有玩家都在同一个局部维度睡觉。这时会将该局部维度的时间跳到第二天早上。
    • 启用局部时间规则时,默认继承全局的时间与昼夜更替规则
    • 时间规则对原版的下界与末地无效,这两个维度永远为黑夜且没有昼夜更替
    • 建议统一在游戏启动时调用
    • 在pc开发包下,可以在聊天栏键入dmtime ondmtime off来测试开启与关闭当前维度的局部时间
  • 示例

import mod.server.extraServerApi as serverApi
comp = serverApi.GetEngineCompFactory().CreateDimension(levelId)
comp.SetUseLocalTime(3, True)