UNPKG

@dcl-sdk/utils

Version:

A collection of helpers to make it easier to build a Decentraland scene using the SDK 7.

239 lines 34.5 kB
import { Transform } from '@dcl/sdk/ecs'; import { Vector3, Quaternion } from '@dcl/sdk/math'; export function remap(value, min1, max1, min2, max2) { let range1 = max1 - min1; let range2 = max2 - min2; return ((value - min1) / range1) * range2 + min2; } export function getWorldPosition(entity) { let transform = Transform.getOrNull(entity); if (!transform) return Vector3.Zero(); let parent = transform.parent; if (!parent) { return transform.position; } else { let parentRotation = Transform.get(parent).rotation; return Vector3.add(getWorldPosition(parent), Vector3.rotate(transform.position, getWorldRotation(parent))); } } export function getWorldRotation(entity) { let transform = Transform.getOrNull(entity); if (!transform) return Quaternion.Identity(); let parent = transform.parent; if (!parent) { return transform.rotation; } else { return Quaternion.multiply(transform.rotation, getWorldRotation(parent)); } } export var InterpolationType; (function (InterpolationType) { InterpolationType["LINEAR"] = "linear"; InterpolationType["EASEINQUAD"] = "easeinquad"; InterpolationType["EASEOUTQUAD"] = "easeoutquad"; InterpolationType["EASEQUAD"] = "easequad"; InterpolationType["EASEINSINE"] = "easeinsine"; InterpolationType["EASEOUTSINE"] = "easeoutsine"; InterpolationType["EASESINE"] = "easeinoutsine"; InterpolationType["EASEINEXPO"] = "easeinexpo"; InterpolationType["EASEOUTEXPO"] = "easeoutexpo"; InterpolationType["EASEEXPO"] = "easeinoutexpo"; InterpolationType["EASEINELASTIC"] = "easeinelastic"; InterpolationType["EASEOUTELASTIC"] = "easeoutelastic"; InterpolationType["EASEELASTIC"] = "easeinoutelastic"; InterpolationType["EASEINBOUNCE"] = "easeinbounce"; InterpolationType["EASEOUTEBOUNCE"] = "easeoutbounce"; InterpolationType["EASEBOUNCE"] = "easeinoutbounce"; })(InterpolationType || (InterpolationType = {})); export function interpolate(type, t) { switch (type) { case InterpolationType.LINEAR: return InterpolateLinear(t); case InterpolationType.EASEINQUAD: return InterpolateEaseInQuad(t); case InterpolationType.EASEOUTQUAD: return InterpolateEaseOutQuad(t); case InterpolationType.EASEQUAD: return InterpolateEaseQuad(t); case InterpolationType.EASEINSINE: return InterpolateEaseInSine(t); case InterpolationType.EASEOUTSINE: return InterpolateEaseOutSine(t); case InterpolationType.EASESINE: return InterpolateEaseInOutSine(t); case InterpolationType.EASEINEXPO: return InterpolateEaseInExpo(t); case InterpolationType.EASEOUTEXPO: return InterpolateEaseOutExpo(t); case InterpolationType.EASEEXPO: return InterpolateEaseInOutExpo(t); case InterpolationType.EASEINELASTIC: return InterpolateEaseInElastic(t); case InterpolationType.EASEOUTELASTIC: return InterpolateEaseOutElastic(t); case InterpolationType.EASEELASTIC: return InterpolateEaseInOutElastic(t); case InterpolationType.EASEINBOUNCE: return InterpolateEaseInBounce(t); case InterpolationType.EASEOUTEBOUNCE: return InterpolateEaseOutBounce(t); case InterpolationType.EASEBOUNCE: return InterpolateEaseInOutBounce(t); default: return InterpolateLinear(t); } } function InterpolateLinear(t) { return t; } function InterpolateEaseInQuad(t) { return t * t; } function InterpolateEaseOutQuad(t) { return t * (2 - t); } function InterpolateEaseQuad(t) { return (t * t) / (2.0 * (t * t - t) + 1.0); } function InterpolateEaseInSine(t) { return 1 - Math.cos((t * Math.PI) / 2); } function InterpolateEaseOutSine(t) { return Math.sin((t * Math.PI) / 2); } function InterpolateEaseInOutSine(t) { return -(Math.cos(Math.PI * t) - 1) / 2; } function InterpolateEaseInExpo(t) { return t === 0 ? 0 : Math.pow(2, 10 * t - 10); } function InterpolateEaseOutExpo(t) { return t === 1 ? 1 : 1 - Math.pow(2, -10 * t); } function InterpolateEaseInOutExpo(t) { return t === 0 ? 0 : t === 1 ? 1 : t < 0.5 ? Math.pow(2, 20 * t - 10) / 2 : (2 - Math.pow(2, -20 * t + 10)) / 2; } function InterpolateEaseInElastic(t) { const c4 = (2 * Math.PI) / 3; return t === 0 ? 0 : t === 1 ? 1 : -Math.pow(2, 10 * t - 10) * Math.sin((t * 10 - 10.75) * c4); } function InterpolateEaseOutElastic(t) { const c5 = (2 * Math.PI) / 3; return t === 0 ? 0 : t === 1 ? 1 : Math.pow(2, -10 * t) * Math.sin((t * 10 - 0.75) * c5) + 1; } function InterpolateEaseInOutElastic(t) { const c6 = (2 * Math.PI) / 4.5; return t === 0 ? 0 : t === 1 ? 1 : t < 0.5 ? -(Math.pow(2, 20 * t - 10) * Math.sin((20 * t - 11.125) * c6)) / 2 : (Math.pow(2, -20 * t + 10) * Math.sin((20 * t - 11.125) * c6)) / 2 + 1; } function InterpolateEaseInBounce(t) { return 1 - bounce(1 - t); } function InterpolateEaseOutBounce(t) { return bounce(t); } function InterpolateEaseInOutBounce(t) { return t < 0.5 ? (1 - bounce(1 - 2 * t)) / 2 : (1 + bounce(2 * t - 1)) / 2; } function bounce(x) { const n1 = 7.5625; const d1 = 2.75; if (x < 1 / d1) { return n1 * x * x; } else if (x < 2 / d1) { return n1 * (x -= 1.5 / d1) * x + 0.75; } else if (x < 2.5 / d1) { return n1 * (x -= 2.25 / d1) * x + 0.9375; } else { return n1 * (x -= 2.625 / d1) * x + 0.984375; } } export function createCatmullRomSpline(points, nbPoints, closed) { const catmullRom = new Array(); const step = 1.0 / nbPoints; let amount = 0.0; if (closed) { const pointsCount = points.length; for (let i = 0; i < pointsCount; i++) { amount = 0; for (let c = 0; c < nbPoints; c++) { catmullRom.push(Vector3.catmullRom(points[i % pointsCount], points[(i + 1) % pointsCount], points[(i + 2) % pointsCount], points[(i + 3) % pointsCount], amount)); amount += step; } } catmullRom.push(catmullRom[0]); } else { const totalPoints = new Array(); totalPoints.push(Vector3.clone(points[0])); Array.prototype.push.apply(totalPoints, points); totalPoints.push(Vector3.clone(points[points.length - 1])); let i = 0; for (; i < totalPoints.length - 3; i++) { amount = 0; for (let c = 0; c < nbPoints; c++) { catmullRom.push(Vector3.catmullRom(totalPoints[i], totalPoints[i + 1], totalPoints[i + 2], totalPoints[i + 3], amount)); amount += step; } } i--; catmullRom.push(Vector3.catmullRom(totalPoints[i], totalPoints[i + 1], totalPoints[i + 2], totalPoints[i + 3], amount)); } return catmullRom; } export function areAABBIntersecting(aMin, aMax, bMin, bMax) { return (aMin.x <= bMax.x && aMax.x >= bMin.x && aMin.y <= bMax.y && aMax.y >= bMin.y && aMin.z <= bMax.z && aMax.z >= bMin.z); } export function areSpheresIntersecting(aPos, aRadius, bPos, bRadius) { const sqDist = Vector3.distanceSquared(aPos, bPos); const radiusSum = aRadius + bRadius; return sqDist < radiusSum * radiusSum; } export function areAABBSphereIntersecting(boxMin, boxMax, spherePos, sphereRadius) { let dmin = 0; if (spherePos.x < boxMin.x) dmin += (boxMin.x - spherePos.x) * (boxMin.x - spherePos.x); if (spherePos.x > boxMax.x) dmin += (spherePos.x - boxMax.x) * (spherePos.x - boxMax.x); if (spherePos.y < boxMin.y) dmin += (boxMin.y - spherePos.y) * (boxMin.y - spherePos.y); if (spherePos.y > boxMax.y) dmin += (spherePos.y - boxMax.y) * (spherePos.y - boxMax.y); if (spherePos.z < boxMin.z) dmin += (boxMin.z - spherePos.z) * (boxMin.z - spherePos.z); if (spherePos.z > boxMax.z) dmin += (spherePos.z - boxMax.z) * (spherePos.z - boxMax.z); return dmin < sphereRadius * sphereRadius; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"math.js","sourceRoot":"","sources":["../src/math.ts"],"names":[],"mappings":"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","sourcesContent":["import { Entity, Transform } from '@dcl/sdk/ecs'\nimport { Vector3, Quaternion } from '@dcl/sdk/math'\n\n/**\n * Remaps a value from one range of values to its equivalent, scaled in proportion to another range of values, using maximum and minimum.\n *\n * @param value - value input number\n * @param min1 - min1 Minimum value in the range of the input.\n * @param max1 - max1 Maximum value in the range of the input.\n * @param min2 - min2 Minimum value in the range of the output.\n * @param max2 - max2 Maximum value in the range of the output.\n * @returns The resulting remapped value between the new min and max\n * @public\n */\nexport function remap(\n  value: number,\n  min1: number,\n  max1: number,\n  min2: number,\n  max2: number\n) {\n  let range1 = max1 - min1\n  let range2 = max2 - min2\n  return ((value - min1) / range1) * range2 + min2\n}\n\n/**\n * Returns the position of an entity that is a child of other entities, relative to the scene instead of relative to the parent. Returns a Vector3.\n *\n * @param entity - Entity to calculate position\n * @returns The Entity's global position relative to the scene's origin\n * @public\n */\nexport function getWorldPosition(entity: Entity): Vector3 {\n  let transform = Transform.getOrNull(entity)\n\n\n  if (!transform) return Vector3.Zero()\n\n  let parent = transform.parent\n\n  if (!parent) {\n    return transform.position\n  } else {\n    let parentRotation = Transform.get(parent).rotation\n    return Vector3.add(getWorldPosition(parent), Vector3.rotate(transform.position, getWorldRotation(parent)))\n  }\n}\n\n/**\n * Returns the position of an entity that is a child of other entities, relative to the scene instead of relative to the parent. Returns a Vector3.\n *\n * @param entity - Entity to calculate position\n * @returns The Entity's global rotation in reference to the scene's origin\n * @public\n */\nexport function getWorldRotation(entity: Entity): Quaternion {\n  let transform = Transform.getOrNull(entity)\n\n  if (!transform)\n    return Quaternion.Identity()\n\n  let parent = transform.parent\n\n  if (!parent) {\n    return transform.rotation\n  } else {\n    return Quaternion.multiply(transform.rotation, getWorldRotation(parent))\n  }\n}\n\n/**\n * @public\n */\nexport enum InterpolationType {\n  LINEAR = 'linear',\n\n  EASEINQUAD = 'easeinquad',\n  EASEOUTQUAD = 'easeoutquad',\n  EASEQUAD = 'easequad',\n\n  EASEINSINE = 'easeinsine',\n  EASEOUTSINE = 'easeoutsine',\n  EASESINE = 'easeinoutsine',\n\n  EASEINEXPO = 'easeinexpo',\n  EASEOUTEXPO = 'easeoutexpo',\n  EASEEXPO = 'easeinoutexpo',\n\n  EASEINELASTIC = 'easeinelastic',\n  EASEOUTELASTIC = 'easeoutelastic',\n  EASEELASTIC = 'easeinoutelastic',\n\n  EASEINBOUNCE = 'easeinbounce',\n  EASEOUTEBOUNCE = 'easeoutbounce',\n  EASEBOUNCE = 'easeinoutbounce',\n}\n\n/**\n * @public\n */\nexport function interpolate(type: InterpolationType, t: number): number {\n  switch (type) {\n    case InterpolationType.LINEAR:\n      return InterpolateLinear(t)\n    case InterpolationType.EASEINQUAD:\n      return InterpolateEaseInQuad(t)\n    case InterpolationType.EASEOUTQUAD:\n      return InterpolateEaseOutQuad(t)\n    case InterpolationType.EASEQUAD:\n      return InterpolateEaseQuad(t)\n\t  case InterpolationType.EASEINSINE:\n\t\t  return InterpolateEaseInSine(t)\n    case InterpolationType.EASEOUTSINE:\n      return InterpolateEaseOutSine(t)\n    case InterpolationType.EASESINE:\n      return InterpolateEaseInOutSine(t)\n    case InterpolationType.EASEINEXPO:\n      return InterpolateEaseInExpo(t)\n    case InterpolationType.EASEOUTEXPO:\n      return InterpolateEaseOutExpo(t)\n    case InterpolationType.EASEEXPO:\n      return InterpolateEaseInOutExpo(t)\n    case InterpolationType.EASEINELASTIC:\n      return InterpolateEaseInElastic(t)\n    case InterpolationType.EASEOUTELASTIC:\n      return InterpolateEaseOutElastic(t)\n    case InterpolationType.EASEELASTIC:\n      return InterpolateEaseInOutElastic(t)\n    case InterpolationType.EASEINBOUNCE:\n      return InterpolateEaseInBounce(t)\n    case InterpolationType.EASEOUTEBOUNCE:\n      return InterpolateEaseOutBounce(t)\n    case InterpolationType.EASEBOUNCE:\n      return InterpolateEaseInOutBounce(t)\n    default:\n      return InterpolateLinear(t)\n  }\n}\n\nfunction InterpolateLinear(t: number): number {\n  return t\n}\n\nfunction InterpolateEaseInQuad(t: number): number {\n  return t * t\n}\n\nfunction InterpolateEaseOutQuad(t: number): number {\n  return t * (2 - t)\n}\n\nfunction InterpolateEaseQuad(t: number): number {\n  return (t * t) / (2.0 * (t * t - t) + 1.0)\n}\n\nfunction InterpolateEaseInSine(t: number): number {\n\treturn 1 - Math.cos((t * Math.PI) / 2)\n}\n\nfunction InterpolateEaseOutSine(t: number): number {\n\treturn Math.sin((t * Math.PI) / 2)\n}\n\nfunction InterpolateEaseInOutSine(t: number): number {\n\treturn -(Math.cos(Math.PI * t) - 1) / 2\n}\n\nfunction InterpolateEaseInExpo(t: number): number {\n\treturn t === 0 ? 0 : Math.pow(2, 10 * t - 10)\n}\n\nfunction InterpolateEaseOutExpo(t: number): number {\n\treturn t === 1 ? 1 : 1 - Math.pow(2, -10 * t)\n}\n\nfunction InterpolateEaseInOutExpo(t: number): number {\n\treturn t === 0\n\t\t\t? 0\n\t\t\t: t === 1\n\t\t\t? 1\n\t\t\t: t < 0.5\n\t\t\t? Math.pow(2, 20 * t - 10) / 2\n\t\t\t: (2 - Math.pow(2, -20 * t + 10)) / 2\n}\n\n\nfunction InterpolateEaseInElastic(t: number): number {\n\tconst c4 = (2 * Math.PI) / 3\n\n\treturn t === 0\n\t\t\t? 0\n\t\t\t: t === 1\n\t\t\t? 1\n\t\t\t: -Math.pow(2, 10 * t - 10) * Math.sin((t * 10 - 10.75) * c4)\n}\n\nfunction InterpolateEaseOutElastic(t: number): number {\n\tconst c5 = (2 * Math.PI) / 3\n\n\treturn t === 0\n\t\t\t? 0\n\t\t\t: t === 1\n\t\t\t? 1\n\t\t\t: Math.pow(2, -10 * t) * Math.sin((t * 10 - 0.75) * c5) + 1\n}\n\nfunction InterpolateEaseInOutElastic(t: number): number {\n\tconst c6 = (2 * Math.PI) / 4.5\n\n\treturn t === 0\n\t\t\t? 0\n\t\t\t: t === 1\n\t\t\t? 1\n\t\t\t: t < 0.5\n\t\t\t? -(Math.pow(2, 20 * t - 10) * Math.sin((20 * t - 11.125) * c6)) / 2\n\t\t\t: (Math.pow(2, -20 * t + 10) * Math.sin((20 * t - 11.125) * c6)) / 2 + 1\n}\n\nfunction InterpolateEaseInBounce(t: number): number {\n\treturn 1 - bounce(1 - t)\n}\n\nfunction InterpolateEaseOutBounce(t: number): number {\n\treturn bounce(t)\n}\n\nfunction InterpolateEaseInOutBounce(t: number): number {\n\treturn t < 0.5 ? (1 - bounce(1 - 2 * t)) / 2 : (1 + bounce(2 * t - 1)) / 2\n}\n\nfunction bounce(x: number) {\n\tconst n1 = 7.5625\n\tconst d1 = 2.75\n\n\tif (x < 1 / d1) {\n\t\treturn n1 * x * x\n\t} else if (x < 2 / d1) {\n\t\treturn n1 * (x -= 1.5 / d1) * x + 0.75\n\t} else if (x < 2.5 / d1) {\n\t\treturn n1 * (x -= 2.25 / d1) * x + 0.9375\n\t} else {\n\t\treturn n1 * (x -= 2.625 / d1) * x + 0.984375\n\t}\n}\n\nexport function createCatmullRomSpline(points: Vector3[], nbPoints: number, closed?: boolean): Vector3[] {\n\tconst catmullRom = new Array<Vector3>();\n\tconst step = 1.0 / nbPoints;\n\tlet amount = 0.0;\n\tif (closed) {\n\t\tconst pointsCount = points.length;\n\t\tfor (let i = 0; i < pointsCount; i++) {\n\t\t\tamount = 0;\n\t\t\tfor (let c = 0; c < nbPoints; c++) {\n\t\t\t\tcatmullRom.push(\n\t\t\t\t\tVector3.catmullRom(points[i % pointsCount], points[(i + 1) % pointsCount], points[(i + 2) % pointsCount], points[(i + 3) % pointsCount], amount)\n\t\t\t\t);\n\t\t\t\tamount += step;\n\t\t\t}\n\t\t}\n\t\tcatmullRom.push(catmullRom[0]);\n\t} else {\n\t\tconst totalPoints = new Array<Vector3>();\n\t\ttotalPoints.push(Vector3.clone(points[0]));\n\t\tArray.prototype.push.apply(totalPoints, points);\n\t\ttotalPoints.push(Vector3.clone(points[points.length - 1]));\n\t\tlet i = 0;\n\t\tfor (; i < totalPoints.length - 3; i++) {\n\t\t\tamount = 0;\n\t\t\tfor (let c = 0; c < nbPoints; c++) {\n\t\t\t\tcatmullRom.push(Vector3.catmullRom(totalPoints[i], totalPoints[i + 1], totalPoints[i + 2], totalPoints[i + 3], amount));\n\t\t\t\tamount += step;\n\t\t\t}\n\t\t}\n\t\ti--;\n\t\tcatmullRom.push(Vector3.catmullRom(totalPoints[i], totalPoints[i + 1], totalPoints[i + 2], totalPoints[i + 3], amount));\n\t}\n\treturn catmullRom;\n}\n\nexport function areAABBIntersecting(aMin: Vector3, aMax: Vector3, bMin: Vector3, bMax: Vector3): boolean {\n\treturn (\n\t\taMin.x <= bMax.x &&\n\t\taMax.x >= bMin.x &&\n\t\taMin.y <= bMax.y &&\n\t\taMax.y >= bMin.y &&\n\t\taMin.z <= bMax.z &&\n\t\taMax.z >= bMin.z\n\t)\n}\n\nexport function areSpheresIntersecting(aPos: Vector3, aRadius: number, bPos: Vector3, bRadius: number): boolean {\n  const sqDist = Vector3.distanceSquared(aPos, bPos)\n  const radiusSum = aRadius + bRadius\n  return sqDist < radiusSum * radiusSum\n}\n\nexport function areAABBSphereIntersecting(boxMin: Vector3, boxMax: Vector3, spherePos: Vector3, sphereRadius: number): boolean {\n  let dmin = 0\n\n  if (spherePos.x < boxMin.x)\n    dmin += (boxMin.x - spherePos.x) * (boxMin.x - spherePos.x)\n  if (spherePos.x > boxMax.x)\n    dmin += (spherePos.x - boxMax.x) * (spherePos.x - boxMax.x)\n  if (spherePos.y < boxMin.y)\n    dmin += (boxMin.y - spherePos.y) * (boxMin.y - spherePos.y)\n  if (spherePos.y > boxMax.y)\n    dmin += (spherePos.y - boxMax.y) * (spherePos.y - boxMax.y)\n  if (spherePos.z < boxMin.z)\n    dmin += (boxMin.z - spherePos.z) * (boxMin.z - spherePos.z)\n  if (spherePos.z > boxMax.z)\n    dmin += (spherePos.z - boxMax.z) * (spherePos.z - boxMax.z)\n\n  return dmin < sphereRadius * sphereRadius\n}\n"]}