A class that wraps the state of a world - a set of dimensions and the environment of Minecraft.

Hierarchy

  • World

Constructors

  • Returns World

Properties

afterEvents: WorldAfterEvents

Remarks

Contains a set of events that are applicable to the entirety of the world. Event callbacks are called in a deferred manner. Event callbacks are executed in read-write mode.

beforeEvents: WorldBeforeEvents

Remarks

Contains a set of events that are applicable to the entirety of the world. Event callbacks are called immediately. Event callbacks are executed in read-only mode.

Example

customCommand.ts

import { world, DimensionLocation } from "@minecraft/server";

function customCommand(targetLocation: DimensionLocation) {
const chatCallback = world.beforeEvents.chatSend.subscribe((eventData) => {
if (eventData.message.includes("cancel")) {
// Cancel event if the message contains "cancel"
eventData.cancel = true;
} else {
const args = eventData.message.split(" ");

if (args.length > 0) {
switch (args[0].toLowerCase()) {
case "echo":
// Send a modified version of chat message
world.sendMessage(`Echo '${eventData.message.substring(4).trim()}'`);
break;
case "help":
world.sendMessage(`Available commands: echo <message>`);
break;
}
}
}
});
}
gameRules: GameRules

Remarks

The game rules that apply to the world.

isHardcore: boolean
scoreboard: Scoreboard

Remarks

Returns the general global scoreboard that applies to the world.

structureManager: StructureManager

Remarks

Returns the manager for Structure related APIs.

