Minecraft displays the player inventory differently, according to how the window was opened. Ranges of slot indices vary in meaning between different “windows”. The Open Window packet indicates which window is being opened according to:
|minecraft:container||Fallback for unknown types; also used fors. Behaves the same as minecraft:chest.|
|minecraft:chest||, large chest, or|
The slot number is calculated starting at 0, counting up through the window's unique slots, and then counting through the players inventory.
For all windows, the slot in the upper-left corner of the player's inventory is slot n where n is the number of unique slots, and slot number -999 is always used for clicking outside the window.
The number of unique slots in the window is sent in the Open Window (Play, 0x2d, clientbound) packet for all storage windows (e.g. Chest, Dropper). For non-storage windows (the items get dropped when the window is closed, e.g. Workbench, Anvil), the received number of unique slots is always 0, but it can be looked up by the client from the window type.
The default inventory window, which is never explicitly opened by the server, has 10 unique slots.
Rectangular regions are always indexed starting with the upper-left corner and scanning across rows. If a window has a crafting region, the output slot is always slot 0 followed immediately by the input region.
Each window type is described in the following sections. All slot index ranges are inclusive and reflect the indices observed in the Minecraft protocol.
For the window properties (additional data in each window, e.g. smelting progress or enchantments), refer to the table in the Window Property packet.
Using -1 as slot index and as window id will set the cursor item (the stack dragged with the mouse).
This is the inventory window that the player can always open, typically by pressing E since. Before, you had to press I.
|1–4||2×2 crafting input (1 + x + 2 * y)|
|5–8||armor (head, chest, legs, feet)|
Note that this is different from inventory items stored in a player.dat file. This may help: https://gist.github.com/459a1691c3dd751db160
This is the window that is opened when the player right-clicks on a single chest block.
This is the window that is opened when the player right-clicks on a double chest block (two adjacent chest blocks).
This is the window that is opened when the player right-clicks on a workbench.
|1–9||3×3 crafting input (1 + x + 3 * y)|
The window that appears when a furnace is right-clicked.
The inventory that appears when a dispenser or dropper is opened.
|0–8||3×3 dispenser contents (x + 3 * y)|
The inventory of an enchantment table. The enchant buttons trigger a Enchant item packet.
|0||item to enchant|
|1||lapis lazuli slot|
The GUI that appears when a brewing stand is opened.
The GUI that appears when a villager is right-clicked. Note that if the villager only requires one item, you can put it in either (or both) slots.
The window that appears when a beacon is right-clicked.
The window that appears when a hopper or hopper minecart is opened.
This is the window that is opened when the player right-clicks on a shulker box chest.
The inventory that appears when a tamed llama is right-clicked and has a chest, or when the player's inventory is opened while riding a tamed llama. Depending on the value of the strength field, the number of chest rows may vary (max is 5, so 15 slots).
The window for when a tamed horse is right-clicked or the player's inventory is opened while riding a horse.
The inventory that appears when a tamed donkey (or mule?) is right-clicked, or when the player's inventory is opened while riding a tamed donkey or mule.
|17–43 (2-28 if unchested)||player inventory|
|44–52 (29-37 if unchested)||hotbar|