Datos en tiempo de ejecución
Obtén datos del contexto donde se ejecuta tu escena y de la escena en sí.
Obtener Decentraland Time
Decentraland sigue un ciclo día/noche que tarda 2 horas en completarse, por lo que hay 12 ciclos completos cada día. Los jugadores también pueden cambiar la configuración para experimentar una hora específica fija del día, por ejemplo para ver siempre Decentraland con un cielo nocturno de las 10pm. Por esta razón, la hora en Decentraland puede variar de un jugador a otro.
Usa getWorldTime() para obtener la hora del día que el jugador está experimentando dentro de Decentraland.
import { getWorldTime } from '~system/Runtime'
executeTask(async () => {
let time = await getWorldTime({})
console.log(time.seconds)
})💡 Tip: El getWorldTime() la función es asíncrona. Ver Funciones asíncronas si no estás familiarizado con ellas.
getWorldTime() devuelve un objeto con una seconds propiedad. Esta propiedad indica cuántos segundos han pasado (en tiempo de Decentraland) desde el inicio del día, asumiendo que el ciclo completo dura 24 horas. Divide el valor seconds por 60 para obtener minutos, y por 60 nuevamente para obtener las horas desde el inicio del día. Por ejemplo, si el seconds valor es 36000, corresponde a 10 AM.
En la hora de Decentraland, el sol siempre sale a las 6:15 y se pone a las 19:50.
Podrías usar esta información para cambiar la escena en consecuencia, por ejemplo para reproducir sonidos de aves cuando hay luz del día y grillos cuando está oscuro, o para encender los materiales emisivos de las farolas cuando está oscuro.
import { getWorldTime } from '~system/Runtime'
executeTask(async () => {
let time = await getWorldTime({})
console.log(time.seconds)
if (time.seconds < 6.25 * 60 * 60 || time.seconds > 19.85 * 60 * 60) {
// noche
console.log('reproduciendo sonidos de grillos')
} else {
// día
console.log('reproduciendo sonidos de aves')
}
})Obtener datos del realm
Los jugadores en Decentraland existen en varios realms. Los jugadores en diferentes realms no pueden verse entre sí, interactuar ni chatear entre ellos, incluso si están parados en los mismos parcels. Dividir a los jugadores de esta manera permite a Decentraland manejar una cantidad ilimitada de jugadores sin encontrarse con limitaciones. También agrupa a los jugadores que están en regiones cercanas, para asegurar que los tiempos de ping entre jugadores que interactúan sean aceptables.
Si tu escena envía datos a un servidor de terceros para sincronizar cambios entre jugadores en tiempo real, entonces a menudo es importante que los cambios solo se sincronicen entre jugadores que estén en el mismo realm. Debes manejar todos los cambios que pertenecen a un realm como separados de los de otro realm diferente. De lo contrario, los jugadores verán cosas cambiar de manera extraña, sin que nadie haga el cambio.
💡 Tip: El getRealm() la función es asíncrona. Ver Funciones asíncronas si no estás familiarizado con ellas.
Decentraland maneja sus comunicaciones entre jugadores (incluyendo posiciones de jugadores, chat, mensajes de messageBus y cambios de estado de smart items) a través de una red descentralizada de servidores de comunicación, cada uno de estos servidores se llama Realm. Cada uno de estos servidores puede soportar múltiples rooms (también llamadas islands), cada una agrupando un conjunto diferente de jugadores que están cerca unos de otros en el mapa de Decentraland.
El getRealm() la función devuelve la siguiente información:
baseUrl: (string) El dominio del servidor del realmrealmName: (string) El nombre del servidor del realmnetworkId: (number) La red de EthereumcommsAdapter: (string) Adaptador de comms, eliminando todos los parámetros de consulta (credenciales)isPreview: (boolean) Verdadero si la escena se está ejecutando como una vista previa local, en lugar de estar publicada en Decentraland.isConnectedSceneRoom: (boolean) Verdadero si el usuario está conectado a la scene room.
📔 Nota: El layer la propiedad está obsoleta y debe evitarse.
A medida que los jugadores se mueven por el mapa, pueden cambiar de rooms para agruparse con aquellos jugadores que ahora están más cerca de ellos. Las rooms también desplazan sus fronteras dinámicamente para ajustarse a un grupo manejable de personas, así que incluso si un jugador permanece quieto, a medida que otros entran y salen del mundo, el jugador podría encontrarse en otra room. Los jugadores en un mismo room se comunican, y compartirán mensajes a través del MessageBus incluso si están demasiado lejos para verse. Los jugadores en un mismo servidor pero en diferentes rooms actualmente no se comunican, pero podrían llegar a comunicarse a medida que se mueven por el mapa y cambian de rooms.
Ver onRealmChangedObservable para saber cómo detectar cambios respecto al realm o isla del jugador.
📔 Nota: Cuando la escena se carga por primera vez, puede que aún no se haya asignado una room para el jugador. El Explorer eventualmente asignará una room al jugador, pero esto a veces puede ocurrir un par de segundos después de que la escena se haya cargado.
Obtener la plataforma del jugador
Los jugadores pueden acceder a Decentraland a través de varias plataformas, incluyendo la aplicación oficial de escritorio, y versiones web y de escritorio obsoletas, así como clientes experimentales alternativos construidos para otros motores.
Usa getExplorerInformation() para saber en qué plataforma está ejecutando Decentraland el jugador actual.
Al usar la aplicación oficial de escritorio de Decentraland, esta función debería devolver los siguientes datos:
Los jugadores que usan la aplicación oficial de escritorio de Decentraland probablemente tendrán una experiencia mucho más fluida que los que usan el navegador, ya que el navegador impone limitaciones de rendimiento sobre cuánto poder de procesamiento de la máquina puede usar la pestaña del navegador. Además, les faltarán muchas características como control de cámara, luces dinámicas, congelar el movimiento del jugador, mejoras de UI, etc.
El componente EngineInfo
El EngineInfoel componente rastrea datos sobre el ciclo de vida de la escena, lo cual a veces puede ser útil para saber cuándo ocurre un evento en relación con la inicialización de la escena.
Este componente se añade a la engine.RootEntity.
El EngineInfoel componente contiene los siguientes datos:
frame_number: Contador de frames del enginetotal_runtime: Tiempo total de ejecución de esta escena en segundostick_number: Contador de ticks de la escena según ADR-148
📔 Nota: El EngineInfo component must be imported via
import { Vector3, Quaternion } from "@dcl/sdk/ecs"
Ver Imports para ver cómo manejarlos fácilmente.
Última actualización