Constructor
new WorldManager(world, fps)
Creates world manager with default values and connection, scene, camera listeners.
Parameters:
Name | Type | Description |
---|---|---|
world |
||
fps |
network framerate, default 5 (send up to 5 events per second) |
- Source:
Classes
Members
avatarFactory
Avatar factory, default this.createAvatar
- Source:
changeListeners
Change listeners receive changes applied to all shared objects
- Source:
createAnimations
Create animations for movement of avatars, default true. Recommended for low fps.
- Source:
customAnimations
Custom avatar animations
- Source:
customOptions
Custom avatar options, applied to avatars after loading. Currently video avatars only
- Source:
debug
Enable debug output
- Source:
defaultPosition
Default position applied after an avatar loads
- Source:
defaultRotation
Default rotation applied after an avatar loads
- Source:
fps
Network frames per second, default 5
- Source:
instance
Current WorldManager instance @type {WorldManager}
- Source:
leftArmPos
Current left arm position
- Source:
leftArmRot
Current left arm rotation
- Source:
loadCallback
Optionally called after an avatar has loaded. Callback is passed VRObject and avatar object as parameters.
Avatar object can be either Avatar or VideoAvatar instance, or an AssetContainer.
TODO this needs to go away, but is used in WorldEditor.
- Source:
loadErrorHandler
Called when loading fails, default null.
TODO used in WorldEditor, replace with WorldListener
- Source:
mediaStreams
This is set once we connect to streaming server
- Source:
myChangeListeners
Listeners notified after own avatar property (e.g. position) has changed and published
- Source:
pos
Current position
- Source:
remoteLogging
Mobile browsers don't have javascript console, and USB debugging is next to useless.
Enable to redirect all console output to the server log. Sure, it starts only after connection to the server is established.
- Source:
resolution
Movement resolution, default 1 cm/3.6 deg. Any movement less than this will be ignored.
- Source:
rightArmPos
Current right arm position
- Source:
rightArmRot
Current right arm rotation
- Source:
rot
Current rotation
- Source:
scene
the scene
- Source:
tokens
client tokens
- Source:
trackedMesh
In 3rd person view, we're not tracking and publishing position and orientation camera, but of this mesh
- Source:
trackRotation
Whether to track user rotation, default true.
- Source:
userHeight
User height in real world, default 1.8
- Source:
world
the world @type {World}
- Source:
Methods
(static) myId()
Returns VRSPACE.me if available, null otherwise
- Source:
addChangeListener()
Add a listener to remote events
- Source:
addMyChangeListener()
Add a listener to own events
- Source:
bBoxMax()
Utility method, calculates bounding box for an AssetContainer and returns maximum of x,y,z.
Works only for meshes already rendered
- Source:
boundingBox()
Utility method, calculates bounding box for an AssetContainer.
- Source:
Returns:
Vector3 bounding box
changeAvatar()
Apply remote changes to an avatar (VRObject listener)
- Source:
changeObject()
Apply remote changes to an object.
- Source:
checkChange()
Check if a value has changed, and update change array if so.
- Source:
createAvatar()
Default video avatar factory method
- Source:
(async) createAvatarFromUrl(url)
Creates new Avatar instance from the URL
Parameters:
Name | Type | Description |
---|---|---|
url |
URL to load avatar from |
- Source:
(async) enter(properties)
Enter the world specified by world.name. If not already connected,
first connect to world.serverUrl and set own properties, then start the session.
World and WorldListeners are notified by calling entered methods.
Parameters:
Name | Type | Description |
---|---|---|
properties |
own properties to set before starting the session |
- Source:
Returns:
Welcome promise
(async) enterAs()
Enter the world as avatar.
Creates propererties by taking user name, height and avatar url from given Avatar,
then calls enter( properties ).
- Source:
entered()
Called after user enters a world, calls world.entered() wrapped in try/catch
- Source:
(async) enterWith(avatarUrl, userName)
Quick enter, with avatar url and optionally user name.
Parameters:
Name | Type | Description |
---|---|---|
avatarUrl |
URL to load avatar from | |
userName |
login name of the user |
- Source:
Returns:
own Avatar instance
isChanged()
Return true if a value is ouside of given range.
- Source:
isOnline()
Returns true if connected to the server and session is active
- Source:
(async) loadAvatar(obj)
Load a 3D avatar, attach a listener to it
Parameters:
Name | Type | Description |
---|---|---|
obj |
VRObject that represents the user |
- Source:
(async) loadMesh()
Load an object and attach a listener.
- Source:
loadMeshAvatar()
Any 3d object can be an avatar
- Source:
loadScript()
Load a script, call it's constructor with the VRObject, then calls init(), and adds the listener.
See basic-script.js and web-portal.js.
- Source:
loadStream()
Load a video avatar, attach a listener to it.
- Source:
log()
Optionally log something
- Source:
notifyListeners()
Notify listeners of remote changes
- Source:
publishChanges(changes)
Publish changes to the server (if online) and local change listeners
Parameters:
Name | Type | Description |
---|---|---|
changes |
array of objects with field-value pairs |
- Source:
pubSub(user, autoPublishVideo)
Publish and subscribe
Parameters:
Name | Type | Description |
---|---|---|
user |
Client | Client object of the local user |
autoPublishVideo |
boolean | should webcam video be published as soon as possible |
- Source:
removeChangeListener()
Remove listener to remote events
- Source:
removeMyChangeListener()
Remove listener to own events
- Source:
removeObject()
Remove an object: remove the mesh from the scene (scene listener), and dispose of everything.
- Source:
routeEvent(obj, field)
Called when applying changes other than rotation and translation:
executes a method if such a method exists, passing it a current instance of associated VRObject.
Parameters:
Name | Type | Description |
---|---|---|
obj |
VRObject to apply change to | |
field |
member field to set or method to execute |
- Source:
sceneChanged(e)
Called when scene has changed (scene listener).
If an object was added, calls either loadAvatar, loadStream or loadMesh, as appropriate.
If an object was removed, calls removeObject.
Any WorldListeners on the world are notified after changes are performed, by calling added and removed methods.
Parameters:
Name | Type | Description |
---|---|---|
e |
SceneEvent containing the change |
- Source:
sendMy(obj)
Send own event.
Parameters:
Name | Type | Description |
---|---|---|
obj |
object containing changes to be sent, i.e. name-value pair(s). |
- Source:
setSessionStatus()
Called when connection to the server is established (connection listener)
- Source:
trackCamera()
Tracks active camera
- Source:
trackChanges()
Periodically executed, as specified by fps.
Tracks changes to camera and XR controllers.
Calls checkChange, and if anything has changed, changes are sent to server,
and to myChangeListeners.
- Source:
trackMesh()
Track a mesh, used in 3rd person view
- Source:
write()
Local user wrote something - send it over and notify local listener(s)
- Source: