Just to add, in Espruino, 'normal' arrays are quite slow to index, but Uint8Array/etc are pretty fast. It's not such an issue for small arrays though. Have you seen the performance page?
One thing that can really help is to use forEach, so you can change:
But as @allObjects suggests, I think drawing only the bits that have changed each frame would be a great help. You could actually have two instances of Graphics. One that contains the current set of squares, and another that is what you're drawing (containing the current squares and the shape that's dropping).
So then instead of m.clear() you can do m.buffer.set(currentSquares.buffer) to copy the current squares into your 'display' buffer.
Just an idea that might tidy up your code, but what about changing drawPixels to take the offset as an argument, so that instead of:
switch(block.type) {
case 'L':
switch(block.rot) {
case 1:
this.drawPixels([[block.x, block.y],
[block.x-1, block.y],
[block.x-1, block.y+1],
[block.x+1, block.y]]);
break;
...
You do:
switch(block.type) {
case 'L':
switch(block.rot) {
case 1:
this.drawPixels(block.x, block.y, [[0,0],[-1, 0], [-1,1], [1,0]]);
break;
In fact you can tidy it up even more by putting all the blocks into a global array:
Espruino is a JavaScript interpreter for low-power Microcontrollers. This site is both a support community for Espruino and a place to share what you are working on.
Just to add, in Espruino, 'normal' arrays are quite slow to index, but Uint8Array/etc are pretty fast. It's not such an issue for small arrays though. Have you seen the performance page?
One thing that can really help is to use
forEach
, so you can change:to
But as @allObjects suggests, I think drawing only the bits that have changed each frame would be a great help. You could actually have two instances of
Graphics
. One that contains the current set of squares, and another that is what you're drawing (containing the current squares and the shape that's dropping).So then instead of
m.clear()
you can dom.buffer.set(currentSquares.buffer)
to copy the current squares into your 'display' buffer.Just an idea that might tidy up your code, but what about changing
drawPixels
to take the offset as an argument, so that instead of:You do:
In fact you can tidy it up even more by putting all the blocks into a global array:
That should be a load faster, and it'll use a lot less memory too.