[SOLVED] Canvas remains empty despite drawing operations
Posted: Mon Mar 06, 2017 1:56 pm
Hello,
I've stomped on a strange behavior where a canvas retained the last drawing operation only (as if it got cleared at every love.draw() run).
Trying to reproduce the issue on a reduced program, I've stomped on a different (but perhaps connected) weird behavior where the same operations get performed on two canvases, the first canvas retains all data and works fine while the second remains completely blank.
Here is the code:
And here is what I get to see running the above code:
That is, canvas1 gets drawn, canvas2 appears as just a black square.
Any advice about how to troubleshoot the issue?
Thanks for your attention, cheers!
[Solution: since love.graphics.clear() gets called between love.update() and love.draw(), the currently active drawing target (in my case handler.canvas2) gets blanked out; the solution is to reset the drawing target with love.graphics.setCanvas() before getting into love.draw() or to refactor the code to use a different approach, see messages below for the details]
I've stomped on a strange behavior where a canvas retained the last drawing operation only (as if it got cleared at every love.draw() run).
Trying to reproduce the issue on a reduced program, I've stomped on a different (but perhaps connected) weird behavior where the same operations get performed on two canvases, the first canvas retains all data and works fine while the second remains completely blank.
Here is the code:
Code: Select all
local handler = {}
function handler.load()
handler.canvas1 = love.graphics.newCanvas(100, 100)
handler.canvas2 = love.graphics.newCanvas(100, 100)
love.graphics.setCanvas(handler.canvas1)
love.graphics.clear(255, 0, 0)
love.graphics.print("this is canvas 1")
love.graphics.setCanvas(handler.canvas2)
love.graphics.clear(0, 255, 0)
love.graphics.print("this is canvas 2")
end
function handler.update()
handler.randomLine(handler.canvas1)
handler.randomLine(handler.canvas2)
end
function handler.randomLine(canvas)
love.graphics.setBlendMode("alpha")
love.graphics.setCanvas(canvas)
local l = {
x1 = math.random(20, 80),
y1 = math.random(20, 80),
x2 = math.random(20, 80),
y2 = math.random(20, 80),
r = math.random(192, 255),
g = math.random(192, 255),
b = math.random(192, 255),
}
love.graphics.setColor(l.r, l.g, l.b)
love.graphics.line(l.x1, l.y1, l.x2, l.y2)
end
function handler.flipCanvas(canvas, x, y)
love.graphics.setBlendMode("alpha", "premultiplied")
love.graphics.setColor(255, 255, 255)
love.graphics.draw(canvas, x, y)
end
function handler.draw()
love.graphics.setCanvas()
love.graphics.setBlendMode("alpha")
love.graphics.clear(0, 0, 255)
handler.flipCanvas(handler.canvas1, 10, 10)
handler.flipCanvas(handler.canvas2, 120, 120)
end
local game = {}
function love.load()
game.handler = handler
game.handler.load()
end
function love.update(dt)
game.handler.update(dt)
end
function love.draw()
game.handler.draw()
end
That is, canvas1 gets drawn, canvas2 appears as just a black square.
Any advice about how to troubleshoot the issue?
Thanks for your attention, cheers!
[Solution: since love.graphics.clear() gets called between love.update() and love.draw(), the currently active drawing target (in my case handler.canvas2) gets blanked out; the solution is to reset the drawing target with love.graphics.setCanvas() before getting into love.draw() or to refactor the code to use a different approach, see messages below for the details]