Listen Tags
Listen tags are tags that can receive shouts and whispers from other bots and actions that happen from the user. To create a listen tag, you make a normal tag and enter a "@" as the first character of the tag's value.
Each listen tag has some predefined variables that can be used. You can read about those here.
Whisper Tags
Whispers are shouts that are sent to specific bots instead of all bots.
@onCreate
A whisper that is sent to a bot when it is first created.
@onDestroy
A whisper that is sent to a bot when it is being destroyed.
@onModDrop
A whisper that is sent to a bot that a mod was dropped on.
If a custom @onModDrop
is not specified, then the mod will be applied automatically.
If a custom @onModDrop
is specified, then the mod needs to be applied manually via applyMod(bot, ...mods)
.
Arguments:
interface Mod {
[tag: string]: any;
}
let that: {
mod: Mod
};
@onModDropEnter
A whisper that is sent to the bot that a mod started to be dragged onto.
Arguments:
let that: {
mod: Mod,
dimension: string
};
@onModDropExit
A whisper that is sent to the bot that a mod was just dragged off of.
Arguments:
let that: {
mod: Mod,
dimension: string
};
@onClick
A whisper that is sent to the bot that was clicked.
Arguments:
let that: {
/**
* The face of the bot that was clicked.
*/
face: 'left' | 'right' | 'front' | 'back' | 'top' | 'bottom';
/**
* The dimension that the bot was clicked in.
*/
dimension: string;
/**
* The UV Coordinates that were clicked on the bot.
*/
uv: Vector2;
/**
* The modality that was used to click the bot.
*
* - `mouse` - The mouse was used to click the bot.
* - `touch` - A touch screen was used to click the bot.
* - `controller` - A XR controller was used to click the bot.
* - `finger` - A finger was used to click the bot in XR.
*/
modality: 'mouse' | 'touch' | 'controller' | 'finger';
/**
* For "finger" modalities, which hand was used to click the bot.
*/
hand: 'left' | 'right';
/**
* For "finger" modalities, which finger was used to click the bot.
*/
finger: 'index' | 'middle' | 'ring' | 'pinky' | 'thumb' | 'unknown';
/**
* For "mouse" modalities, which button was used to click the bot.
*/
buttonId: 'left' | 'middle' | 'right';
};
@onKeyClick
A whisper that is sent to the bot when a key is clicked on it.
This event will only be available for bots that have their #form
set to keyboard
.
Arguments:
let that: {
key: string
};
@onPointerEnter
A whisper that is sent to a bot when the mouse cursor starts to hover over it.
Arguments:
let that: {
/**
* The bot that the pointer hovered.
*/
bot: Bot;
/**
* The dimension that the bot was hovered in.
*/
dimension: string;
/**
* The modality that was used to hover over the bot.
*
* - `mouse` - The mouse was used to hover over the bot.
* - `touch` - A touch screen was used to hover over the bot.
* - `controller` - A XR controller was used to hover over the bot.
* - `finger` - A finger was used to hover over the bot in XR.
*/
modality: 'mouse' | 'touch' | 'controller' | 'finger';
/**
* For "finger" modalities, which hand was used to hover over the bot.
*/
hand: 'left' | 'right';
/**
* For "finger" modalities, which finger was used to hover over the bot.
*/
finger: 'index' | 'middle' | 'ring' | 'pinky' | 'thumb' | 'unknown';
/**
* For "mouse" modalities, which button was used to hover over the bot.
*/
buttonId: 'left' | 'middle' | 'right';
};
@onPointerExit
A whisper that is sent to a bot when the mouse cursor stops hovering over it.
Arguments:
let that: {
/**
* The bot that the pointer hovered.
*/
bot: Bot;
/**
* The dimension that the bot was hovered in.
*/
dimension: string;
/**
* The modality that was used to hover over the bot.
*
* - `mouse` - The mouse was used to hover over the bot.
* - `touch` - A touch screen was used to hover over the bot.
* - `controller` - A XR controller was used to hover over the bot.
* - `finger` - A finger was used to hover over the bot in XR.
*/
modality: 'mouse' | 'touch' | 'controller' | 'finger';
/**
* For "finger" modalities, which hand was used to hover over the bot.
*/
hand: 'left' | 'right';
/**
* For "finger" modalities, which finger was used to hover over the bot.
*/
finger: 'index' | 'middle' | 'ring' | 'pinky' | 'thumb' | 'unknown';
/**
* For "mouse" modalities, which button was used to hover over the bot.
*/
buttonId: 'left' | 'middle' | 'right';
};
@onPointerDown
A whipser that is sent to a bot when the user starts clicking it.
Arguments:
let that: {
/**
* The bot that the pointer started clicking.
*/
bot: Bot;
/**
* The dimension that the bot was clicked in.
*/
dimension: string;
/**
* The modality that was used to click the bot.
*
* - `mouse` - The mouse was used to click the bot.
* - `touch` - A touch screen was used to click the bot.
* - `controller` - A XR controller was used to click the bot.
* - `finger` - A finger was used to click the bot in XR.
*/
modality: 'mouse' | 'touch' | 'controller' | 'finger';
/**
* For "finger" modalities, which hand was used to click the bot.
*/
hand: 'left' | 'right';
/**
* For "finger" modalities, which finger was used to click the bot.
*/
finger: 'index' | 'middle' | 'ring' | 'pinky' | 'thumb' | 'unknown';
/**
* For "mouse" modalities, which button was used to click the bot.
*/
buttonId: 'left' | 'middle' | 'right';
};
@onPointerUp
A whisper that is sent to a bot when the user stops clicking it.
Arguments:
let that: {
/**
* The bot that the pointer stopped clicking.
*/
bot: Bot;
/**
* The dimension that the bot was clicked in.
*/
dimension: string;
/**
* The modality that was used to click the bot.
*
* - `mouse` - The mouse was used to click the bot.
* - `touch` - A touch screen was used to click the bot.
* - `controller` - A XR controller was used to click the bot.
* - `finger` - A finger was used to click the bot in XR.
*/
modality: 'mouse' | 'touch' | 'controller' | 'finger';
/**
* For "finger" modalities, which hand was used to click the bot.
*/
hand: 'left' | 'right';
/**
* For "finger" modalities, which finger was used to click the bot.
*/
finger: 'index' | 'middle' | 'ring' | 'pinky' | 'thumb' | 'unknown';
/**
* For "mouse" modalities, which button was used to click the bot.
*/
buttonId: 'left' | 'middle' | 'right';
};
@onDrag
A whisper that is sent whenever a bot is starting to be dragged.
Arguments:
let that: {
bot: Bot,
face: 'left' | 'right' | 'front' | 'back' | 'top' | 'bottom',
from: {
x: number,
y: number,
dimension: string
},
uv: Vector2
};
@onDragging
A whisper that is sent whenever a bot would be moved while dragging.
Note that this whisper is only sent for drag operations that have called os.enableCustomDragging()
.
Arguments:
let that: {
bot: Bot,
to: {
x: number,
y: number,
bot: Bot,
dimension: string
},
from: {
x: number,
y: number,
dimension: string
}
};
@onDrop
A whisper that is sent whenever a bot has been dropped after being dragged. The whisper is sent to both the bot that was dropped and the bot that was dropped on.
Arguments
let that: {
bot: Bot,
to: {
bot: Bot,
x: number,
y: number,
dimension: string
},
from: {
x: number,
y: number,
dimension: string
}
};
@onDropEnter
A whisper that is sent to both bots when a bot is dragged onto another bot.
Arguments
let that: {
dragBot: Bot,
to: {
bot: Bot,
x: number,
y: number,
dimension: string
},
from: {
x: number,
y: number,
dimension: string
}
};
@onDropExit
A whisper that is sent to both bots when a bot is dragged off of another bot.
Arguments
let that: {
dragBot: Bot,
to: {
bot: Bot,
x: number,
y: number,
dimension: string
},
from: {
x: number,
y: number,
dimension: string
}
};
@onSaveInput
A whisper that is sent when the input box for a bot has been changed by the user.
Arguments:
let that = null;
@onCloseInput
A whisper that is sent when the input box for a bot has been closed by the user.
Arguments:
let that = null;
@onListen
A whisper that is sent whenever this bot receives a whisper or shout.
Arguments:
let that: {
name: string,
that: any,
targets: Bot[],
listeners: Bot[],
responses: any[]
};
@onMaxLODEnter
A whisper that is sent whenever a bot enters its maximum Level-Of-Detail.
Arguments:
let that: {
bot: Bot,
dimension: string
};
@onMinLODEnter
A whisper that is sent whenever a bot enters its minimum Level-Of-Detail.
Arguments:
let that: {
bot: Bot,
dimension: string
};
@onMaxLODExit
A whisper that is sent whenever a bot exits its maximum Level-Of-Detail.
Arguments:
let that: {
bot: Bot,
dimension: string
};
@onMinLODExit
A whisper that is sent whenever a bot exits its minimum Level-Of-Detail.
Arguments:
let that: {
bot: Bot,
dimension: string
};
@onFocusEnter
A whisper that is sent whenever a bot starts being focused by the player.
Focus is when the bot is in the center of the screen.
Only sent if #focusable
is true.
Arguments:
let that: {
bot: Bot,
dimension: string
};
@onFocusExit
A whisper that is sent whenever a bot stops being focused by the player.
Focus is when the bot is in the center of the screen.
Arguments:
let that: {
bot: Bot,
dimension: string
};
@onInputTyping
A whisper that is sent whenever the player is typing in the menu bot's input box.
Only sent for bots that are in a menu and have #form
set to input
.
Arguments:
let that: {
text: string
};
@onSubmit
A whisper that is sent whenever the player submits the text in the menu bot's input box. This can happen by pressing enter while there is text in the box or by clicking the send button on the right side of the box.
Only sent for bots that are in a menu and have #form
set to input
.
Arguments:
let that: {
text: string
};
@onSetupApp
A whisper that is sent when a custom app has been setup.
Called when os.registerApp(appId, bot)
has completed its work.
Arguments:
let that: {
/**
* The HTML document that has been setup for the app
* See https://developer.mozilla.org/en-US/docs/Web/API/HTMLDocument
*/
document: Document
};
@onBotAdded
A whisper that is sent when the bot is added to the local inst.
Unlike @onCreate
, this listen tag is triggered whenever the bot as been added to the current device's inst, even if the bot has already been created.
An example of this happening is when you first load an inst. Even though all the bots have already been created, they still need to be added to the inst in order for you to interact with them.
Note that this listen tag is triggered after executing scripts have finished running. This means that if a script creates multiple bots, @onBotAdded
will be triggered after all the bots have been created.
This is in contrast to @onCreate
which is triggered immediately after the bot has been created.
Also note that this listen tag can be triggered before @onInstJoined
. This means that it is possible for bots in other spaces to not be available when this listener is triggered.
There is no that
argument for this listen tag.
@onBotChanged
A whisper that is sent when a tag on the bot is updated.
This listen tag is triggered whenever the bot has been updated in the current device's inst, even if the bot was not updated locally. An example of this happening is when another player changes a tag in the sheet portal. Even though the change was made on their device, it will show up on the current device.
Note that this listen tag is triggered after executing scripts have finished running. This means that if a script updates the same tag multiple times, @onBotChanged
will still only be triggered once.
This is in contrast to @onCreate
which is triggered immediately after the bot has been created.
Also note that this listen tag can be triggered before @onInstJoined
. This means that it is possible for bots in other spaces to not be available when this listener is triggered.
Arguments:
let that: {
/**
* The list of tags that were changed on the bot.
*/
tags: string[]
};
@[groupName][stateName]OnEnter
A whisper that is sent whenever the [groupName]
tag is set to [stateName]
via the changeState(bot, stateName, groupName?)
function.
Arguments:
let that: {
/**
* The stateName that the bot is coming from.
*/
from: string,
/**
* The stateName that the bot is going to.
*/
to: string,
};
@[groupName][stateName]OnExit
A whisper that is sent whenever the [groupName]
tag is changed from [stateName]
via the changeState(bot, stateName, groupName?)
function.
Arguments:
let that: {
/**
* The stateName that the bot is coming from.
*/
from: string,
/**
* The stateName that the bot is going to.
*/
to: string,
};
@onFormAnimationStarted
A whisper that is sent whenever an animation is started via the os.startFormAnimation(botOrBots, nameOrIndex, options?)
function.
Arguments:
let that: {
/**
* The animation that was started.
*/
animation: string | number;
};
@onFormAnimationStopped
A whisper that is sent whenever an animation is stopped via the os.stopFormAnimation(botOrBots, options?)
function.
Arguments:
let that: {
/**
* The animation that was stopped.
*/
animation: string | number;
};
@onFormAnimationLooped
A whisper that is sent whenever an animation finishes and starts to repeat based on the loop rules given to os.startFormAnimation(botOrBots, nameOrIndex, options?)
in the options.
Arguments:
let that: {
/**
* The animation that was looped.
*/
animation: string | number;
/**
* The number of loops that have been completed.
*/
loopCount: number;
};
@onFormAnimationFinished
A whisper that is sent whenever an animation that was started by os.startFormAnimation(botOrBots, nameOrIndex, options?)
stops.
This whisper is sent both for when the animation is manually stopped (by calling os.stopFormAnimation(botOrBots, options?)
) and also when it stops because it shouldn't repeat.
Arguments:
let that: {
/**
* The animation that finished.
*/
animation: string | number;
};
Shout Tags
Shouts are events which are sent to all bots.
@onAnyCreate
A shout that is sent to all bots when a bot is created. Sent immediately after @onCreate
is sent.
Arguments:
let that: {
bot: Bot
};
@onAnyBotClicked
A shout that is sent to all bots when a bot is clicked.
Arguments:
let that: {
/**
* The bot that was clicked.
*/
bot: Bot;
/**
* The face of the bot that was clicked.
*/
face: 'left' | 'right' | 'front' | 'back' | 'top' | 'bottom';
/**
* The dimension that the bot was clicked in.
*/
dimension: string;
/**
* The UV Coordinates that were clicked on the bot.
*/
uv: Vector2;
/**
* The modality that was used to click the bot.
*
* - `mouse` - The mouse was used to click the bot.
* - `touch` - A touch screen was used to click the bot.
* - `controller` - A XR controller was used to click the bot.
* - `finger` - A finger was used to click the bot in XR.
*/
modality: 'mouse' | 'touch' | 'controller' | 'finger';
/**
* For "finger" modalities, which hand was used to click the bot.
*/
hand: 'left' | 'right';
/**
* For "finger" modalities, which finger was used to click the bot.
*/
finger: 'index' | 'middle' | 'ring' | 'pinky' | 'thumb' | 'unknown';
/**
* For "mouse" modalities, which button was used to click the bot.
*/
buttonId: 'left' | 'middle' | 'right';
};
@onAnyBotPointerEnter
A shout that is sent to all bots when the mouse cursor starts to hover over a bot.
Arguments:
let that: {
bot: Bot,
dimension: string
};
@onAnyBotPointerExit
A shout that is sent to all bots when the mouse cursor stops hovering over a bot.
Arguments:
let that: {
bot: Bot,
dimension: string1
};
@onAnyBotPointerDown
A shout that is sent all bots when the user starts clicking a bot.
Arguments:
let that: {
bot: Bot,
dimension: string
};
@onAnyBotPointerUp
A shout that is sent to all bots when the user stops clicking a bot.
Arguments:
let that: {
bot: Bot,
dimension: string
};
@onChat
A shout that is sent to all bots when the player sends a chat message. Chat messages can be sent when the player presses the Enter key while writing a message or by clicking/tapping the "Send Message" button to the right of the chat bar.
Arguments:
let that: {
message: string
};
@onChatTyping
A shout that is sent to all bots when the player changes the text in the chat bar. Only triggered when the chat bar is visible.
Arguments:
let that: {
message: string
};
@onFileUpload
A shout that is sent to all bots when the user drags a file into the window.
Arguments:
let that: {
file: {
// The name of the file. Includes the file extension.
name: string;
// The size of the file in bytes.
size: number;
// The data in the file.
// If the file is a text file, the data will be a string.
// If the file is not a text file, then the data will be an ArrayBuffer.
//
// Text files have one of the following extensions:
// .txt
// .json
// .md
// .aux
// .html
// .js
// .ts
// All the other file extensions map to an ArrayBuffer
data: string | ArrayBuffer;
// The MIME type of the file.
// See https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/MIME_types for more information.
mimeType: string;
}
};
@onGridClick
A shout that is sent to all bots when the user clicks on empty space.
Arguments:
let that: {
/**
* The position within the dimension that was clicked.
*/
position: {
x: number,
y: number
};
/**
* The dimension that the grid was clicked on.
*/
dimension: string;
/**
* The modality that was used to click the grid.
*
* - `mouse` - The mouse was used to click the grid.
* - `touch` - A touch screen was used to click the grid.
* - `controller` - A XR controller was used to click the grid.
* - `finger` - A finger was used to click the grid in XR.
*/
modality: 'mouse' | 'touch' | 'controller' | 'finger';
/**
* For "finger" modalities, which hand was used to click the grid.
*/
hand: 'left' | 'right';
/**
* For "finger" modalities, which finger was used to click the grid.
*/
finger: 'index' | 'middle' | 'ring' | 'pinky' | 'thumb' | 'unknown';
/**
* For "mouse" modalities, which button was used to click the grid.
*/
buttonId: 'left' | 'middle' | 'right';
};
@onGridDown
A shout that is sent to all bots when the user starts clicking on empty space.
Arguments:
let that: {
/**
* The position within the dimension that was clicked.
*/
position: {
x: number,
y: number
};
/**
* The dimension that the grid was clicked on.
*/
dimension: string;
/**
* The modality that was used to click the grid.
*
* - `mouse` - The mouse was used to click the grid.
* - `touch` - A touch screen was used to click the grid.
* - `controller` - A XR controller was used to click the grid.
* - `finger` - A finger was used to click the grid in XR.
*/
modality: 'mouse' | 'touch' | 'controller' | 'finger';
/**
* For "finger" modalities, which hand was used to click the grid.
*/
hand: 'left' | 'right';
/**
* For "finger" modalities, which finger was used to click the grid.
*/
finger: 'index' | 'middle' | 'ring' | 'pinky' | 'thumb' | 'unknown';
/**
* For "mouse" modalities, which button was used to click the grid.
*/
buttonId: 'left' | 'middle' | 'right';
};
@onGridUp
A shout that is sent to all bots when the user stops clicking on empty space.
Arguments:
let that: {
/**
* The position within the dimension that was clicked.
*/
position: {
x: number,
y: number
};
/**
* The dimension that the grid was clicked on.
*/
dimension: string;
/**
* The modality that was used to click the grid.
*
* - `mouse` - The mouse was used to click the grid.
* - `touch` - A touch screen was used to click the grid.
* - `controller` - A XR controller was used to click the grid.
* - `finger` - A finger was used to click the grid in XR.
*/
modality: 'mouse' | 'touch' | 'controller' | 'finger';
/**
* For "finger" modalities, which hand was used to click the grid.
*/
hand: 'left' | 'right';
/**
* For "finger" modalities, which finger was used to click the grid.
*/
finger: 'index' | 'middle' | 'ring' | 'pinky' | 'thumb' | 'unknown';
/**
* For "mouse" modalities, which button was used to click the grid.
*/
buttonId: 'left' | 'middle' | 'right';
};
@onPortalChanged
A shout that is sent to all bots when a portal changes on the config bot.
Arguments:
let that: {
portal: string;
dimension: string;
};
@onBarcodeScanned
A shout that is sent to all bots when the player scans a barcode.
Arguments:
let that: string;
@onBarcodeScannerOpened
A shout that is sent to all bots when the barcode scanner is opened.
@onBarcodeScannerClosed
A shout that is sent to all bots when the barcode scanner is closed.
@onQRCodeScanned
A shout that is sent to all bots when a QR Code is scanned.
Arguments:
let that: string;
@onQRCodeScannerOpened
A shout that is sent to all bots when the QR Code Scanner is opened.
@onQRCodeScannerClosed
A shout that is sent to all bots when the QR Code Scanner is closed.
@onImageClassified
A shout that is sent to all bots when an image has been classified.
Arguments:
let that: {
/**
* The model that the classifier is currently operating on.
*/
model: {
/**
* The modelUrl that was provided to open the classifier.
*/
modelUrl?: string;
/**
* The modelJsonUrl that was provided to open the classifier.
*/
modelJsonUrl?: string;
/**
* The modelMetadataUrl that was provided to open the classifier.
*/
modelMetadataUrl?: string;
/**
* The cameraType that was provided to open the classifier.
*/
cameraType?: string;
/**
* The names of the categories that the loaded model contains.
*/
classLabels: string[];
};
/**
* The list of probablities that was produced by the classifier.
*/
prediction: {
/**
* The name of the class name.
*/
className: string;
/**
* The probability (between 0 and 1) that the image belongs to this category.
* All of the probabilities added together will equal (or be really close to) 1.
*/
probability: number;
}[];
};
@onImageClassifierOpened
A shout that is sent to all bots when the image classifier is opened.
Arguments:
let that: {
/**
* The modelUrl that was provided to open the classifier.
*/
modelUrl?: string;
/**
* The modelJsonUrl that was provided to open the classifier.
*/
modelJsonUrl?: string;
/**
* The modelMetadataUrl that was provided to open the classifier.
*/
modelMetadataUrl?: string;
/**
* The cameraType that was provided to open the classifier.
*/
cameraType?: string;
/**
* The names of the categories that the loaded model contains.
*/
classLabels: string[];
};
@onImageClassifierClosed
A shout that is sent to all bots when the image classifier is closed.
@onPhotoCaptured
A shout that is sent to all bots when a picture has been captured from the photo camera.
Arguments:
let that: {
photo: {
/**
* The width of the captured photo in pixels.
*/
width: number;
/**
* The height of the captured photo in pixels.
*/
height: number;
/**
* The data of the captured photo.
*/
data: Blob;
}
};
@onPhotoCameraOpened
A shout that is sent to all bots when the photo camera is opened.
@onPhotoCameraClosed
A shout that is sent to all bots when the photo camera is closed.
@onTapCode
A shout that is sent to all bots whenever a 4-digit tap code is entered.
Arguments:
let that: string;
@onKeyDown
A shout that is sent to all bots whenever the user starts pressing a key.
Arguments:
let that: {
/**
* The list of keys that were pressed.
*/
keys: string[]
};
@onKeyUp
A shout that is sent to all bots whenever the user stops pressing a key.
Arguments:
let that: {
/**
* The list of keys that were released.
*/
keys: string[]
};
@onKeyRepeat
A shout that is sent to all bots whenever the user holds down a key and it automatically fires "repeated key event". (This is like when you hold down the "a" key and then the computer starts continually typing "a" characters until you stop holding the key)
Arguments:
let that: {
/**
* The list of keys that were held.
*/
keys: string[]
};
@onInstJoined
A shout that is sent when a inst is loaded.
An inst is considered loaded once all the bots in each space have been added (See @onBotAdded
).
Sent to every inst that is loaded.
Arguments:
let that: {
inst: string
};
@onInstLeave
A shout that is sent when a inst is unloaded. Sent to every inst that is loaded.
Arguments:
let that: {
inst: string
};
@onInstStreaming
A shout that is sent when a inst is connected and fully synced.
Note that this can occur multiple times throughout the lifetime of a session because the player can lose and regain its connection to the inst.
Sent to every inst that is loaded.
Arguments:
let that: {
inst: string
};
@onInstStreamLost
A shout that is sent when a inst has been temporarily disconnected from the server.
Note that this can occur multiple times throughout the lifetime of a session because the player can lose and regain its connection to the inst.
Sent to every inst that is loaded.
Arguments:
let that: {
inst: string
};
@onCheckout
A shout that is sent when the user submits their credit card info to purchase something.
Arguments:
let that: {
token: string,
productId: string,
user: {
username: string,
device: string,
token: string
}
};
@onPaste
A shout that is sent when some text is pasted into the server.
This happens by pressing Ctrl+V or Cmd+V while something is in your clipboard.
Arguments:
let that: {
text: string;
};
@onPaymentSuccessful
A shout that is sent when payment has been approved for a checkout.
Arguments:
let that: {
/**
* The bot that was created for the transaction.
*/
bot: Bot,
charge: any,
extra: any
};
@onPaymentFailed
A shout that is sent when payment has been rejected for a checkout.
Arguments:
let that: {
/**
* The bot that was created for the transaction.
*/
bot: Bot,
error: any,
extra: any
};
@onAnyBotDrag
A shout that is sent whenever a bot starts to be dragged.
Arguments:
let that: {
bot: Bot,
face: 'left' | 'right' | 'front' | 'back' | 'top' | 'bottom',
from: {
x: number,
y: number,
dimension: string
},
uv: Vector2
};
@onAnyBotDragging
A shout that is sent whenever a bot would be moved while dragging.
Note that this whisper is only sent for drag operations that have called os.enableCustomDragging()
.
Arguments:
let that: {
bot: Bot,
to: {
bot: Bot,
x: number,
y: number,
dimension: string
},
from: {
x: number,
y: number,
dimension: string
}
};
@onAnyBotDrop
A shout that is sent whenever a bot is dropped after being dragged.
Arguments:
let that: {
bot: Bot,
to: {
bot: Bot,
x: number,
y: number,
dimension: string
},
from: {
x: number,
y: number,
dimension: string
}
};
@onAnyBotDropEnter
A shout that is sent whenever a bot is dragged onto another bot.
Arguments:
let that: {
dragBot: Bot,
to: {
bot: Bot,
x: number,
y: number,
dimension: string
},
from: {
x: number,
y: number,
dimension: string
}
};
@onAnyBotDropExit
A shout that is sent whenever a bot is dragged off of another bot.
Arguments:
let that: {
dragBot: Bot,
to: {
bot: Bot,
x: number,
y: number,
dimension: string
},
from: {
x: number,
y: number,
dimension: string
}
};
@onAnyListen
A shout that is sent whenever a whisper or shout is issued.
Arguments:
let that: {
name: string,
that: any,
targets: Bot[],
listeners: Bot[],
responses: any[]
};
@onAnyMaxLODEnter
A shout that is sent whenever a bot enters its maximum Level-Of-Detail.
Only sent for bots that have one of @onMaxLODEnter
, @onMaxLODExit
, @onMinLODEnter
, @onMinLODExit
, #maxLODThreshold
or #minLODThreshold
specified.
Arguments:
let that: {
bot: Bot,
dimension: string
};
@onAnyMinLODEnter
A shout that is sent whenever a bot enters its minimum Level-Of-Detail.
Only sent for bots that have one of @onMaxLODEnter
, @onMaxLODExit
, @onMinLODEnter
, @onMinLODExit
, #maxLODThreshold
or #minLODThreshold
specified.
Arguments:
let that: {
bot: Bot,
dimension: string
};
@onAnyMaxLODExit
A shout that is sent whenever a bot exits its maximum Level-Of-Detail.
Only sent for bots that have one of @onMaxLODEnter
, @onMaxLODExit
, @onMinLODEnter
, @onMinLODExit
, #maxLODThreshold
or #minLODThreshold
specified.
Arguments:
let that: {
bot: Bot,
dimension: string
};
@onAnyMinLODExit
A shout that is sent whenever a bot exits its minimum Level-Of-Detail.
Only sent for bots that have one of @onMaxLODEnter
, @onMaxLODExit
, @onMinLODEnter
, @onMinLODExit
, #maxLODThreshold
or #minLODThreshold
specified.
Arguments:
let that: {
bot: Bot,
dimension: string
};
@onAnyFocusEnter
A shout that is sent whenever a bot starts being focused by the player.
Focus is when the bot is in the center of the screen.
Only sent if #focusable
is true.
Arguments:
let that: {
bot: Bot,
dimension: string
};
@onAnyFocusExit
A shout that is sent whenever a bot stops being focused by the player.
Focus is when the bot is in the center of the screen.
Arguments:
let that: {
bot: Bot,
dimension: string
};
@onBeginAudioRecording
A shout that is sent whenever audio recording starts.
There are no arguments with this listener.
@onAudioChunk
A shout that is sent whenever a piece of audio is prepared for streaming.
Only called when os.beginAudioRecording(options?)
is called with stream
set to true
.
Arguments:
let that: Blob;
@onEndAudioRecording
A shout that is sent whenever audio recording stops.
If the data was streamed, that
is null
. Otherwise, that
is a Blob
object that contains the recorded data.
Arguments:
let that: Blob;
@onEnterAR
A shout that is sent whenever the device enters augmented reality mode.
You can enter AR by calling os.enableAR(options?)
.
There are no arguments with this listener.
@onExitAR
A shout that is sent whenever the device exits augmented reality mode.
You can exit AR by calling os.disableAR()
.
There are no arguments with this listener.
@onEnterVR
A shout that is sent whenever the device enters virtual reality mode.
You can exit VR by calling os.enterVR(options?)
.
There are no arguments with this listener.