Difference between revisions of "Pre-release protocol"

From wiki.vg
Jump to navigation Jump to search
(16w20a protocol changes)
Line 10: Line 10:
  
 
No changes so far.
 
No changes so far.
 
=== Packets ===
 
  
 
=== Packets ===
 
=== Packets ===
Line 28: Line 26:
 
  |}
 
  |}
  
 +
== New/modified data types ==
 +
 +
=== Entity Metadata ===
 +
 +
Format is now an array of entries, each of which looks like the following:
 +
 +
{| class="wikitable"
 +
! Name
 +
! Type
 +
! Meaning
 +
|-
 +
| Index
 +
| Unsigned Byte
 +
| Unique index key determining the meaning of the following value, see the table below. If this is <code>0xff</code> then the it is the end of the Entity Metadata array and no more is read.
 +
|-
 +
| Type
 +
| Optional Byte Enum
 +
| Only if Index is not <code>0xff</code>; the type of the index, see the table below
 +
|-
 +
| Value
 +
| Optional ''value of Type''
 +
| Only if Index is not <code>0xff</code>: the value of the metadata field
 +
|}
  
<!--
 
 
{| class="wikitable"
 
{| class="wikitable"
  ! ID
+
  ! Value of Type field
  ! Packet name
+
  ! [[Data types|Type]] of Value field
  !colspan="2"| Documentation
+
  ! Notes
 +
|-
 +
| 0
 +
| Byte
 +
|
 +
|-
 +
| 1
 +
| VarInt
 +
|
 +
|-
 +
| 2
 +
| Float
 +
|
 +
|-
 +
| 3
 +
| String
 +
|
 +
|-
 +
| 4
 +
| [[Chat]]
 +
|
 +
|-
 +
| 5
 +
| [[Slot]]
 +
|
 +
|-
 +
| 6
 +
| Boolean
 +
|
 +
|-
 +
| 7
 +
| Rotation
 +
| 3 floats: rotation on x, rotation on y, rotation on z
 +
|-
 +
| 8
 +
| [[Data Types#Position|Position]]
 +
|
 +
|-
 +
| 9
 +
| OptPosition (Boolean + Optional Position)
 +
| Position is present if the Boolean is set to true
 +
|-
 +
| 10
 +
| Direction (VarInt)
 +
| (Down = 0, Up = 1, North = 2, South = 3, West = 4, East = 5)
 +
|-
 +
| 11
 +
| OptUUID (Boolean + Optional UUID)
 +
| UUID is present if the Boolean is set to true
 
  |-
 
  |-
!colspan="4"| Handshaking serverbound
+
| 12
{{PacketList|0x00|Handshake}}
+
| BlockID (VarInt)
 +
| <code><nowiki>id &lt;&lt; 4 | data</nowiki></code>
 
  |}
 
  |}
-->
 
  
== New/modified data types ==
+
Entity classes also recursively use fields from classes they extend.
 +
 
 +
{| class="wikitable"
 +
! Entity class
 +
! Index
 +
! Type
 +
! style="width: 250px" colspan="2" |  Meaning
 +
|-
 +
|rowspan="13"| Entity
 +
|rowspan="8"| 0
 +
|rowspan="8"| Byte
 +
! Bit Mask !! Meaning
 +
|-
 +
| 0x01 || On Fire
 +
|-
 +
| 0x02 || Crouched
 +
|-
 +
| 0x08 || Sprinting
 +
|-
 +
| 0x10 || Eating/Drinking/Blocking
 +
|-
 +
| 0x20 || Invisible
 +
|-
 +
| 0x40 || Glowing Effect
 +
|-
 +
| 0x80 || Flying with Elytra
 +
|-
 +
| 1
 +
| VarInt
 +
| colspan="2" | Air
 +
|-
 +
| 2
 +
| String
 +
| colspan="2" | Custom Name
 +
|-
 +
| 3
 +
| Boolean
 +
| colspan="2" | Is Custom Name Visible
 +
|-
 +
| 4
 +
| Boolean
 +
| colspan="2" | Is Silent
 +
|- style="background-color: #d9ead3;"
 +
| 5
 +
| Boolean
 +
| colspan="2" | No Gravity
 +
|-
 +
| Potion <sup>extends Entity</sup>
 +
| {{change|5|6}}
 +
| [[Slot]]
 +
| colspan="2" | Potion which is thrown
 +
|-
 +
| FallingBlock <sup>extends Entity</sup>
 +
| {{change|5|6}}
 +
| [[Data Types#Position|Position]]
 +
| colspan="2" | Spawn Position
 +
|-
 +
|rowspan="4"| AreaEffectButt <sup>extends Entity</sup>
 +
| {{change|5|6}}
 +
| Float
 +
| colspan="2" | Radius
 +
|-
 +
| {{change|6|7}}
 +
| VarInt
 +
| colspan="2" | Color (only for mob spell particle)
 +
|-
 +
| {{change|7|8}}
 +
| Boolean
 +
| colspan="2" | Ignore radius and show effect as single point, not area
 +
|-
 +
| {{change|8|9}}
 +
| VarInt
 +
| colspan="2" | Particle ID
 +
|-
 +
| Arrow <sup>extends Entity</sup>
 +
| {{change|5|6}}
 +
| Byte
 +
| colspan="2" | Is Critical
 +
|-
 +
| TippedArrow <sup>extends Arrow</sup>
 +
| {{change|6|7}}
 +
| VarInt
 +
| colspan="2" | Color
 +
|-
 +
|rowspan="6"| Boat <sup>extends Entity</sup>
 +
| {{change|5|6}}
 +
| VarInt
 +
| colspan="2" | Time Since Last Hit
 +
|-
 +
| {{change|6|7}}
 +
| VarInt
 +
| colspan="2" | Forward Direction
 +
|-
 +
| {{change|7|8}}
 +
| Float
 +
| colspan="2" | Damage Taken
 +
|-
 +
| {{change|8|9}}
 +
| VarInt
 +
| colspan="2" | Type
 +
|-
 +
| {{change|9|10}}
 +
| Boolean
 +
| colspan="2" | Right paddle turning
 +
|-
 +
| {{change|10|11}}
 +
| Boolean
 +
| colspan="2" | Left paddle turning
 +
|-
 +
|rowspan="2"| EnderCrystal <sup>extends Entity</sup>
 +
| {{change|5|6}}
 +
| OptPosition
 +
| colspan="2" | Beam Target
 +
|-
 +
| {{change|6|7}}
 +
| Boolean
 +
| colspan="2" | Show Bottom
 +
|-
 +
| Fireball <sup>extends Entity</sup>
 +
|colspan="4"| ''no additional metadata''
 +
|-
 +
| WitherSkull <sup>extends Fireball</sup>
 +
| {{change|5|6}}
 +
| Boolean
 +
| colspan="2" | Invulnerable
 +
|-
 +
| Fireworks <sup>extends Entity</sup>
 +
| {{change|5|6}}
 +
| [[Slot]]
 +
| colspan="2" | Firework Info
 +
|-
 +
| Hanging <sup>extends Entity</sup>
 +
|colspan="4"| ''no additional metadata''
 +
|-
 +
|rowspan="2"| ItemFrame <sup>extends Hanging</sup>
 +
| {{change|5|6}}
 +
| [[Slot]]
 +
| colspan="2" | Item
 +
|-
 +
| {{change|6|7}}
 +
| VarInt
 +
| colspan="2" | Rotation
 +
|-
 +
| Item <sup>extends Entity</sup>
 +
| {{change|5|6}}
 +
| [[Slot]]
 +
| colspan="2" | Item
 +
|-
 +
|rowspan="5"| Living <sup>extends Entity</sup>
 +
| {{change|5|6}}
 +
| Byte
 +
|colspan="3"| Likely used to limit placing blocks from both hands at the same time.
 +
|-
 +
! Bit mask
 +
! Meaning
 +
|-
 +
| 0x01
 +
| Is hand active
 +
|-
 +
| 0x02
 +
| Active hand (0 = main hand, 1 = offhand)
 +
|-
 +
| {{change|6|7}}
 +
| Float
 +
| colspan="2" | Health
 +
|-
 +
| {{change|7|8}}
 +
| VarInt
 +
| colspan="2" | Potion Effect Color
 +
|-
 +
| {{change|8|9}}
 +
| Boolean
 +
| colspan="2" | Is Potion Effect Ambient
 +
|-
 +
| {{change|9|10}}
 +
| VarInt
 +
| colspan="2" | Number of Arrows in Entity
 +
|-
 +
|rowspan="8"| ArmorStand <sup>extends Living</sup>
 +
|-
 +
| {{change|10|11}}
 +
| Byte
 +
| colspan="2" | Status bit mask
 +
|-
 +
| {{change|11|12}}
 +
| Vector3F
 +
| colspan="2" | Head rotation
 +
|-
 +
| {{change|12|13}}
 +
| Vector3F
 +
| colspan="2" | Body rotation
 +
|-
 +
| {{change|13|14}}
 +
| Vector3F
 +
| colspan="2" | Left arm rotation
 +
|-
 +
| {{change|14|15}}
 +
| Vector3F
 +
| colspan="2" | Right arm rotation
 +
|-
 +
| {{change|15|16}}
 +
| Vector3F
 +
| colspan="2" | Left leg rotation
 +
|-
 +
| {{change|16|17}}
 +
| Vector3F
 +
| colspan="2" | Right leg rotation
 +
|-
 +
| Insentient <sup>extends Living</sup>
 +
| {{change|10|11}}
 +
| Byte
 +
| colspan="2" | Status bit mask (NoAI, Left handed)
 +
|-
 +
| Ambient <sup>extends Insentient</sup>
 +
|colspan="4"| ''no additional metadata''
 +
|-
 +
| Bat <sup>extends Ambient</sup>
 +
| {{change|11|12}}
 +
| Byte
 +
| colspan="2" | Is Hanging
 +
|-
 +
| Creature <sup>extends Insentient</sup>
 +
|colspan="4"| ''no additional metadata''
 +
|-
 +
| Ageable <sup>extends Creature</sup>
 +
| {{change|11|12}}
 +
| Boolean
 +
| colspan="2" | Is Baby
 +
|- style="background-color: #d9ead3;"
 +
| PolarBear <sup>extends Ageable</sup>
 +
| 13
 +
| Boolean
 +
| colspan="2" | Is Standing
 +
|-
 +
| Animal <sup>extends Ageable</sup>
 +
|colspan="4"| ''no additional metadata''
 +
|-
 +
|rowspan="5"| Horse <sup>extends Animal</sup>
 +
| {{change|12|13}}
 +
| Byte
 +
| colspan="2" | Status bit mask
 +
|-
 +
| {{change|13|14}}
 +
| VarInt
 +
| colspan="2" | Type
 +
|-
 +
| {{change|14|15}}
 +
| VarInt
 +
| colspan="2" | Variant
 +
|-
 +
| {{change|15|16}}
 +
| OptUUID
 +
| colspan="2" | Owner's UUID
 +
|-
 +
| {{change|16|17}}
 +
| VarInt
 +
| colspan="2" | Armor
 +
|-
 +
| Pig <sup>extends Animal</sup>
 +
| {{change|12|13}}
 +
| Boolean
 +
| colspan="2" | Has Saddle
 +
|-
 +
| Rabbit <sup>extends Animal</sup>
 +
| {{change|12|13}}
 +
| VarInt
 +
| colspan="2" | Type
 +
|-
 +
| Sheep <sup>extends Animal</sup>
 +
| {{change|12|13}}
 +
| Byte
 +
| colspan="2" | Status bit mask
 +
|-
 +
|rowspan="2"| TameableAnimal <sup>extends Animal</sup>
 +
| {{change|12|13}}
 +
| Byte
 +
| colspan="2" | Status bit mask (sitting, tamed)
 +
|-
 +
| {{change|13|14}}
 +
| OptUUID
 +
| colspan="2" | Owner's UUID
 +
|-
 +
| Ocelot <sup>extends TameableAnimal</sup>
 +
| {{change|14|15}}
 +
| VarInt
 +
| colspan="2" | Type
 +
|-
 +
|rowspan="3"| Wolf <sup>extends TameableAnimal</sup>
 +
| {{change|14|15}}
 +
| Float
 +
| colspan="2" | Damage Taken (used for tail rotation)
 +
|-
 +
| {{change|15|16}}
 +
| Boolean
 +
| colspan="2" | Is Begging
 +
|-
 +
| {{change|16|17}}
 +
| VarInt
 +
| colspan="2" | Collar Color
 +
|-
 +
| Villager <sup>extends Ageable</sup>
 +
| {{change|12|13}}
 +
| VarInt
 +
| colspan="2" | Profession (Farmer = 0, Librarian = 1, Priest = 2, Blacksmith = 3, Butcher = 4)
 +
|-
 +
| Golem <sup>extends Creature</sup>
 +
|colspan="4"| ''no additional metadata''
 +
|-
 +
| IronGolem <sup>extends Golem</sup>
 +
| {{change|11|12}}
 +
| Byte
 +
| colspan="2" | Is Player Created
 +
|-
 +
|rowspan="3"| Shulker <sup>extends Golem</sup>
 +
| {{change|11|12}}
 +
| Direction
 +
| colspan="2" | Facing Direction
 +
|-
 +
| {{change|12|13}}
 +
| OptPosition
 +
| colspan="2" | Attachment Position
 +
|-
 +
| {{change|13|14}}
 +
| Byte
 +
| colspan="2" | Shield Height
 +
|-
 +
| Monster <sup>extends Creature</sup>
 +
|colspan="4"| ''no additional metadata''
 +
|-
 +
| Blaze <sup>extends Monster</sup>
 +
| {{change|11|12}}
 +
| Byte
 +
| colspan="2" | Is On Fire
 +
|-
 +
|rowspan="3"| Creeper <sup>extends Monster</sup>
 +
| {{change|11|12}}
 +
| VarInt
 +
| colspan="2" | State (-1 = Idle, 1 = Fuse)
 +
|-
 +
| {{change|12|13}}
 +
| Boolean
 +
| colspan="2" | Is Powered
 +
|-
 +
| {{change|13|14}}
 +
| Boolean
 +
| colspan="2" | Is Ignited
 +
|-
 +
|rowspan="2"| Guardian <sup>extends Monster</sup>
 +
| {{change|11|12}}
 +
| Byte
 +
| colspan="2" | Status bit mask (elderly, retracting spikes)
 +
|-
 +
| {{change|12|13}}
 +
| VarInt
 +
| colspan="2" | Target EID
 +
|-
 +
|rowspan="2"| Skeleton <sup>extends Monster</sup>
 +
| {{change|11|12}}
 +
| VarInt
 +
| colspan="2" | Type
 +
|-
 +
| {{change|12|13}}
 +
| Boolean
 +
| colspan="2" | ''Unknown (something hand related)''
 +
|-
 +
| Spider <sup>extends Monster</sup>
 +
| {{change|11|12}}
 +
| Byte
 +
| colspan="2" | Is Climbing
 +
|-
 +
| Witch <sup>extends Monster</sup>
 +
| {{change|11|12}}
 +
| Boolean
 +
| colspan="2" | Is Aggresive
 +
|-
 +
|rowspan="4"| Wither <sup>extends Monster</sup>
 +
| {{change|11|12}}
 +
| VarInt
 +
| colspan="2" | First Head's Target
 +
|-
 +
| {{change|12|13}}
 +
| VarInt
 +
| colspan="2" | Second Head's Target
 +
|-
 +
| {{change|13|14}}
 +
| VarInt
 +
| colspan="2" | Third Head's Target
 +
|-
 +
| {{change|14|15}}
 +
| VarInt
 +
| colspan="2" | Invulnerable Time
 +
|-
 +
|rowspan="4"| Zombie <sup>extends Monster</sup>
 +
| {{change|11|12}}
 +
| Boolean
 +
| colspan="2" | Is Baby
 +
|-
 +
| {{change|12|13}}
 +
| VarInt
 +
| colspan="2" | Is Villager (profession)
 +
|-
 +
| {{change|13|14}}
 +
| Boolean
 +
| colspan="2" | Is Converting
 +
|-
 +
| {{change|14|15}}
 +
| Boolean
 +
| colspan="2" | Are Hands Rised Up
 +
|-
 +
|rowspan="2"| Enderman <sup>extends Monster</sup>
 +
| {{change|11|12}}
 +
| Block ID
 +
| colspan="2" | Carried Block
 +
|-
 +
| {{change|12|13}}
 +
| Boolean
 +
| colspan="2" | Is Screaming
 +
|-
 +
| EnderDragon <sup>extends Insentient</sup>
 +
| {{change|11|12}}
 +
| VarInt
 +
| colspan="2" | Dragon Phase
 +
|-
 +
| Flying <sup>extends Insentient</sup>
 +
|colspan="4"| ''no additional metadata''
 +
|-
 +
| Ghast <sup>extends Flying</sup>
 +
| {{change|11|12}}
 +
| Boolean
 +
| colspan="2" | Is Attacking
 +
|-
 +
| Slime <sup>extends Insentient</sup>
 +
| {{change|11|12}}
 +
| VarInt
 +
| colspan="2" | Size
 +
|-
 +
|rowspan="6"| Minecart <sup>extends Entity</sup>
 +
| {{change|5|6}}
 +
| VarInt
 +
| colspan="2" | Shaking Power
 +
|-
 +
| {{change|6|7}}
 +
| VarInt
 +
| colspan="2" | Shaking Direction
 +
|-
 +
| {{change|7|8}}
 +
| Float
 +
| colspan="2" | Shaking Multiplier
 +
|-
 +
| {{change|8|9}}
 +
| VarInt
 +
| colspan="2" | Block ID and Meta
 +
|-
 +
| {{change|9|10}}
 +
| VarInt
 +
| colspan="2" | Block Y Position
 +
|-
 +
| {{change|10|11}}
 +
| Boolean
 +
| colspan="2" | Show Block
 +
|-
 +
|rowspan="2"| MinecartCommandBlock <sup>extends Minecart</sup>
 +
| {{change|11|12}}
 +
| String
 +
| colspan="2" | Command
 +
|-
 +
| {{change|12|13}}
 +
| [[Chat]]
 +
| colspan="2" | Last Output
 +
|-
 +
| MinecartFurnace <sup>extends Minecart</sup>
 +
| {{change|11|12}}
 +
| Boolean
 +
| colspan="2" | Is Powered
 +
|-
 +
| TNTPrimed <sup>extends Entity</sup>
 +
| {{change|5|6}}
 +
| VarInt
 +
| colspan="2" | Fuse Time
 +
|}
  
None so far.
+
Entity classes also recursively use fields from classes they extend.
  
 
== Handshaking ==
 
== Handshaking ==

Revision as of 19:07, 22 May 2016

This page documents the changes from the last stable Minecraft release (currently 1.9.4, protocol 110) to the current pre-release (currently 16w20a, protocol 201). Note that this page contains bleeding-edge information that may not be completely or correctly documented.

One who wishes to commandeer the merging of this into Protocol when an update is made must be sure to respect any changes that may have occurred to the respective packets there.

Contents

Data types

No changes so far.

Packets

ID Packet name Documentation
Handshaking serverbound
0x00 Handshake Current Pre
Play clientbound
0x19 Named Sound Effect Current Pre
0x46 Sound Effect Current Pre

New/modified data types

Entity Metadata

Format is now an array of entries, each of which looks like the following:

Name Type Meaning
Index Unsigned Byte Unique index key determining the meaning of the following value, see the table below. If this is 0xff then the it is the end of the Entity Metadata array and no more is read.
Type Optional Byte Enum Only if Index is not 0xff; the type of the index, see the table below
Value Optional value of Type Only if Index is not 0xff: the value of the metadata field
Value of Type field Type of Value field Notes
0 Byte
1 VarInt
2 Float
3 String
4 Chat
5 Slot
6 Boolean
7 Rotation 3 floats: rotation on x, rotation on y, rotation on z
8 Position
9 OptPosition (Boolean + Optional Position) Position is present if the Boolean is set to true
10 Direction (VarInt) (Down = 0, Up = 1, North = 2, South = 3, West = 4, East = 5)
11 OptUUID (Boolean + Optional UUID) UUID is present if the Boolean is set to true
12 BlockID (VarInt) id << 4 | data

Entity classes also recursively use fields from classes they extend.

Entity class Index Type Meaning
Entity 0 Byte Bit Mask Meaning
0x01 On Fire
0x02 Crouched
0x08 Sprinting
0x10 Eating/Drinking/Blocking
0x20 Invisible
0x40 Glowing Effect
0x80 Flying with Elytra
1 VarInt Air
2 String Custom Name
3 Boolean Is Custom Name Visible
4 Boolean Is Silent
5 Boolean No Gravity
Potion extends Entity 5 6 Slot Potion which is thrown
FallingBlock extends Entity 5 6 Position Spawn Position
AreaEffectButt extends Entity 5 6 Float Radius
6 7 VarInt Color (only for mob spell particle)
7 8 Boolean Ignore radius and show effect as single point, not area
8 9 VarInt Particle ID
Arrow extends Entity 5 6 Byte Is Critical
TippedArrow extends Arrow 6 7 VarInt Color
Boat extends Entity 5 6 VarInt Time Since Last Hit
6 7 VarInt Forward Direction
7 8 Float Damage Taken
8 9 VarInt Type
9 10 Boolean Right paddle turning
10 11 Boolean Left paddle turning
EnderCrystal extends Entity 5 6 OptPosition Beam Target
6 7 Boolean Show Bottom
Fireball extends Entity no additional metadata
WitherSkull extends Fireball 5 6 Boolean Invulnerable
Fireworks extends Entity 5 6 Slot Firework Info
Hanging extends Entity no additional metadata
ItemFrame extends Hanging 5 6 Slot Item
6 7 VarInt Rotation
Item extends Entity 5 6 Slot Item
Living extends Entity 5 6 Byte Likely used to limit placing blocks from both hands at the same time.
Bit mask Meaning
0x01 Is hand active
0x02 Active hand (0 = main hand, 1 = offhand)
6 7 Float Health
7 8 VarInt Potion Effect Color
8 9 Boolean Is Potion Effect Ambient
9 10 VarInt Number of Arrows in Entity
ArmorStand extends Living
10 11 Byte Status bit mask
11 12 Vector3F Head rotation
12 13 Vector3F Body rotation
13 14 Vector3F Left arm rotation
14 15 Vector3F Right arm rotation
15 16 Vector3F Left leg rotation
16 17 Vector3F Right leg rotation
Insentient extends Living 10 11 Byte Status bit mask (NoAI, Left handed)
Ambient extends Insentient no additional metadata
Bat extends Ambient 11 12 Byte Is Hanging
Creature extends Insentient no additional metadata
Ageable extends Creature 11 12 Boolean Is Baby
PolarBear extends Ageable 13 Boolean Is Standing
Animal extends Ageable no additional metadata
Horse extends Animal 12 13 Byte Status bit mask
13 14 VarInt Type
14 15 VarInt Variant
15 16 OptUUID Owner's UUID
16 17 VarInt Armor
Pig extends Animal 12 13 Boolean Has Saddle
Rabbit extends Animal 12 13 VarInt Type
Sheep extends Animal 12 13 Byte Status bit mask
TameableAnimal extends Animal 12 13 Byte Status bit mask (sitting, tamed)
13 14 OptUUID Owner's UUID
Ocelot extends TameableAnimal 14 15 VarInt Type
Wolf extends TameableAnimal 14 15 Float Damage Taken (used for tail rotation)
15 16 Boolean Is Begging
16 17 VarInt Collar Color
Villager extends Ageable 12 13 VarInt Profession (Farmer = 0, Librarian = 1, Priest = 2, Blacksmith = 3, Butcher = 4)
Golem extends Creature no additional metadata
IronGolem extends Golem 11 12 Byte Is Player Created
Shulker extends Golem 11 12 Direction Facing Direction
12 13 OptPosition Attachment Position
13 14 Byte Shield Height
Monster extends Creature no additional metadata
Blaze extends Monster 11 12 Byte Is On Fire
Creeper extends Monster 11 12 VarInt State (-1 = Idle, 1 = Fuse)
12 13 Boolean Is Powered
13 14 Boolean Is Ignited
Guardian extends Monster 11 12 Byte Status bit mask (elderly, retracting spikes)
12 13 VarInt Target EID
Skeleton extends Monster 11 12 VarInt Type
12 13 Boolean Unknown (something hand related)
Spider extends Monster 11 12 Byte Is Climbing
Witch extends Monster 11 12 Boolean Is Aggresive
Wither extends Monster 11 12 VarInt First Head's Target
12 13 VarInt Second Head's Target
13 14 VarInt Third Head's Target
14 15 VarInt Invulnerable Time
Zombie extends Monster 11 12 Boolean Is Baby
12 13 VarInt Is Villager (profession)
13 14 Boolean Is Converting
14 15 Boolean Are Hands Rised Up
Enderman extends Monster 11 12 Block ID Carried Block
12 13 Boolean Is Screaming
EnderDragon extends Insentient 11 12 VarInt Dragon Phase
Flying extends Insentient no additional metadata
Ghast extends Flying 11 12 Boolean Is Attacking
Slime extends Insentient 11 12 VarInt Size
Minecart extends Entity 5 6 VarInt Shaking Power
6 7 VarInt Shaking Direction
7 8 Float Shaking Multiplier
8 9 VarInt Block ID and Meta
9 10 VarInt Block Y Position
10 11 Boolean Show Block
MinecartCommandBlock extends Minecart 11 12 String Command
12 13 Chat Last Output
MinecartFurnace extends Minecart 11 12 Boolean Is Powered
TNTPrimed extends Entity 5 6 VarInt Fuse Time

Entity classes also recursively use fields from classes they extend.

Handshaking

Clientbound

No changes so far.

Serverbound

No changes so far.

Handshake

This causes the server to switch into the target state.

Packet ID State Bound To Field Name Field Type Notes
0x00 Handshaking Server Protocol Version VarInt See protocol version numbers (currently 110 201)
Server Address String Hostname or IP, e.g. localhost or 127.0.0.1, that was used to connect. The Notchian server does not use this information.
Server Port Unsigned Short Default is 25565. The Notchian server does not use this information.
Next State VarInt Enum 1 for status, 2 for login


Play

Clientbound

Named Sound Effect

See also: #Sound Effect

Used to play a sound effect on the client. Custom sounds may be added by resource packs.

Packet ID State Bound To Field Name Field Type Notes
0x19 Play Client Sound Name String All known sound effect names can be seen here.
Sound Category VarInt Enum The category that this sound will be played from (current categories)
Effect Position X Int Effect X multiplied by 8 (fixed-point number with only 3 bits dedicated to the fractional part)
Effect Position Y Int Effect Y multiplied by 8 (fixed-point number with only 3 bits dedicated to the fractional part)
Effect Position Z Int Effect Z multiplied by 8 (fixed-point number with only 3 bits dedicated to the fractional part)
Volume Float 1 is 100%, can be more
Pitch Unsigned Byte Float 63 is 100%, can be more

Sound Effect

This packet is used to play a number of hardcoded sound events. For custom sounds, use Named Sound Effect (Play, 0x19, clientbound).

Warning.png Numeric sound effect IDs are liable to change between versions

Packet ID State Bound To Field Name Field Type Notes
0x46 Play Client Sound ID VarInt ID of hardcoded sound event (events)
Sound Category VarInt Enum The category that this sound will be played from (current categories)
Effect Position X Int Effect X multiplied by 8 (fixed-point number with only 3 bits dedicated to the fractional part)
Effect Position Y Int Effect Y multiplied by 8 (fixed-point number with only 3 bits dedicated to the fractional part)
Effect Position Z Int Effect Z multiplied by 8 (fixed-point number with only 3 bits dedicated to the fractional part)
Volume Float 1.0 is 100%, capped between 0.0 and 1.0 by Notchian clients
Pitch Unsigned Byte Float Float multiplied by 63.5, capped between 0.5 and 2.0 by Notchian clients

Serverbound

No changes so far.

Status

Clientbound

No changes so far.

Serverbound

No changes so far.

Login

Clientbound

No changes so far.

Serverbound

No changes so far.