UNPKG

@dcl-sdk/utils

Version:

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

75 lines 10.7 kB
import { engine, Transform, AudioSource } from '@dcl/sdk/ecs'; import { Vector3 } from '@dcl/sdk/math'; import { InterpolationType } from './math'; export function getEntitiesWithParent(parent) { const entitiesWithParent = []; for (const [entity, transform] of engine.getEntitiesWith(Transform)) { if (transform.parent === parent) { entitiesWithParent.push(entity); } } return entitiesWithParent; } export function getEntityParent(child) { const transform = Transform.getOrNull(child); if (transform) { return transform.parent; } else { return engine.RootEntity; } } export function getPlayerPosition() { return Transform.getOrNull(engine.PlayerEntity)?.position || Vector3.create(); } export function playSound(file, loop = false, position) { const entity = engine.addEntity(); AudioSource.create(entity, { audioClipUrl: file, loop, playing: true }); Transform.create(entity, { position: position ? position : getPlayerPosition() }); return entity; } export function getEasingFunctionFromInterpolation(type) { switch (type) { case InterpolationType.LINEAR: return 0; case InterpolationType.EASEINQUAD: return 1; case InterpolationType.EASEOUTQUAD: return 2; case InterpolationType.EASEQUAD: return 3; case InterpolationType.EASEINSINE: return 4; case InterpolationType.EASEOUTSINE: return 5; case InterpolationType.EASESINE: return 6; case InterpolationType.EASEINEXPO: return 7; case InterpolationType.EASEOUTEXPO: return 8; case InterpolationType.EASEEXPO: return 9; case InterpolationType.EASEINELASTIC: return 10; case InterpolationType.EASEOUTELASTIC: return 11; case InterpolationType.EASEELASTIC: return 12; case InterpolationType.EASEINBOUNCE: return 13; case InterpolationType.EASEOUTEBOUNCE: return 14; case InterpolationType.EASEBOUNCE: return 15; default: return 0; } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"helpers.js","sourceRoot":"","sources":["../src/helpers.ts"],"names":[],"mappings":"AAAA,OAAO,EAAU,MAAM,EAAE,SAAS,EAAE,WAAW,EAAkB,MAAM,cAAc,CAAA;AACrF,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAA;AACvC,OAAO,EAAE,iBAAiB,EAAE,MAAM,QAAQ,CAAC;AAS3C,MAAM,UAAU,qBAAqB,CACpC,MAAc;IAEd,MAAM,kBAAkB,GAAa,EAAE,CAAC;IAExC,KAAK,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,IAAI,MAAM,CAAC,eAAe,CAAC,SAAS,CAAC,EAAE,CAAC;QACrE,IAAI,SAAS,CAAC,MAAM,KAAK,MAAM,EAAE,CAAC;YACjC,kBAAkB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACjC,CAAC;IACF,CAAC;IAED,OAAO,kBAAkB,CAAC;AAC3B,CAAC;AAWD,MAAM,UAAU,eAAe,CAC9B,KAAa;IAEb,MAAM,SAAS,GAAG,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC7C,IAAI,SAAS,EAAE,CAAC;QACf,OAAO,SAAS,CAAC,MAAgB,CAAC;IACnC,CAAC;SAAM,CAAC;QACP,OAAO,MAAM,CAAC,UAAoB,CAAC;IACpC,CAAC;AACF,CAAC;AASD,MAAM,UAAU,iBAAiB;IAChC,OAAO,SAAS,CAAC,SAAS,CAAC,MAAM,CAAC,YAAY,CAAC,EAAE,QAAQ,IAAI,OAAO,CAAC,MAAM,EAAE,CAAA;AAC9E,CAAC;AAaD,MAAM,UAAU,SAAS,CACxB,IAAY,EACZ,OAAgB,KAAK,EACrB,QAAkB;IAElB,MAAM,MAAM,GAAG,MAAM,CAAC,SAAS,EAAE,CAAA;IACjC,WAAW,CAAC,MAAM,CAAC,MAAM,EAAE;QAC1B,YAAY,EAAE,IAAI;QAClB,IAAI;QACJ,OAAO,EAAE,IAAI;KACb,CAAC,CAAA;IAEF,SAAS,CAAC,MAAM,CAAC,MAAM,EAAE;QACxB,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,iBAAiB,EAAE;KACnD,CAAC,CAAA;IAEF,OAAO,MAAM,CAAA;AACd,CAAC;AASD,MAAM,UAAU,kCAAkC,CAAC,IAAuB;IACzE,QAAQ,IAAI,EAAE,CAAC;QACd,KAAK,iBAAiB,CAAC,MAAM;YAC5B,SAA+B;QAChC,KAAK,iBAAiB,CAAC,UAAU;YAChC,SAAmC;QACpC,KAAK,iBAAiB,CAAC,WAAW;YACjC,SAAoC;QACrC,KAAK,iBAAiB,CAAC,QAAQ;YAC9B,SAAiC;QAClC,KAAK,iBAAiB,CAAC,UAAU;YAChC,SAAmC;QACpC,KAAK,iBAAiB,CAAC,WAAW;YACjC,SAAoC;QACrC,KAAK,iBAAiB,CAAC,QAAQ;YAC9B,SAAiC;QAClC,KAAK,iBAAiB,CAAC,UAAU;YAChC,SAAmC;QACpC,KAAK,iBAAiB,CAAC,WAAW;YACjC,SAAoC;QACrC,KAAK,iBAAiB,CAAC,QAAQ;YAC9B,SAAiC;QAClC,KAAK,iBAAiB,CAAC,aAAa;YACnC,UAAsC;QACvC,KAAK,iBAAiB,CAAC,cAAc;YACpC,UAAuC;QACxC,KAAK,iBAAiB,CAAC,WAAW;YACjC,UAAoC;QACrC,KAAK,iBAAiB,CAAC,YAAY;YAClC,UAAqC;QACtC,KAAK,iBAAiB,CAAC,cAAc;YACpC,UAAsC;QACvC,KAAK,iBAAiB,CAAC,UAAU;YAChC,UAAmC;QACpC;YACC,SAA+B;IACjC,CAAC;AACF,CAAC","sourcesContent":["import { Entity, engine, Transform, AudioSource, EasingFunction } from '@dcl/sdk/ecs'\nimport { Vector3 } from '@dcl/sdk/math'\nimport { InterpolationType } from './math';\n\n/**\n * Returns an array of entities that all share the provided entity as parent.\n *\n * @param parent - Parent of the entities you want to fetch.\n * @returns An array of entities that are children of the provided entity. If the entity has no children, it returns an empty array.\n * @public\n */\nexport function getEntitiesWithParent(\n\tparent: Entity\n): Entity[] {\n\tconst entitiesWithParent: Entity[] = [];\n\n\tfor (const [entity, transform] of engine.getEntitiesWith(Transform)) {\n\t\tif (transform.parent === parent) {\n\t\t\tentitiesWithParent.push(entity);\n\t\t}\n\t}\n\n\treturn entitiesWithParent;\n}\n\n\n/**\n * Returns an entity that is the parent of the provided entity.\n *\n * @param child - Child of the entity you want to fetch.\n * @returns The parent entity. If no parent is found it defaults to the root entity of the scene.\n * @public\n */\n\nexport function getEntityParent(\n\tchild: Entity\n): Entity {\n\tconst transform = Transform.getOrNull(child);\n\tif (transform) {\n\t\treturn transform.parent as Entity;\n\t} else {\n\t\treturn engine.RootEntity as Entity;\n\t}\n}\n\n\n/**\n * Returns the position of the player's avatar.\n *\n * @returns A Vector3 with the current position of the player's avatar, relative to the scene's origin. If no data can be retrieved, it returns (0,0,0).\n * @public\n */\nexport function getPlayerPosition(): Vector3 {\n\treturn Transform.getOrNull(engine.PlayerEntity)?.position || Vector3.create()\n}\n\n\n\n/**\n * Plays a sound from an audio file, at a given location in the scene.\n *\n * @param file - Path to an audio file stored in the scene's folder, as a string.\n * @param loop - Boolean to specify if the sound should be played once or looped. False by default.\n * @param position - Vector3 with the position relative to the scene's origin. If not provided, the sound plays at the camera's location.\n * @returns An array of [entity, transform] for each entity that is a child of the provided entity. If the entity has no children, it returns null.\n * @public\n */\nexport function playSound(\n\tfile: string,\n\tloop: boolean = false,\n\tposition?: Vector3\n) {\n\tconst entity = engine.addEntity()\n\tAudioSource.create(entity, {\n\t\taudioClipUrl: file,\n\t\tloop,\n\t\tplaying: true\n\t})\n\n\tTransform.create(entity, {\n\t\tposition: position ? position : getPlayerPosition()\n\t})\n\n\treturn entity\n}\n\n/**\n * Maps an EasingFunction to the provided InterpolationType\n *\n * @param type - an InterpolationType enum type\n * @returns An EasingFunction enum type\n * @public\n */\nexport function getEasingFunctionFromInterpolation(type: InterpolationType): EasingFunction {\n\tswitch (type) {\n\t\tcase InterpolationType.LINEAR:\n\t\t\treturn EasingFunction.EF_LINEAR\n\t\tcase InterpolationType.EASEINQUAD:\n\t\t\treturn EasingFunction.EF_EASEINQUAD\n\t\tcase InterpolationType.EASEOUTQUAD:\n\t\t\treturn EasingFunction.EF_EASEOUTQUAD\n\t\tcase InterpolationType.EASEQUAD:\n\t\t\treturn EasingFunction.EF_EASEQUAD\n\t\tcase InterpolationType.EASEINSINE:\n\t\t\treturn EasingFunction.EF_EASEINSINE\n\t\tcase InterpolationType.EASEOUTSINE:\n\t\t\treturn EasingFunction.EF_EASEOUTSINE\n\t\tcase InterpolationType.EASESINE:\n\t\t\treturn EasingFunction.EF_EASESINE\n\t\tcase InterpolationType.EASEINEXPO:\n\t\t\treturn EasingFunction.EF_EASEINEXPO\n\t\tcase InterpolationType.EASEOUTEXPO:\n\t\t\treturn EasingFunction.EF_EASEOUTEXPO\n\t\tcase InterpolationType.EASEEXPO:\n\t\t\treturn EasingFunction.EF_EASEEXPO\n\t\tcase InterpolationType.EASEINELASTIC:\n\t\t\treturn EasingFunction.EF_EASEINELASTIC\n\t\tcase InterpolationType.EASEOUTELASTIC:\n\t\t\treturn EasingFunction.EF_EASEOUTELASTIC\n\t\tcase InterpolationType.EASEELASTIC:\n\t\t\treturn EasingFunction.EF_EASEELASTIC\n\t\tcase InterpolationType.EASEINBOUNCE:\n\t\t\treturn EasingFunction.EF_EASEINBOUNCE\n\t\tcase InterpolationType.EASEOUTEBOUNCE:\n\t\t\treturn EasingFunction.EF_EASEOUTBOUNCE\n\t\tcase InterpolationType.EASEBOUNCE:\n\t\t\treturn EasingFunction.EF_EASEBOUNCE\n\t\tdefault:\n\t\t\treturn EasingFunction.EF_LINEAR\n\t}\n}\n"]}