|
export class LevelsAPI{
|
|
|
|
/**
|
|
* Test if a specified elevation is withing the range of a specified document, bounds are included.
|
|
* @param {Document} document - the document to be tested
|
|
* @param {Float} elevation - the elevation to test against
|
|
* @returns {Boolean} returns wether the elevation is in the range or not
|
|
**/
|
|
|
|
static inRange(document, elevation){
|
|
return CONFIG.Levels.helpers.inRange(document, elevation);
|
|
}
|
|
|
|
/**
|
|
* Test if a token's losHeight is contained within the range of the placeable or document.
|
|
* @param {Token} token - the token to test
|
|
* @param {PlaceableObject|Document} placeableOrDocument - "sight" or "collision" (defaults to "sight")
|
|
* @param {boolean} useElevation - if true, use the token's elevation, otherwise use the token's losHeight (the 'eye' elevation)
|
|
* @returns {Boolean} returns wether the token is in the range or not
|
|
**/
|
|
|
|
static isTokenInRange(token, placeableOrDocument, useElevation = true){
|
|
placeableOrDocument = placeableOrDocument?.document ?? placeableOrDocument;
|
|
const elevation = useElevation ? token.document.elevation : token.losHeight;
|
|
return CONFIG.Levels.helpers.inRange(placeableOrDocument, elevation);
|
|
}
|
|
|
|
/**
|
|
* Perform a collision test between 2 TOKENS in 3D space
|
|
* @param {Token} token1 - a token, the source of the check
|
|
* @param {Token} token2 - a token, the target of the check
|
|
* @param {String} type - "sight" or "collision" (defaults to "sight")
|
|
* @returns {Object|Boolean} returns the collision point if a collision is detected, flase if it's not
|
|
**/
|
|
|
|
static checkCollision(token1, token2, type = "sight"){
|
|
return CONFIG.Levels.handlers.SightHandler.checkCollision(token1, token2, type);
|
|
}
|
|
|
|
/**
|
|
* Perform a collision test between 2 point in 3D space
|
|
* @param {Object} p0 - a point in 3d space {x:x,y:y,z:z} where z is the elevation
|
|
* @param {Object} p1 - a point in 3d space {x:x,y:y,z:z} where z is the elevation
|
|
* @param {String} type - "sight" or "collision" (defaults to "sight")
|
|
* @returns {Object|Boolean} returns the collision point if a collision is detected, flase if it's not
|
|
**/
|
|
|
|
static testCollision(p0, p1, type = "sight"){
|
|
return CONFIG.Levels.handlers.SightHandler.testCollision(p0, p1, type);
|
|
}
|
|
}
|