Methods

  • Beta

    Parameters

    • id: string

      The message identifier.

    • value: string

      The message.

    Returns void

    Remarks

    A method that is internal-only, used for broadcasting specific messages between client and server.

    This function can't be called in read-only mode.

  • Returns void

    Remarks

    Clears the set of dynamic properties declared for this behavior pack within the world.

  • Returns number

    Remarks

    Returns the absolute time since the start of the world.

  • Beta

    Returns AimAssistRegistry

    Remarks

    The aim-assist presets and categories that can be used in the world.

    Required Experiments:

    • Camera Aim Assist
  • Returns Player[]

    Remarks

    Returns an array of all active players within the world.

    Throws

    This function can throw errors.

  • Returns number

    The current day, determined by the world time divided by the number of ticks per day. New worlds start at day 0.

    Remarks

    Returns the current day.

  • Returns Vector3

    The default Overworld spawn location. By default, the Y coordinate is 32767, indicating a player's spawn height is not fixed and will be determined by surrounding blocks.

    Remarks

    Returns the default Overworld spawn location.

  • Parameters

    • dimensionId: string

      The name of the dimension. For example, "overworld", "nether" or "the_end".

    Returns Dimension

    The requested dimension

    Remarks

    Returns a dimension object.

    Throws

    Throws if the given dimension name is invalid

  • Parameters

    • identifier: string

      The property identifier.

    Returns undefined | string | number | boolean | Vector3

    Returns the value for the property, or undefined if the property has not been set.

    Remarks

    Returns a property value.

    Throws

    Throws if the given dynamic property identifier is not defined.

    Example

    incrementDynamicProperty.ts

    import { world, DimensionLocation } from "@minecraft/server";

    function incrementDynamicProperty(
    log: (message: string, status?: number) => void,
    targetLocation: DimensionLocation
    ) {
    let number = world.getDynamicProperty("samplelibrary:number");

    log("Current value is: " + number);

    if (number === undefined) {
    number = 0;
    }

    if (typeof number !== "number") {
    log("Number is of an unexpected type.");
    return -1;
    }

    world.setDynamicProperty("samplelibrary:number", number + 1);
    }

    Example

    incrementDynamicPropertyInJsonBlob.ts

    import { world, DimensionLocation } from "@minecraft/server";

    function incrementDynamicPropertyInJsonBlob(
    log: (message: string, status?: number) => void,
    targetLocation: DimensionLocation
    ) {
    let paintStr = world.getDynamicProperty("samplelibrary:longerjson");
    let paint: { color: string; intensity: number } | undefined = undefined;

    log("Current value is: " + paintStr);

    if (paintStr === undefined) {
    paint = {
    color: "purple",
    intensity: 0,
    };
    } else {
    if (typeof paintStr !== "string") {
    log("Paint is of an unexpected type.");
    return -1;
    }

    try {
    paint = JSON.parse(paintStr);
    } catch (e) {
    log("Error parsing serialized struct.");
    return -1;
    }
    }

    if (!paint) {
    log("Error parsing serialized struct.");
    return -1;
    }

    paint.intensity++;
    paintStr = JSON.stringify(paint); // be very careful to ensure your serialized JSON str cannot exceed limits
    world.setDynamicProperty("samplelibrary:longerjson", paintStr);
    }
  • Returns string[]

    A string array of active dynamic property identifiers.

    Remarks

    Gets a set of dynamic property identifiers that have been set in this world.

  • Returns number

    Remarks

    Gets the total byte count of dynamic properties. This could potentially be used for your own analytics to ensure you're not storing gigantic sets of dynamic properties.

  • Parameters

    • id: string

      The id of the entity.

    Returns undefined | Entity

    The requested entity object.

    Remarks

    Returns an entity based on the provided id.

    Throws

    Throws if the given entity id is invalid.

  • Returns MoonPhase

    Remarks

    Returns the MoonPhase for the current time.

  • Parameters

    • Optional options: EntityQueryOptions

      Additional options that can be used to filter the set of players returned.

    Returns Player[]

    A player array.

    Remarks

    Returns a set of players based on a set of conditions defined via the EntityQueryOptions set of filter criteria.

    Throws

    Throws if the provided EntityQueryOptions are invalid.

  • Returns number

    The time of day, in ticks, between 0 and 24000.

    Remarks

    Returns the time of day.

  • Parameters

    Returns void

    Remarks

    Plays a particular music track for all players.

    This function can't be called in read-only mode.

    Throws

    This function can throw errors.

    Example

    playMusicAndSound.ts

    import { world, MusicOptions, WorldSoundOptions, PlayerSoundOptions, DimensionLocation } from "@minecraft/server";

    function playMusicAndSound(targetLocation: DimensionLocation) {
    const players = world.getPlayers();

    const musicOptions: MusicOptions = {
    fade: 0.5,
    loop: true,
    volume: 1.0,
    };
    world.playMusic("music.menu", musicOptions);

    const worldSoundOptions: WorldSoundOptions = {
    pitch: 0.5,
    volume: 4.0,
    };
    world.playSound("ambient.weather.thunder", targetLocation, worldSoundOptions);

    const playerSoundOptions: PlayerSoundOptions = {
    pitch: 1.0,
    volume: 1.0,
    };

    players[0].playSound("bucket.fill_water", playerSoundOptions);
    }
  • Parameters

    • trackId: string

      Identifier of the music track to play.

    • Optional musicOptions: MusicOptions

      Additional options for the music track.

    Returns void

    Remarks

    Queues an additional music track for players. If a track is not playing, a music track will play.

    This function can't be called in read-only mode.

    Throws

    An error will be thrown if volume is less than 0.0. An error will be thrown if fade is less than 0.0.

  • Parameters

    Returns void

    Remarks

    Sends a message to all players.

    Throws

    This method can throw if the provided RawMessage is in an invalid format. For example, if an empty name string is provided to score.

  • Parameters

    • absoluteTime: number

      The world time, in ticks.

    Returns void

    Remarks

    Sets the world time.

    This function can't be called in read-only mode.

  • Parameters

    • spawnLocation: Vector3

      Location of the spawn point. Note that this is assumed to be within the overworld dimension.

    Returns void

    Remarks

    Sets a default spawn location for all players.

    This function can't be called in read-only mode.

    Throws

    Throws if the provided spawn location is out of bounds.

    Error

    LocationOutOfWorldBoundariesError

  • Beta

    Parameters

    • values: Record<string, string | number | boolean | Vector3>

      A Record of key value pairs of the dynamic properties to set.

    Returns void

    Remarks

    Sets multiple dynamic properties with specific values.

    Throws

    This function can throw errors.

  • Parameters

    • identifier: string

      The property identifier.

    • Optional value: string | number | boolean | Vector3

      Data value of the property to set.

    Returns void

    Remarks

    Sets a specified property to a value.

    Throws

    Throws if the given dynamic property identifier is not defined.

    Example

    incrementDynamicProperty.ts

    import { world, DimensionLocation } from "@minecraft/server";

    function incrementDynamicProperty(
    log: (message: string, status?: number) => void,
    targetLocation: DimensionLocation
    ) {
    let number = world.getDynamicProperty("samplelibrary:number");

    log("Current value is: " + number);

    if (number === undefined) {
    number = 0;
    }

    if (typeof number !== "number") {
    log("Number is of an unexpected type.");
    return -1;
    }

    world.setDynamicProperty("samplelibrary:number", number + 1);
    }

    Example

    incrementDynamicPropertyInJsonBlob.ts

    import { world, DimensionLocation } from "@minecraft/server";

    function incrementDynamicPropertyInJsonBlob(
    log: (message: string, status?: number) => void,
    targetLocation: DimensionLocation
    ) {
    let paintStr = world.getDynamicProperty("samplelibrary:longerjson");
    let paint: { color: string; intensity: number } | undefined = undefined;

    log("Current value is: " + paintStr);

    if (paintStr === undefined) {
    paint = {
    color: "purple",
    intensity: 0,
    };
    } else {
    if (typeof paintStr !== "string") {
    log("Paint is of an unexpected type.");
    return -1;
    }

    try {
    paint = JSON.parse(paintStr);
    } catch (e) {
    log("Error parsing serialized struct.");
    return -1;
    }
    }

    if (!paint) {
    log("Error parsing serialized struct.");
    return -1;
    }

    paint.intensity++;
    paintStr = JSON.stringify(paint); // be very careful to ensure your serialized JSON str cannot exceed limits
    world.setDynamicProperty("samplelibrary:longerjson", paintStr);
    }
  • Parameters

    • timeOfDay: number

      The time of day, in ticks, between 0 and 24000.

    Returns void

    Remarks

    Sets the time of day.

    This function can't be called in read-only mode.

    Throws

    Throws if the provided time of day is not within the valid range.

  • Returns void

    Remarks

    Stops any music tracks from playing.

    This function can't be called in read-only mode.