Ti presentiamo PROXX

Un gioco di prossimità, ispirato a Campo Minato.

Mariko Kosaka

Il team che ha creato squoosh.app è tornato! Questa volta abbiamo creato un gioco basato sul web chiamato PROXX (proxx.app). PROXX è un gioco di prossimità ispirato al leggendario gioco Campo minato. Il gioco si svolge nello spazio e il tuo compito è scoprire dove si trovano i buchi neri. Funziona su tutti i tipi di dispositivi, dai computer ai cellulari. Gli utenti possono giocare utilizzando un mouse, una tastiera, un d-pad o anche uno screen reader.

PROXX su un telefono con funzionalità di base.

Il nostro valore basale

Prima di creare questo gioco, abbiamo impostato i seguenti scopi e budget per l'applicazione:

  • Stessa esperienza di base: tutti i dispositivi devono funzionare allo stesso modo
  • Accessibile: mouse, tastiera, tocco, pad direzionale, screen reader
  • Efficace:
    • Un payload iniziale inferiore a 25 KB
    • TTI (tempo all'interattività) inferiore a 5 secondi su rete 3G lenta
    • Animazione coerente a 60 fps
Un Pixelbook su cui è in esecuzione PROXX
PROXX su un Pixelbook.

Web worker

Il gioco è costituito da quattro entità principali: la logica di gioco di base, il servizio UI, il servizio di stato e le animazioni grafiche. Dato che sapevamo fin dall'inizio che avremmo dovuto eseguire grafica fortemente animata sul thread principale, abbiamo spostato la logica di gioco e il servizio di stato in un web worker per mantenere il thread principale il più possibile libero.

Pre-rendering in fase di compilazione

La nostra UI è realizzata con Preact, in quanto ci consente di raggiungere il nostro obiettivo aggressivo per un payload iniziale inferiore a 25 KB. Per offrire un'esperienza di caricamento iniziale positiva, abbiamo deciso di eseguire il pre-rendering della prima visualizzazione. Eseguiamo il prerendering in fase di compilazione utilizzando Puppeteer per accedere alla pagina superiore e consentire a preact di compilare il DOM. Il DOM risultante viene poi serializzato in HTML e salvato come index.html

Canvas per l'animazione, DOM (invisibile) per l'accessibilità

Eseguiamo il rendering della grafica del gioco in una tela utilizzando WebGL. Un canvas è responsabile dell'animazione di sfondo e un altro della griglia del gioco in alto. Per motivi di accessibilità, abbiamo anche una tabella HTML con pulsanti che si trova sopra entrambi i canvas, ma è resa invisibile (opacità: 0). Anche se quello che vedi è un rendering in canvas dello stato del gioco, il giocatore interagisce con la tabella DOM invisibile, il che ci consente di collegare gli ascoltatori di eventi e fare affidamento sulla gestione dell'attenzione del browser.

Mantenendo l'elemento DOM nella tela, possiamo sfruttare le funzionalità di accessibilità integrate dei browser. Ad esempio, impostando role="grid" nella nostra tabella di gioco, gli screen reader possono annunciare la riga e la colonna della cella attiva senza che sia necessario implementare questa funzionalità.

Rollup per il bundling e la suddivisione del codice

Le dimensioni totali dell'app si riducono a 100 KB compressi. Di questi, 20 KB sono per il payload iniziale (index.html). Per questo progetto utilizziamo Rollup.js. Abbiamo dipendenze condivise tra il thread principale e il nostro worker web e Rollup può inserire queste dipendenze condivise in un chunk separato che deve essere caricato solo una volta. Altri bundler come webpack duplicano le dipendenze condivise, il che comporta un doppio caricamento.

Supporto di feature phone

Gli smartphone con funzionalità avanzate, come i telefoni KaiOS, stanno guadagnando rapidamente popolarità. Si tratta di dispositivi con risorse molto limitate, ma il nostro approccio di utilizzo di web worker, quando possibile, ci ha permesso di rendere l'esperienza molto reattiva anche su questi telefoni. Poiché i feature phone sono dotati di un'interfaccia di input diversa (pad direzionale e tasti numerici, senza touchscreen), abbiamo anche implementato un'interfaccia basata sui tasti.

Un uomo che gioca a PROXX su un cellulare giallo
PROXX su un telefono con funzionalità di base.

Passaggi successivi

Abbiamo trascorso un periodo impegnativo, ma fantastico, a creare questo gioco in tempo per Google I/O 2019, quindi ci prenderemo un po' di meritato riposo, ma torneremo con una documentazione più approfondita su ciascuna di queste aree del gioco.

Nel frattempo, dai un'occhiata al talk di Mariko su questo progetto tenuto alla conferenza I/O.

Puoi sfogliare il codice nel repository GitHub di proxx.

Un saluto! Surma, Jake, Mariko