Skip to content

Commit

Permalink
Merge pull request #132 from mind-ar/fix-frontend-background-image
Browse files Browse the repository at this point in the history
Corrección de falla al intentar cargar imagen de fondo
  • Loading branch information
PalumboN authored Mar 20, 2024
2 parents cbdfda2 + d4e215a commit 782a4fe
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 10 deletions.
6 changes: 4 additions & 2 deletions public/game/sketch.js
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ function setup() {
})
loadBackground()
loadVisuals()
socket.emit("ready")
}

function draw() {
Expand Down Expand Up @@ -59,9 +60,10 @@ function checkError() {

function loadBackground() {
socket.on("background", (fondo) => {
const imagen = images.find((img) => img.name == fondo)
backgroundImage =
fondo != "default"
? images.find((img) => img.name == fondo).url
fondo != "default" && imagen != null
? imagen.url
: defaultBackground
})
}
Expand Down
21 changes: 13 additions & 8 deletions src/commands/run.ts
Original file line number Diff line number Diff line change
Expand Up @@ -86,10 +86,8 @@ export const getGameInterpreter = (environment: Environment, io: Server): Interp
drawer: {
*apply() {
try {
const game = interpreter?.object(GAME_MODULE)
const background = game.get('boardGround') ? game.get('boardGround')?.innerString : 'default'
const game = interpreter?.object('wollok.game.game')
const visuals = getVisuals(game, interpreter)
io.emit('background', background)
io.emit('visuals', visuals)

const gameSounds = game.get('sounds')?.innerCollection ?? []
Expand Down Expand Up @@ -185,7 +183,6 @@ export async function initializeDynamicDiagram(programPackage: Package, options:
}
}


export const eventsFor = (io: Server, interpreter: Interpreter, dynamicDiagramClient: DynamicDiagramClient, { game, project, assets }: Options): void => {
if (!game) return
const sizeCanvas = canvasResolution(interpreter)
Expand All @@ -195,14 +192,22 @@ export const eventsFor = (io: Server, interpreter: Interpreter, dynamicDiagramCl
queueEvent(interpreter, buildKeyPressEvent(interpreter, wKeyCode(key.key, key.keyCode)), buildKeyPressEvent(interpreter, 'ANY'))
})

const gameSingleton = interpreter?.object('wollok.game.game')
const background = gameSingleton.get('boardGround') ? gameSingleton.get('boardGround')?.innerString : 'default'

if (!assets) logger.warn(failureDescription('Folder for assets not found!'))
socket.emit('images', getImages(project, assets))
socket.emit('sizeCanvasInic', [sizeCanvas.width, sizeCanvas.height])

// send assets only when frontend is ready
socket.on("ready", () => {

Check warning on line 201 in src/commands/run.ts

View workflow job for this annotation

GitHub Actions / test

Strings must use singlequote
logger.info(successDescription('Ready!'))
socket.emit('images', getImages(project, assets))
socket.emit('sizeCanvasInic', [sizeCanvas.width, sizeCanvas.height])
socket.emit('cellPixelSize', gameSingleton.get('cellSize')!.innerNumber!)
socket.emit('background', background)
})

const flushInterval = 100
const id = setInterval(() => {
const gameSingleton = interpreter?.object('wollok.game.game')
socket.emit('cellPixelSize', gameSingleton.get('cellSize')!.innerNumber!)
try {
interpreter.send('flushEvents', gameSingleton, interpreter.reify(timer))
timer += flushInterval
Expand Down

0 comments on commit 782a4fe

Please sign in to comment.