230 lines
7.3 KiB
Plaintext
230 lines
7.3 KiB
Plaintext
/// @addtogroup item Item
|
|
/// @brief Functions exposing additional item properties.
|
|
/// @{
|
|
/// @file nwnx_item.nss
|
|
#include "nwnx"
|
|
|
|
const string NWNX_Item = "NWNX_Item"; ///< @private
|
|
|
|
/// @brief Set an item's weight.
|
|
/// @note Will not persist through saving.
|
|
/// @param oItem The item object.
|
|
/// @param weight The weight, note this is in tenths of pounds.
|
|
void NWNX_Item_SetWeight(object oItem, int weight);
|
|
|
|
/// @brief Set an item's base value in gold pieces.
|
|
/// @remark Total cost = base_value + additional_value.
|
|
/// @remark Equivalent to SetGoldPieceValue NWNX2 function.
|
|
/// @note Will not persist through saving.
|
|
/// @note This value will also revert if item is identified or player relogs into server.
|
|
/// @param oItem The item object.
|
|
/// @param gold The base gold value.
|
|
void NWNX_Item_SetBaseGoldPieceValue(object oItem, int gold);
|
|
|
|
/// @brief Set an item's additional value in gold pieces.
|
|
/// @remark Total cost = base_value + additional_value.
|
|
/// @note Will persist through saving.
|
|
/// @param oItem The item object.
|
|
/// @param gold The additional gold value.
|
|
void NWNX_Item_SetAddGoldPieceValue(object oItem, int gold);
|
|
|
|
/// @brief Get an item's base value in gold pieces.
|
|
/// @param oItem The item object.
|
|
/// @return The base gold piece value for the item.
|
|
int NWNX_Item_GetBaseGoldPieceValue(object oItem);
|
|
|
|
/// @brief Get an item's additional value in gold pieces.
|
|
/// @param oItem The item object.
|
|
/// @return The additional gold piece value for the item.
|
|
int NWNX_Item_GetAddGoldPieceValue(object oItem);
|
|
|
|
/// @brief Set an item's base item type.
|
|
/// @warning This will not be visible until the item is refreshed (e.g. drop and take the item,
|
|
/// or logging out and back in).
|
|
/// @param oItem The item object.
|
|
/// @param nBaseItem The new base item.
|
|
void NWNX_Item_SetBaseItemType(object oItem, int nBaseItem);
|
|
|
|
/// @brief Make a single change to the appearance of an item.
|
|
/// @warning This will not be visible to PCs until the item is refreshed for them (e.g. by logging out and back in).
|
|
///
|
|
/// Helmet models and simple items ignore nIndex.
|
|
/// ```
|
|
/// nType nIndex nValue
|
|
/// ITEM_APPR_TYPE_SIMPLE_MODEL [Ignored] Model #
|
|
/// ITEM_APPR_TYPE_WEAPON_COLOR ITEM_APPR_WEAPON_COLOR_* 0-255
|
|
/// ITEM_APPR_TYPE_WEAPON_MODEL ITEM_APPR_WEAPON_MODEL_* Model #
|
|
/// ITEM_APPR_TYPE_ARMOR_MODEL ITEM_APPR_ARMOR_MODEL_* Model #
|
|
/// ITEM_APPR_TYPE_ARMOR_COLOR ITEM_APPR_ARMOR_COLOR_* [0] 0-255 [1]
|
|
/// ```
|
|
///
|
|
/// [0] Where ITEM_APPR_TYPE_ARMOR_COLOR is specified, if per-part coloring is
|
|
/// desired, the following equation can be used for nIndex to achieve that:
|
|
///
|
|
/// ITEM_APPR_ARMOR_NUM_COLORS + (ITEM_APPR_ARMOR_MODEL_ * ITEM_APPR_ARMOR_NUM_COLORS) + ITEM_APPR_ARMOR_COLOR_
|
|
///
|
|
/// For example, to change the CLOTH1 channel of the torso, nIndex would be:
|
|
///
|
|
/// 6 + (7 * 6) + 2 = 50
|
|
///
|
|
/// [1] When specifying per-part coloring, the value 255 corresponds with the logical
|
|
/// function 'clear colour override', which clears the per-part override for that part.
|
|
void NWNX_Item_SetItemAppearance(object oItem, int nType, int nIndex, int nValue);
|
|
|
|
/// @brief Return a string containing the entire appearance for an item.
|
|
/// @sa NWNX_Item_RestoreItemAppearance
|
|
/// @param oItem The item object.
|
|
/// @return A string representing the item's appearance.
|
|
string NWNX_Item_GetEntireItemAppearance(object oItem);
|
|
|
|
/// @brief Restores an item's appearance using the value retrieved through NWNX_Item_GetEntireItemAppearance().
|
|
/// @param oItem The item object.
|
|
/// @param sApp A string representing the item's appearance.
|
|
void NWNX_Item_RestoreItemAppearance(object oItem, string sApp);
|
|
|
|
/// @brief Get an item's base armor class
|
|
/// @param oItem The item object.
|
|
/// @return The base armor class.
|
|
int NWNX_Item_GetBaseArmorClass(object oItem);
|
|
|
|
/// @brief Get an item's minimum level required to equip.
|
|
/// @param oItem The item object.
|
|
/// @return The minimum level required to equip the item.
|
|
int NWNX_Item_GetMinEquipLevel(object oItem);
|
|
|
|
/// @brief Move oItem to oTarget
|
|
/// @remark Moving items from a container to the inventory of the container's owner (or the other way around) is always "silent" and won't trigger feedback messages
|
|
/// @param oItem The item object.
|
|
/// @param oTarget The target bag/creature/placeable or store object to move oItem to.
|
|
/// @param bHideAllFeedback Hides all feedback messages generated by losing/acquiring items
|
|
/// @return TRUE if the item was successfully moved to the target, otherwise FALSE
|
|
int NWNX_Item_MoveTo(object oItem, object oTarget, int bHideAllFeedback = FALSE);
|
|
|
|
/// @}
|
|
|
|
void NWNX_Item_SetWeight(object oItem, int w)
|
|
{
|
|
string sFunc = "SetWeight";
|
|
|
|
NWNX_PushArgumentInt(w);
|
|
NWNX_PushArgumentObject(oItem);
|
|
|
|
NWNX_CallFunction(NWNX_Item, sFunc);
|
|
}
|
|
|
|
void NWNX_Item_SetBaseGoldPieceValue(object oItem, int g)
|
|
{
|
|
string sFunc = "SetBaseGoldPieceValue";
|
|
|
|
NWNX_PushArgumentInt(g);
|
|
NWNX_PushArgumentObject(oItem);
|
|
|
|
NWNX_CallFunction(NWNX_Item, sFunc);
|
|
}
|
|
|
|
void NWNX_Item_SetAddGoldPieceValue(object oItem, int g)
|
|
{
|
|
string sFunc = "SetAddGoldPieceValue";
|
|
|
|
NWNX_PushArgumentInt(g);
|
|
NWNX_PushArgumentObject(oItem);
|
|
|
|
NWNX_CallFunction(NWNX_Item, sFunc);
|
|
}
|
|
|
|
int NWNX_Item_GetBaseGoldPieceValue(object oItem)
|
|
{
|
|
string sFunc = "GetBaseGoldPieceValue";
|
|
|
|
NWNX_PushArgumentObject(oItem);
|
|
|
|
NWNX_CallFunction(NWNX_Item, sFunc);
|
|
return NWNX_GetReturnValueInt();
|
|
}
|
|
|
|
int NWNX_Item_GetAddGoldPieceValue(object oItem)
|
|
{
|
|
string sFunc = "GetAddGoldPieceValue";
|
|
|
|
NWNX_PushArgumentObject(oItem);
|
|
|
|
NWNX_CallFunction(NWNX_Item, sFunc);
|
|
return NWNX_GetReturnValueInt();
|
|
}
|
|
|
|
void NWNX_Item_SetBaseItemType(object oItem, int nBaseItem)
|
|
{
|
|
string sFunc = "SetBaseItemType";
|
|
|
|
NWNX_PushArgumentInt(nBaseItem);
|
|
NWNX_PushArgumentObject(oItem);
|
|
|
|
NWNX_CallFunction(NWNX_Item, sFunc);
|
|
}
|
|
|
|
void NWNX_Item_SetItemAppearance(object oItem, int nType, int nIndex, int nValue)
|
|
{
|
|
string sFunc = "SetItemAppearance";
|
|
|
|
NWNX_PushArgumentInt(nValue);
|
|
NWNX_PushArgumentInt(nIndex);
|
|
NWNX_PushArgumentInt(nType);
|
|
NWNX_PushArgumentObject(oItem);
|
|
|
|
NWNX_CallFunction(NWNX_Item, sFunc);
|
|
|
|
}
|
|
|
|
string NWNX_Item_GetEntireItemAppearance(object oItem)
|
|
{
|
|
string sFunc = "GetEntireItemAppearance";
|
|
|
|
NWNX_PushArgumentObject(oItem);
|
|
|
|
NWNX_CallFunction(NWNX_Item, sFunc);
|
|
return NWNX_GetReturnValueString();
|
|
}
|
|
|
|
void NWNX_Item_RestoreItemAppearance(object oItem, string sApp)
|
|
{
|
|
string sFunc = "RestoreItemAppearance";
|
|
|
|
NWNX_PushArgumentString(sApp);
|
|
NWNX_PushArgumentObject(oItem);
|
|
|
|
NWNX_CallFunction(NWNX_Item, sFunc);
|
|
}
|
|
|
|
int NWNX_Item_GetBaseArmorClass(object oItem)
|
|
{
|
|
string sFunc = "GetBaseArmorClass";
|
|
|
|
NWNX_PushArgumentObject(oItem);
|
|
|
|
NWNX_CallFunction(NWNX_Item, sFunc);
|
|
return NWNX_GetReturnValueInt();
|
|
}
|
|
|
|
int NWNX_Item_GetMinEquipLevel(object oItem)
|
|
{
|
|
string sFunc = "GetMinEquipLevel";
|
|
|
|
NWNX_PushArgumentObject(oItem);
|
|
|
|
NWNX_CallFunction(NWNX_Item, sFunc);
|
|
return NWNX_GetReturnValueInt();
|
|
}
|
|
|
|
int NWNX_Item_MoveTo(object oItem, object oTarget, int bHideAllFeedback = FALSE)
|
|
{
|
|
string sFunc = "MoveTo";
|
|
|
|
NWNX_PushArgumentInt(bHideAllFeedback);
|
|
NWNX_PushArgumentObject(oTarget);
|
|
NWNX_PushArgumentObject(oItem);
|
|
|
|
NWNX_CallFunction(NWNX_Item, sFunc);
|
|
|
|
return NWNX_GetReturnValueInt();
|
|
}
|