HOW-TO: Add items and attributes
Table of contents:
Adding Items to NPC inventory
To add item to NPC Inventory you can use Inventory tab in NPC Template Editor.
To add new inventory item use Add item
button (red sign button)
First select category of item from items category! Without that you won't be able to select an item.
After selecting category can add new Item. You can do that by using red arrow in initializer
row. To select specific item select - CInventoryInitializerUnifrom
to select random item form chosen category select CInventoryInitializerRandom
.
After selecting CInventoryInitializerUnifrom
you can choose item from dropdown (red arrow button in itemName
row)
This tutorial adds information and context to the creating custom entity NPC tutorial which you can find, here: https://cdprojektred.atlassian.net/wiki/spaces/W3REDkit/pages/6326348.
Adding custom items
Items represent a number of different objects that can be purchased, found in the world or received during quests.
To add custom item you need to add new item definition to existing .xlm
file (check .xml files named def_item
.xml
) or create your own .xml
(preferred method - creating new one will prevent from modifying original files).
Important note - You need to mount every new .xml
file so that it can be visible to the engine and its contents can be used in other files. To do that you need to modify existing one or create new .reddlc
file. See https://cdprojektred.atlassian.net/wiki/x/GpBg for more info.
Item Definitions
Every item has an intended use and generally falls into one of the following categories, Equipment, Components or Other.
Equipment | Components | Other |
---|---|---|
Consumables | Alchemy | Monster Trophies |
Weapons | Crafting | Quest Rewards |
Armor | Herbs | Junk |
Upgrades | Mutagens |
|
Item Abilities
Every item has an intended use and can be examined in the player inventory.
Once acquired, an item might be equipped, used, sold, given or dropped.
Example:
Equipped to grant the player unique abilities during combat.
Used to augment other items.
Given to a crafter to crafter new items.
Sold to a merchant for money.
Given to an NPC to complete a challenge or quest.
Creating an XML Item Definition
When creating a new item definition in xml, the following properties must be defined:
name ="Short sword 2"
category ="steelsword"
price ="16"
initial_durability ="100"
max_durability ="100"
enhancement_slots ="0"
More detailed information for every property type has been included below, but only for properties driven by game design. Other aspects of an item's design like attachment points and user interface options are outside the scope of this documentation.
Name
___
To keep schematic names consistent, use the crafted item’s name followed by ‘schematic’.
Naming Convention
name_name = "Name of Item"
Example
name_name = "Short sword 2”
Category
___
The category of an Item should represent its intended use.
Naming Convention
category ="Category Name"
Example
category ="steelsword"
Durability
___
An Item's Durability represents how much damage it can sustain before becoming ineffective in combat.
Durability is determined by setting two values, the initial durability and the max durability.
Naming Convention
initial_durability ="0 - 100"
max_durability ="0 - 100"
Example
initial_durability ="80"
max_durability ="100"
Price
___
The price of an item represents it's base worth to the player and is unmodified by merchants.
Naming Convention
price ="XXXX"
Example
price ="16"
Enhancement Slots
___
The number of enhancement slots represents the amount of Upgrades (Runestone or Glyph) an item can hold.
The maximum number of enhancement slots is 3.
Naming Convention
enhancement_slots ="X"
Example
enhancement_slots ="3"
Example of an item’s full xml definition
<item
name ="Short sword 2"
category ="steelsword"
price ="16"
initial_durability ="100"
max_durability ="100"
enhancement_slots ="0"
stackable ="1"
grid_size ="2"
equip_template ="short_sword_lvl2"
equip_slot ="steel_sword_back_slot"
hold_slot ="r_weapon"
weapon ="true"
lethal ="true"
ability_mode ="OnHold"
hand ="right"
sound_identification ="long steel"
draw_event ="DrawWeapon"
draw_act ="draw_steel_sword_back_act"
draw_deact ="draw_steel_sword_back_deact"
holster_event ="HolsterWeapon"
holster_act ="holster_steel_sword_back_act"
holster_deact ="holster_steel_sword_back_deact"
localisation_key_name ="item_name_short_sword_2"
localisation_key_description ="item_desc_steel_sword"
icon_path ="icons/inventory/weapons/short_sword_lvl1_64x128.png"
>
<tags> Autogen, PlayerSteelWeapon, Weapon, sword1h, 1handedWeapon, mod_weapon
</tags>
<base_abilities>
<a>Default weapon _Stats</a>
<a>Short sword 2 _Stats</a>
</base_abilities>
<recycling_parts>
<parts count="1">Leather squares</parts>
<parts count="2">Iron ingot</parts>
</recycling_parts>
</item>
Adding attributes
To add custom attributes to NPC Entity Template you need to add new gameplay parameter in gameplay tab. To do that use red button with plus icon next to Gameplay params
label:
To add new gameplay attributes select CCharacterStatsParam
from dropdown list.
After adding new CCharacterStatsParam
you can add new ability that contain attributes definitions.
New ability definitions are defined in separate .xml
file.
Adding custom attribute
To add custom attribute you need to add new ability definition to existing .xlm
file (check .xml files named monster_base_abl.xml
) or create your own .xml
(preferred method - creating new one will prevent from modifying original files).
You can use example below to create an abilities definition file:
<?xml version="1.0" encoding="UTF-16"?>
<redxml>
<definitions>
<abilities>
<ability name="test_bandit">
<level type="add" min="15" max="15" />
<vitality type="base" min="2000" max="2000" />
<stamina type="base" min="200" max="200" />
<experience type="add" min="100" max="100" />
</ability>
</abilities>
</definitions>
</redxml>
You can modify Base Stats:
vitality
essence
stamina
toxicity
focus
morale
air
panic
panicStatic
swimmingStamina
Power stats:
attack_power
spell_power
Regeneration stats:
vitalityCombatRegen
vitalityRegen
essenceRegen
staminaRegen
moraleRegen
airRegen
panicRegen
swimmingStaminaRegen
Resistance Stats:
physical_resistance
poison_resistance
fire_resistance
frost_resistance
shock_resistance
force_resistance
slashing_resistance
piercing_resistance
bludgeoning_resistance
rending_resistance
elemental_resistance
burning_DoT_damage_resistance
poison_DoT_damage_resistance
bleeding_DoT_damage_resistance
______________________________________
The Witcher 3: Wild Hunt Complete Edition © 2024 CD PROJEKT S.A. Published by CD PROJEKT S.A. Developed by CD PROJEKT RED. CD PROJEKT®, The Witcher®, REDengine® are registered trademarks of CD PROJEKT Capital Group. All rights reserved. The Witcher game is set in the universe created by Andrzej Sapkowski in his series of books. All rights reserved.