Difference between revisions of "Object Data"

From wiki.vg
Jump to navigation Jump to search
(Add in a few other types, mostly regarding velocity)
(31 intermediate revisions by 13 users not shown)
Line 1: Line 1:
== Object Data ==
+
This article documents the '''Data''' field in the [[Protocol#Spawn Object|Spawn Object]] packet. The field is of type Int, and the meaning of its contents depend on the [[Entities#Objects|type of object]] being spawned, as defined in the Type field of the same packet, and is documented below.
  
In the "Spawn Object/Vehicle" packet, additional metadata about the spawned entity may be provided.  The length and contents of this extra data depend on the type of object being spawnedNo matter what, you must send at least one integer to the client, although 0 is a valid value. If a number other than zero is provided (for all entities), the following data is appended to the end of the object data:
+
In some cases, the data field has no meaning, but is only used to indicate presence of velocityIn others, it (and velocity) is always ignored.
 +
 
 +
== Item (id 2) ==
 +
 
 +
The int value is ignored, but should be set to <code>1</code> to indicate that velocity is present.
 +
 
 +
== Minecarts (id 10) ==
 +
 
 +
The int value itself specifies the minecart's functionality:
  
 
{| class="wikitable"
 
{| class="wikitable"
|- class="row0"
+
|-
! class="col0" | Field Name
+
! Value
! class="col1" | Field Type
+
! Minecart functionality
! class="col2" | Example
+
|-
! class="col3" | Notes
+
| 0
|- class="row2"
+
| Empty (ride-able) minecart
| class="col0 centeralign" | Speed X
+
|-
| class="col1 centeralign" | short
+
| 1
| class="col2 centeralign" | <code>0</code>
+
| Chest minecart
| class="col3" | The speed of the fireball
+
|-
|- class="row2"
+
| 2
| class="col0 centeralign" | Speed Y
+
| Furnace (powered) minecart
| class="col1 centeralign" | short
+
|-
| class="col2 centeralign" | <code>0</code>
+
| 3
| class="col3" | The speed of the fireball
+
| TNT minecart
|- class="row2"
+
|-
| class="col0 centeralign" | Speed Z
+
| 4
| class="col1 centeralign" | short
+
| Spawner minecart
| class="col2 centeralign" | <code>0</code>
+
|-
| class="col3" | The speed of the fireball
+
| 5
|}
+
| Hopper minecart
 +
|-
 +
| 6
 +
| Command Block minecart
 +
|}
  
=== Falling Block (70) ===
+
== Item Frame (id 71) ==
  
 
{| class="wikitable"
 
{| class="wikitable"
|- class="row0"
+
|-
! class="col0" | Field Name
+
! Value
! class="col1" | Field Type
+
! Orientation
! class="col2" | Example
+
|-
! class="col3" | Notes
+
| 0
|- class="row1"
+
| South
| class="col0 centeralign" | Block Type
+
|-
| class="col1 centeralign" | int
+
| 1
| class="col2 centeralign" | <code>12</code>
+
| West
| class="col3" | <code>BlockID | (Metadata << 0xC)</code>
+
|-
|}
+
| 2
 +
| North
 +
|-
 +
| 3
 +
| East
 +
|}
  
=== Ghast Fireball ===
+
Velocity in the packet is always ignored.
 +
 
 +
== Falling Block (id 70) ==
  
 
{| class="wikitable"
 
{| class="wikitable"
|- class="row0"
+
|-
! class="col0" | Field Name
+
! Field name
! class="col1" | Field Type
+
! Field type
! class="col2" | Example
+
! Example
! class="col3" | Notes
+
! Notes
|- class="row1"
+
|-
| class="col0 centeralign" | Entity ID
+
| Block type
| class="col1 centeralign" | int
+
| Int
| class="col2 centeralign" | <code>64</code>
+
| <code>12</code>
| class="col3" | The ID of the ghast that created the fireball
+
| <code><nowiki>BlockID | (Metadata << 12)</nowiki></code>
|}
+
|}
 +
 
 +
Velocity in the packet is always ignored.
 +
 
 +
== Fishing Float (id 90) ==
 +
 
 +
{| class="wikitable"
 +
! Field name
 +
! Field type
 +
! Example
 +
! Notes
 +
|-
 +
| Owner
 +
| Int
 +
|
 +
| The entity ID of the owner
 +
|}
 +
 
 +
Velocity in the packet is ignored, and instead should be inferred from the shooter's position.
 +
 
 +
{{Need Info|What's the exact algorithm for determining this?}}
 +
 
 +
== Arrow (id 60) and Spectral Arrow (id 91) ==
 +
 
 +
{| class="wikitable"
 +
|-
 +
! Field name
 +
! Field type
 +
! Example
 +
! Notes
 +
|-
 +
| Entity ID
 +
| Int
 +
| <code>64</code>
 +
| The entity ID of the shooter + 1 (Subtract 1 to get the actual entity ID)
 +
|}
 +
 
 +
== Llama spit (id 68) ==
 +
 
 +
Velocity is always used even though the data field is always 0.
 +
 
 +
== Fireball (id 63), small fireball (id 64), dragon fireball (id 93), and wither skull (id 66) ==
 +
 
 +
The data field stores the ID of the shooting entity, or 0 if there was no shooting entity.  Velocity is used even if data is set to 0.
 +
 
 +
== Shulker bullet (id 67) ==
 +
 
 +
Velocity is always used even though the data field is always 0.
 +
 
 +
== Potion (id 73) ==
 +
 
 +
Velocity in the packet is always ignored.
 +
 
 +
== EXP bottle (id 75) ==
 +
 
 +
Velocity in the packet is always ignored.
 +
 
 +
[[Category:Protocol Details]]
 +
[[Category:Minecraft Modern]]

Revision as of 07:48, 27 November 2016

This article documents the Data field in the Spawn Object packet. The field is of type Int, and the meaning of its contents depend on the type of object being spawned, as defined in the Type field of the same packet, and is documented below.

In some cases, the data field has no meaning, but is only used to indicate presence of velocity. In others, it (and velocity) is always ignored.

Item (id 2)

The int value is ignored, but should be set to 1 to indicate that velocity is present.

Minecarts (id 10)

The int value itself specifies the minecart's functionality:

Value Minecart functionality
0 Empty (ride-able) minecart
1 Chest minecart
2 Furnace (powered) minecart
3 TNT minecart
4 Spawner minecart
5 Hopper minecart
6 Command Block minecart

Item Frame (id 71)

Value Orientation
0 South
1 West
2 North
3 East

Velocity in the packet is always ignored.

Falling Block (id 70)

Field name Field type Example Notes
Block type Int 12 BlockID | (Metadata << 12)

Velocity in the packet is always ignored.

Fishing Float (id 90)

Field name Field type Example Notes
Owner Int The entity ID of the owner

Velocity in the packet is ignored, and instead should be inferred from the shooter's position.

Huh.png The following information needs to be added to this page:
What's the exact algorithm for determining this?

Arrow (id 60) and Spectral Arrow (id 91)

Field name Field type Example Notes
Entity ID Int 64 The entity ID of the shooter + 1 (Subtract 1 to get the actual entity ID)

Llama spit (id 68)

Velocity is always used even though the data field is always 0.

Fireball (id 63), small fireball (id 64), dragon fireball (id 93), and wither skull (id 66)

The data field stores the ID of the shooting entity, or 0 if there was no shooting entity. Velocity is used even if data is set to 0.

Shulker bullet (id 67)

Velocity is always used even though the data field is always 0.

Potion (id 73)

Velocity in the packet is always ignored.

EXP bottle (id 75)

Velocity in the packet is always ignored.