Sprig es un pequeño kit de construcción para crear juegos basados en baldosas (tiles). Fue creado por Hack Club, una comunidad global de programadores adolescentes quienes creen que las personas aprenden mejor haciendo cosas que les importan y compartiéndolas con otros.
Si esta es tu primera vez usando Sprig intenta jugar a través del juego de inicio. Después de eso echa un vistazo a la galería. También puedes comenzar con un archivo en blanco y seguir este tutorial.
Si te quedas atorado, puedes hablar con otras personas de la comunidad acerca de Sprig en el Slack de Hack Club.
Ejecuta los juegos presionando el botón Run
o presionando shift+enter
.
Los juegos de Sprig se componen de cuadrículas de tiles cuadradas.
Dile a Sprig qué tipos de sprites están disponibles en tu juego. Las claves de mapa de bits (bitMap keys) deben de ser un solo carácter. Recomendamos almacenar las claves de caracteres en variables.
const player = "p"
const wall = "w"
setLegend(
[ player, bitmap`...` ],
[ wall, bitmap`...` ],
)
Para crear un nuevo bitmap, escribe
bitmap`.`
¡Esas son comillas invertidas (backticks)! Haz clic en el botón del "bitmap" resaltado para editar tu dibujo.
El orden de los tipos de sprites en tu leyenda también determinan el orden z (z-order) de dibujarlos. Los tipos de sprites que aparecen primero se dibujan en la parte superior.
Coloca un bitmap como el fondo del juego:
setBackground(spriteKey)
Esto solo cambia las imágenes del juego.
Diseñar un nivel es como dibujar un bitmap:
map`...`
Los caracteres del mapa proceden del orden de la leyenda del mapa de bits. No es necesario realizar un seguimiento de los niveles en una leyenda, deberías almacenarlos tu mismo en una variable.
Puedes llamar a setMap
para borrar el juego y cargar un nuevo nivel:
const level = map`...`
setMap(level)
Es posible que desees realizar un seguimiento de varios niveles utilizando un array para cambiar entre ellos a mitad del juego:
const levels = [
map`...`,
map`...`,
// etc.
]
setMap(levels[0])
// Later:
setMap(levels[1])
Los sprites sólidos no pueden superponerse entre sí. Esto es útil para crear cosas como paredes:
const player = "p"
const wall = "w"
setSolids([ player, wall ])
Usa setPushables
para hacer que los sprites empujen a otros sprites. El sprite de la izquierda podrá empujar todos los sprites enumerados a la derecha.
const player = "p"
const block = "b"
setPushables({
[player]: [ block, player ]
})
¡Cuidado! Asegúrate de que todo lo que pase a setPushables
también esté marcado como un sólido o no se desplazará.
Gamelab tiene ocho entradas w
, a
, s
, d
, i
, j
, k
, l
.
Típicamente w
, a
, s
, d
se utilizan como controles direccionales.
Hacer algo cuando el jugador presiona un control:
onInput("a", () => {
// Mueve al jugador un tile a la derecha.
getFirst(player).x += 1
})
Se ejecuta después de que cada evento de entrada haya terminado de manejarse. Útil para tareas como verificar los estados de victoria:
afterInput(() => {
if (getAll(block).length > 0) {
console.log("you win")
}
})
Cada tile puede contener cualquier número de sprites apilados uno encima del otro.
Los sprites contienen:
{
type
x
y
dx
dy
}
Puedes mover el sprite configurando x
e y
.
El bitmapKey
también se puede cambiar para actualizar los gráficos renderizados y las reglas de colisión que seguirá el sprite.
sprite.y += 1
sprite.type = "p"
dx
y dy
se borran después de afterInput
.
Se pueden usar para verificar si el sprite se movió y qué tanto.
Puedes eliminar un sprite con sprite.remove()
.
Devuelve una lista de los sprites en el tile especificado.
Devuelve una lista de tiles con todos los tipos contenidos en ella.
tilesWith(block)
tilesWith
acepta múltiples tipos de sprites.
tilesWith(block, player, ...)
Crea un nuevo sprite del tipo dado.
Elimina todos los sprites del tile especificado.
Devuelve todos los sprites del tipo dado. Si no se especifica ninguna clave de mapa de bits, devuelve todos los sprites del juego.
Devuelve el primer sprite de un tipo dado. Útil si sabes que solo hay uno por sprite, como con un personaje de jugador.
Atajo para getAll(type)[0]
.
Puedes agregar texto con x
, y
y color
opcionales.
Por ejemplo:
addText("hello", {
x: 10,
y: 4,
color: color`3`
})
Borra todo el texto de la pantalla.
¡Sprig viene con un motor de sonido y un secuenciador integrados! Puede usar esto para escribir música de fondo o con un alto BPM para hacer efectos de sonido.
Puedes crear una melodía con la palabra clave tune
.
Como de costumbre, haz clic en el botón para abrir una ventana de edición.
// Crear una melodía:
const melody = tune`...`
// Reproducirla:
playTune(melody)
// Reproducirla 5 veces:
playTune(melody, 5)
// Reproducirla hasta la muerte térmica del universo:
const playback = playTune(melody, Infinity)
// O haz que se calle rápidamente:
playback.end()
Abra la consola de tu navegador para depurar.
Puedes ver el estado del juego por...