Estoy creando un nuevo motor de juego para la web con el nombre de Engine1. Actualmente he producido un par de prototipos. Hasta ahora he podido:¿Debo usar un fragmento DOM como dom Shadow en mi motor de juegos Javascript?
- Mapa de los píxeles transparentes de los sprites utilizando el lienzo.
- Enlace de eventos a los píxeles opacos de los sprites.
- Desarrolla un tiempo de ejecución del juego con un conjunto de fps.
- Animate sprites con temporización de cuadro variable.
- movimiento elemento Animate, tanto del marco
- por la fama
- y con interpolación de movimiento basado en cuadros
estoy feliz con mi progreso, pero me parece que ser incómodo con el avance más lejos sin consultar a un experto en rendimiento DOM.
Actualmente, cuando se crea un elemento, se agrega a un fragmento DOM que llamo el "DOM sombreado". Cada cuadro de este HTML de "DOM sombra" se copia e inserta en el cuerpo de la página (o el puerto de vista actual).
Lo he configurado de esta manera porque puedo agregar todo a la página en un nuevo flujo del navegador.
Mi preocupación es que el rendimiento obtenido se verá compensado por la necesidad de volver a fluir el contenido del navegador, incluso si solo se cambian partes de la página.
Además, el enlace de eventos se vuelve mucho más complicado.
¿Alguna idea?
¿Debo usar un "DOM sombra"?
¿Hay una mejor manera de representar una gran cantidad de elementos?
¿Hay alguna forma de copiar solo las diferencias del "DOM sombreado" al cuerpo del navegador?
Esta técnica de DOM de Shadow me recuerda el doble almacenamiento en búfer. ¿Es asi? – Spidey
Sí, creo que doble buffering es el término correcto. –
Quizás deberías saber que desde que se hizo la pregunta, el término DOM Shadow se ha convertido en algo real: https://dvcs.w3.org/hg/webcomponents/raw-file/tip/spec/shadow/index.html. Los lectores futuros pueden desear que se les avise que esta pregunta no está relacionada con esta especificación. –