Stackable Item Definition
Stackable item system for the Lilia framework.
name
Purpose
Sets the display name of the stackable item
When Called
During item definition
Example Usage
model
Purpose
Sets the 3D model for the stackable item
When Called
During item definition
Example Usage
width
Purpose
Sets the inventory width of the stackable item
When Called
During item definition
Example Usage
height
Purpose
Sets the inventory height of the stackable item
When Called
During item definition
Example Usage
isStackable
Purpose
Marks the item as stackable
When Called
During item definition
Example Usage
maxQuantity
Purpose
Sets the maximum quantity for the stackable item
When Called
During item definition
Example Usage
canSplit
Purpose
Sets whether the item can be split
When Called
During item definition
Example Usage
ITEM:getDesc()
Purpose
Custom description function that shows quantity
When Called
When displaying item description
Example Usage
ITEM:paintOver(item)
Purpose
Custom paint function to display quantity on the item
When Called
When rendering the item in inventory
Example Usage
function ITEM:paintOver(item)
local quantity = item:getQuantity()
lia.util.drawText(quantity, 8, 5, color_white, TEXT_ALIGN_LEFT, TEXT_ALIGN_TOP, "LiliaFont.16")
end
ITEM:onCombine(other)
Purpose
Handles combining stackable items
When Called
When two stackable items are combined
Example Usage
function ITEM:onCombine(other)
if other.uniqueID ~= self.uniqueID then return end
local combined = self:getQuantity() + other:getQuantity()
if combined <= self.maxQuantity then
self:setQuantity(combined)
other:remove()
else
self:setQuantity(self.maxQuantity)
other:setQuantity(combined - self.maxQuantity)
end
return true
end
Example Item:
Example Usage
-- Basic item identification
ITEM.name = "Ammo Box"                                    -- Display name shown to players
ITEM.model = "models/props_junk/cardboard_box001a.mdl"   -- 3D model for the item
ITEM.width = 1                                            -- Inventory width (1 slot)
ITEM.height = 1                                           -- Inventory height (1 slot)
ITEM.isStackable = true                                   -- Enables stacking functionality
ITEM.maxQuantity = 10                                     -- Maximum items per stack