Player Items
Adding New Player Items
- To add a new player item, locate the Hands object inside the HEROPLAYER object. Create a new game object in the Hands object and name it as you want, but to keep the structure clean, name it, for example: FlashlightItem 

- Add your player item model with animations to the newly created player item object and name it, for example: FlashlightAnims. 

- (optional) If you want to add a nice sway effect to the item when you move the camera, create a new object inside your newly created item and name it, for example Pivot, and position it at the pivot point in the player item model. Then add the item model object to the Pivot object, as shown in the image at Step 1. 

- If you don't have one, create a new Animator Controller asset. Add your item animation states to it and create transitions between them. After creating the Animator Controller asset and setting up the animation states and transitions, assign the Controller reference in the Animator component of the - FlashlightAnimsobject.

- To handle all the logic of the player item, create a new script. For this guide, I'll name it - Flashlightand derive it from the PlayerItemBehaviour class.
- After deriving from the PlayerItemBehaviour class, you will be prompted to implement the four main functions that handle when the item is selected or deselected. 
using UnityEngine;
using UHFPS.Runtime;
public class Flashlight : PlayerItemBehaviour
{
    public ItemGuid BatteryItem;
    public override void OnItemSelect()
    {
        // do something when the item is selected
    }
    
    public override void OnItemDeselect()
    {
        // do something when the item is deselected
    }
    
    public override void OnItemActivate()
    {
        // do something when the item is activated
    }
    
    public override void OnItemDeactivate()
    {
        // do something when the item is deactivated
    }
}- In the editor script, derive from the PlayerItemEditor class and override the OnInspectorGUI() function to define how your script should look in the inspector. Here is a code snippet for the - FlashlightEditorscript:
using UnityEngine;
using UnityEditor;
using ThunderWire.Editors;
namespace UHFPS.Editors
{
    [CustomEditor(typeof(Flashlight))]
    public class FlashlightEditor : PlayerItemEditor<Flashlight>
    {
        public override void OnEnable()
        {
            // when overriding OnEnable(), do not remove the base.OnEnable()
            base.OnEnable();
        }
    
        public override void OnInspectorGUI()
        {
            EditorDrawing.DrawInspectorHeader(new GUIContent("Flashlight"), Target);
            EditorGUILayout.Space();
            serializedObject.Update();
            {
                base.OnInspectorGUI(); // this will draw settings dropdown
                EditorGUILayout.Space();
                Properties.Draw("<ItemObject>k__BackingField");
                Properties.Draw("BatteryItem");
            }
            serializedObject.ApplyModifiedProperties();
        }
    }
}Make sure to put the editor script in the Editor folder, otherwise you won't be able to find some editor class references.
- Add the - Flashlightscript to the- Flashlightobject and set the Item Object reference to the- FlashlightAnimsobject where the Animator is located.
- (optional) To enable the Item Motions, simply enable the Motion Preset feature and assign the Motion Preset and Motion Pivot. You can also leave the Motion Pivot object unassigned if you want to use the default camera pivot object. 



- Add your newly created player item to the Player Items Manager component in FPView inside the HEROPLAYER object. 

- To make an item equippable, you can open the inventory builder and enable the Is Usable setting. After that, set the Usable Type to Player Item and assign the Player Item reference. 

External Motions
- To enable external motions, go to the player item script and enable Camera Motions. 

- Add external motion states and define a custom Event ID that will be used to identify the state to be played from the player item script. 

- Add motion modules to the motion state. Currently there are only a few, but you can create your own modules very easily. 

- Finally, you can apply external motions by calling the ApplyEffect() method in the Player Item script, which inherits from PlayerItemBehaviour. 


Last updated
