Adding Avatar Agents or NPCs
Introduction
Avatar models can be brought into SightLab if they are in .fbx
, .glTF
, or .cfg
formats. These avatars can serve as Non-Player Characters (NPCs) or intelligent agents in your VR experiments.
Resources
Avatar Libraries
- FBX Avatars: Workflow Tips
- Mixamo Avatars Tutorial | Mixamo Website
- Reallusion Avatars: Workflow Tips | Character Creator | ActorCore Library
- Ready Player Me Workflow
- Avaturn | MetaPerson | RocketBox Avatars
Included Avatars
- Sample avatars are included with SightLab under:
C:\Program Files\WorldViz\Sightlab2\sightlab_resources\avatar\full_body
C:\Program Files\WorldViz\Sightlab2\sightlab_resources\avatar\Complete Character
C:\Program Files\WorldViz\Vizard\<version>\bin\lib\site-packages\sightlab_utils\resources\avatar
Replace <version>
with Vizard7
or Vizard8
.
- Additional avatars are available in the Additional Asset Pack.
Adding an NPC to the Scene
-
Open the Environment:
- Open your environment in the Inspector scene editor via "Modify" > "Edit" in the GUI or directly from the project folder by double clicking your model.
-
Add an Avatar:
- Go to
File > Add
. - Navigate to
sightlab_resources/objects
and choosestandInAvatar.osgb
(or can directly place your avatar and use the root node). - Adjust the avatar's position and scale as necessary.
- Go to
-
Position the Avatar:
- Select the
avatarTransform
node in the Scene Graph. - Use the Translate and Rotate tools to place the avatar.
- Select the
-
Preview Animations:
- Open the avatar in Inspector.
- Use the "Animations" tab to review available animations.
-
Place the Avatar Using Code:
- Import the
avatarPlacer
module. - Call the
place
function with the required arguments, including your environment, avatar, and the name of the GEODE or avatar root node you wish to target:avatarPlacer.place(myEnvironment, myAvatar, 'avatarStandin')
- Add this code to your
SightlabVR.py
script for single-user experiments. For multi-user experiments, include it in both the client and server scripts.
- Import the
Using GEODE or Avatar Root
The avatarPlacer
module is specifically designed to work with either GEODE nodes in the scene graph or the avatar root.
Specify the name of the GEODE node or the avatar root to place the avatar. Using other types of nodes may lead to unexpected behavior.
Example:
avatarPlacer.place(env, avatar, "GEODE_NODE_NAME")
# OR
avatarPlacer.place(env, avatar, "avatarRoot")
Sample Code
script provided in ExampleScripts/Adding_NPCs.py
.
from sightlab_utils import avatarPlacer
import sightlab_utils.sightlab as sl
from sightlab_utils.settings import *
# Initialize SightLab without GUI
sightlab = sl.SightLab(gui=False)
# Load Environment
env = vizfx.addChild("sightlab_resources/environments/ShowRoom_standin_avatar.osgb")
sightlab.setEnvironment(env)
#Load avatar, making sure to use avatar = True
avatar = vizfx.addAvatar("sightlab_resources/avatar/full_body/RocketBox_Male1.osgb")
sightlab.addSceneObject("avatar", avatar, gaze=True, avatar=True)
def sightLabExperiment():
while True:
yield viztask.waitKeyDown(" ")
yield sightlab.startTrial()
# Place the avatar in the scene
avatarPlacer.place(env, avatar, "avatarStandin")
# Set avatar animation state
avatar.state(1)
yield viztask.waitKeyDown(" ")
yield sightlab.endTrial()
viztask.schedule(sightlab.runExperiment)
viztask.schedule(sightLabExperiment)
viz.callback(viz.getEventID("ResetPosition"), sightlab.resetViewPoint)
Customizing Avatar Position and Rotation
Can also override the position and rotation using this code:
avatar.setPosition(0, 0, 2)
avatar.setEuler(180, 0, 0)
Replay Integration
Add this to your session replay script to not show the standin avatar object:
def ontrialchanged():
trial_number = int(replay.currTrial)
avatarObject = replay.sceneObjects[AVATAR_OBJECTS]["avatar"]
env = replay.getEnvironmentObject()
env.getChild('avatarStandin').alpha(0)
viz.callback(TRIAL_LOADED_EVENT, ontrialchanged)
ontrialchanged()
Creating Animations for Avatars
Tools for Animation
High-End Solutions
- Xsens
- Optitrack
- Vicon
Helpful Links
More information on avatars in the Vizard Documentation