Java Edition 1.19.4

1.19.4 is an upcoming minor update to with no set release date, which adds the  command, makes technical changes, and fixes bugs.

Non-mob entities

 * Display Entities
 * Including Block Display, Item Display, and Text Display, for flexible display of blocks, items and text.
 * Like marker, don't tick and have no collisions or physics.
 * Models render at entity position, with normal rotation around X and Y axis (so it can be controlled by teleport commands), but also with additional arbitrary model transform.
 * 2 new data types added, each of them has 2 forms, but only one for saving, as following:
 * Quaternion form (used for saving): array of 4 numbers, describing components (x, y, z, w).
 * Axis-angle form: object with following fields:
 * : 3D vector.
 * : Angle in radians.
 * : Arbitrary affine transform, composed as following fields and following order:
 * Matrix form: array of 16 numbers, describing row-major matrix.
 * Decomposed form (used for saving): object with following fields:
 * : 3D vector.
 * : object.
 * : 3D vector.
 * : object.
 * Some properties of display entites can be interpolated, to create gradual changes over time for clients, instead of instantenous jumps.
 * Display entities keep track of current and previous values of interpolated values:
 * All properties marked as "interpolated" are part of a single interpolation set.
 * Any update to interpolated property will cause all values of interpolation set to be saved as "current".
 * Data command executions that do not change value of property (even if it's present in NBT) do not count as updates.
 * Updates are synchronized to clients at most once per tick, so multiple updates within command will still count as single update.
 * Previous current values are saved as "previous".
 * If interpolation is enabled, entity will transition between "previous" and "current" values over time.
 * Start of interpolation (entity fully in "previous" state) is defined by field (game time, in ticks).
 * Set to to load current game time instead.
 * End of interpolation (entity fully in "current" state) is defined as +  (in ticks).
 * Every entity in family has the following fields:
 * : applied to model (after normal entity orientation). Defaults to identity. Interpolated.
 * : option to control if entity should pivot to face player when rendered:
 * : No rotation (default).
 * Entity can pivot around vertical axis.
 * Entity can pivot around horizontal axis.
 * Entity can pivot around center point.
 * : If present, overrides light values used for rendering. Omited by default (which means rendering uses values from entity position). Object has two fields:
 * : Value of skylight, from 0 to 15.
 * : Value of block light, from 0 to 15.
 * : Maximum view range of this entity. Actual distance depends on client-side render distance and entity distance scalling. Default value 1.0 (roughly the same as fireball).
 * : Size of shadow. Defaults to 0 (no shadow). Interpolated.
 * : Strength of the shadow. Controls the opacity of the shadow as a function of distance to block below. Defaults to 1. Interpolated.
 * : Describe size of culling bounding box. Bounding box spans vertically to  and horizontally  in all directions from entity position. If either field is set to 0, culling is disabled. Both default to 0.
 * : Override glow border color. Defaults to 0 (use team color).
 * Besides common fields, these entitiy types also have some exclusive fields for their different usages:
 * Item Display : Displays a single item stack (stack can be changed with commands by setting slot ).
 * : Item stack to display. Same format as in inventory.
 * Example:
 * : Describes item model transform applied to item (as defined in section in model JSON)
 * Values: (default),.
 * Block Display : Displays a block state, does not display block entities, even if they would normally be created on block placement (like chest).
 * : Block state to display. Same format as item held by endermen.
 * Example:.
 * Text Display : Displays a text component (backgrounds uses new shader types ).
 * : Text to display. Components are resolved with the context of the display entity.
 * : Line width used to split lines (note: new line can be also addded with characters). Defaults to 200.
 * : Opacity (alpha component) of rendered text. Defaults to 255. Interpolated.
 * : Color of background. Includes alpha channel. Defaults to 0x40000000. Interpolated.
 * : If true, rendering uses default text background color (same as in chat). Defaults to false.
 * : Should text be displayed with shadow. Defaults to false.
 * : Should text be visible through blocks. Defaults to false.
 * : How text should be aligned.
 * Values: (default),.
 * Values: (default),.

Command format

 * Game rule
 * Added.
 * Defaults to.
 * Controls the maximum number of blocks changed in one execution of, , and commands.
 * Added.
 * Defaults to.
 * Determines if vines will spread to nearby blocks.
 * Does not affect cave vines, twisting vines and weeping vines.


 * A new command to apply damage to entities, with following syntaxes:
 * Parameters:
 * : The entity to damage.
 * : Amount of damage to inflict.
 * : The type of damage to inflict.
 * This determines how the damage affects the entity as well as which death message is displayed.
 * : The location the damage originated at (when no entity caused the damage).
 * For instance, might represent the location of a bed exploding in the Nether.
 * : The entity inflicting the damage.
 * : The cause of the damage, in the case of indirect damage.
 * Example: When shot by an arrow, the is the arrow projectile while  might be a skeleton.
 * : The entity inflicting the damage.
 * : The cause of the damage, in the case of indirect damage.
 * Example: When shot by an arrow, the is the arrow projectile while  might be a skeleton.


 * Added sub-command, with the following syntax:
 * This sub-command is for summoning new entity and binding context to it. Meant to simplify entity setup and reduce need for raw NBT editing.
 * This sub-command is for summoning new entity and binding context to it. Meant to simplify entity setup and reduce need for raw NBT editing.
 * This sub-command is for summoning new entity and binding context to it. Meant to simplify entity setup and reduce need for raw NBT editing.


 * A new command to allow entities to start or stop riding other entities, syntaxes:
 * : makes a single target mount a single vehicle, will fail if:
 * is a player;
 * is already riding a vehicle;
 * and are the same entity;
 * is already a passenger (direct or indirect) of.
 * : dismounts from any vehicle it is riding, will fail if  is not riding anything.
 * : dismounts from any vehicle it is riding, will fail if  is not riding anything.

General

 * Data pack
 * Added damage types, which are a new registry.
 * Determines how damage is handled by the game.
 * Includes which attributes the damage has as well as which death message is used when an entity dies due to that type of damage, example:
 * Fields:
 * : The message id used for deaths caused by this damage type.
 * Will be combined with other string fragments to form a translation key.
 * : The amount of hunger exhaustion caused by this damage type.
 * : Whether this damage type scales with difficulty levels. Possible values:
 * : Damage is always the same.
 * : Damage always scales with difficulty.
 * : Damage scales with difficulty if it was caused by a living entity who is not a player.
 * : Optional field controlling how damage manifests when inflicted on players. Possible values:
 * (default): The default hurt sound.
 * : Thorns hurt sound.
 * : Drowning sound.
 * : A single tick of burning sound.
 * : Berry bush poke sound.
 * : Freeze tick sound.
 * : Optional field that controls if special death message variants are used. Possible values:
 * (default): No special death message logic is applied.
 * : Show a variant of fall damage death instead of a regular death message, e.g..
 * : Show the intentional game design message instead of a regular death message.
 * Damage type tags control many aspects of how damage from different sources are interpreted.


 * Menu screen
 * Added an accessibility onboarding screen for players launching the game for the first time, which allows players to turn on the narrator and change accessibility settings if needed.
 * Added arrow key navigation.
 * Menu screens can now be navigated by using the arrow keys.
 * When navigating with arrow keys, sliders need to be activated by pressing or  to start changing their value.


 * Options
 * Added a new "Notification Time" accessibility option, to change how long the notifications such as unlocked recipes, advancements, subtitles and selected item names are visible.
 * Added "Glint Speed" and "Glint Strength" accessibility option for adjusting the speed and transparency of enchantment glints.
 * Added "Damage Tilt" accessibility option, for controlling the amount of camera shake when being hurt.
 * Added a tooltip in the Key Binds screen that specifies which keybinds are conflicting.


 * Protocol
 * Added a network protocol feature for forcing bundle of packets to be processed within same client tick.
 * Added new delimiter packet to clientbound game protocol.
 * All packets between two delimiters are guaranteed to be processed within same tick.
 * For security reasons this feature is not supported in serverbound direction.


 * Tag
 * Added following biome tags:
 * : contains.
 * Fire will burn out faster in these defined biomes.
 * : contains.
 * Snow golems will melt in these defined biomes.
 * : contains.
 * Snow foxes will spawn in these defined biomes.
 * : contains.
 * White rabbits will spawn in these defined biomes.
 * Added following damage type tags:
 * : contains.
 * : contains.
 * : contains.
 * : contains.
 * : contains.
 * : contains.
 * : contains.
 * : contains.
 * : contains.
 * : contains.
 * : contains.
 * : contains.
 * : contains.
 * : contains.
 * : contains.
 * : contains.
 * : contains.
 * : contains.
 * : contains.
 * : contains.
 * : contains.
 * : contains.


 * General
 * Added argument to dedicated server command line for printing  to file.

Blocks

 * Jukebox
 * Now emit a note particle above them while playing a music disc, to match.


 * Sculk Sensor
 * Are now able to detect more events, such as the following:
 * Turtle and frogs laying eggs (signal 6).
 * Using shears on kelp, twisting vines and weeping vines (signal 6).
 * Closing a minecart with chest or a boat with chest (signal 14).
 * Picking an item from a cave vine or a lectern (signal 6).
 * Interacting with items placed on both types of item frames (signal 6).
 * Trampling farmland into regular dirt (signal 6).
 * Dyeing a sheep (signal 7).
 * Attaching or removing a lead from an entity (signal 8).
 * Charging up a respawn anchor (signal 6).
 * Mounting and dismounting a boat (signal 7 and 6 respectively).
 * Interacting with a composter (signal 6).

Items

 * Armor and Elytra
 * Now can swap the equipped gears by them.


 * Shield
 * A sound is now played when a shield is placed into the offhand slot.


 * General
 * Enchantment glint on items and armor is now more subtle.

Mobs

 * Donkey, Mule, Skeleton Horse, and Zombie Horse
 * Changed their textures.


 * Vex
 * Now use a separate charging animation when empty-handed.

Non-mob entities

 * Armor Stand
 * Now preserve custom names when placed and broken.


 * Minecart with Hopper
 * No longer aggravates piglins.

Command format

 * Chat component
 * Added an optional field to  text components.
 * The new field is a string that will be used in place of translation if it is missing.
 * If is missing, the old behavior (i.e. using the key itself as the translation) is preserved.
 * Out-of-bound arguments in formats are no longer silently ignored.


 * Now supports specifying the source and target dimensions, new syntax:
 * {{cmd|link=none|clone [from
 * The resulting textures can be referenced in other resources like this:
 * The resulting textures can be referenced in other resources like this:


 * Tag
 * Added following item tags:
 * {{cd|#noteblock_top_instruments}}: contains {{cd|d=and|zombie_head|skeleton_skull|creeper_head|dragon_head|wither_skeleton_skull|piglin_head|player_head}}.
 * {{cd|#trim_materials}}: contains {{cd|d=and|amethyst_shard|copper_ingot|diamond|emerald|gold_ingot|iron_ingot|lapis_lazuli|netherite_ingot|quartz|redstone}}.
 * {{cd|#trim_templates}}: contains {{cd|d=and|coast_armor_trim_smithing_template|dune_armor_trim_smithing_template|eye_armor_trim_smithing_template|rib_armor_trim_smithing_template|sentry_armor_trim_smithing_template|snout_armor_trim_smithing_template|spire_armor_trim_smithing_template|tide_armor_trim_smithing_template|vex_armor_trim_smithing_template|ward_armor_trim_smithing_template|wild_armor_trim_smithing_template}}.
 * {{cd|#trimmable_armor}}: contains {{cd|d=and|chainmail_boots|chainmail_chestplate|chainmail_helmet|chainmail_leggings|diamond_boots|diamond_chestplate|diamond_helmet|diamond_leggings|golden_boots|golden_chestplate|golden_helmet|golden_leggings|iron_boots|iron_chestplate|iron_helmet|iron_leggings|leather_helmet|leather_chestplate|leather_leggings|leather_boots|netherite_boots|netherite_chestplate|netherite_helmet|netherite_leggings|turtle_helmet}}.

Blocks

 * Head
 * They can be placed on top of note blocks without sneaking now.

Items

 * Armor
 * Now can be visually customized with a variety of unique trims at the smithing table.
 * Purely visual with no gameplay benefits, and can only be applied to helmets, chestplates, leggings and boots.
 * All trim patterns are visually the same on an armor's item icon, but the color will still change based on the trim material.
 * The name of the trim pattern will be displayed on the item's tooltip.
 * Armor trim has 2 properties: pattern and material.
 * Pattern: Defined by the smithing template used to apply the trim, and represents the visual pattern of the trim.
 * Material: Defined by what ingredient is used to apply the trim, and represents the color of the trim.
 * Available ingredients:

Gameplay

 * Smithing Table functionality
 * Redesigned: it is now a workstation for physical equipment upgrades and modifications.
 * Added a slot used by smithing templates to the left of the old 2 slots.
 * Smithing templates define what type of upgrade that will be making to equipment.
 * It specifies both what type of items that can upgrade, and which ingredients are valid to customize the upgrade.
 * Netherite equipment crafting now also requires a netherite upgrade smithing template.
 * Two menu types:
 * Old menu without the smithing template slot has been renamed to, and will be removed when armor trims are no longer an experimental feature.
 * New menu with smithing template slot was added, called.