Bangle.js 2 Screen resolution in Flappy Bird

Posted on
  • I tried to adjust https://banglejs.com/apps/?id=flappy so that it shows full screen on Bangle.js 2.
    My code currently is:

    if (process.env.HWVERSION==2) {
      b = Graphics.createArrayBuffer(178,178,8);
      var gimg = {
          width:178,
          height:178,
          bpp:8,
          buffer:b.buffer
        };
      b.flip = function() {
        g.drawImage(gimg,0,0);
      };
    } else {
      b = Graphics.createArrayBuffer(120,120,8);
      var gimg = {
          width:120,
          height:104,
          bpp:8,
          buffer:b.buffer
        };
      b.flip = function() {
        g.drawImage(gimg,0,24,{scale:2});
      };
    }
    
    var BIRDIMG = E.toArrayBuffer(atob("EQyI/v7+/v7+/gAAAAAAAP7+/v7+/v7+/gYG0tLS0gDXAP7+/v7+/v4A0tLS0tIA19fXAP7+/v4AAAAA0tLS0gDX1wDXAP7+ANfX19cA0tLSANfXANcA/v4A19fX19cA0tLSANfX1wD+/gDS19fX0gDS0tLSAAAAAAD+/gDS0tIA0tLS0gDAwMDAwAD+/gAAAM3Nzc0AwAAAAAAA/v7+/v4Azc3Nzc0AwMDAwAD+/v7+/v4AAM3Nzc0AAAAAAP7+/v7+/v7+AAAAAP7+/v7+/g=="))
    var FLOORIMG = require("heatshrink").decompress(atob("iEKxH+kklABuLAAlgAAwNFB34OLmAAO0YAO5wAOA"));
    
    
    var birdy, birdvy;
    var floorpos = 0;
    var running = false;
    var barriers;
    var score;
    
    function newBarrier(x) {
      barriers.push({
        x1 : x-7,
        x2 : x+7,
        y : 20+Math.random()*38,
        gap : 12+Math.random()*15
      });
    }
    
    function gameStart() {
      running = true;
      birdy = 48/2;
      birdvy = 0;
      barriers = [];
      for (var i=38;i<g.getWidth();i+=38)
        newBarrier(i);
      score = 0;
    }
    
    function gameStop() {
      running = false;
    }
    
    function draw() {
      "ram"
      var H = b.getHeight()-24;
      b.setColor("#71c6cf");
      b.fillRect(0,0,b.getWidth(),H-1);
      floorpos++;
      for (var x=-(floorpos&15);x<b.getWidth();x+=16)
        b.drawImage(FLOORIMG,x,H);
    
    
      if (!running) {
        var x = b.getWidth()/2;
        b.setColor("#000000");
        b.setFontAlign(0,0);
        b.setFont("4x6",2);
        b.drawString("GAME OVER!",x,20);
        b.setFont("6x8",1);
        b.drawString("Score",x,40);
        b.drawString(score,x,56);
        b.drawString("Tap screen to",x,76);
        b.drawString("restart and flap",x,84);
        b.flip();
        return;
      }
    
      score++;
      birdvy += 0.4;
      birdvy *= 0.9;
      birdy += birdvy;
      if (birdy > H)
        gameStop();
      // draw bird
      b.drawImage(BIRDIMG, 6,birdy, {rotate:Math.atan2(birdvy,15)});
      // draw barriers
      barriers.forEach(function(r) {
        r.x1--;
        r.x2--;
        var btop = r.y-r.gap;
        var bbot = r.y+r.gap;
        b.setColor("#73bf2f"); // middle
        b.fillRect(r.x1+4, 0, r.x2-4, btop-1);
        b.fillRect(r.x1+4, bbot, r.x2-4, H-1);
        b.setColor("#c0f181"); // left
        b.fillRect(r.x1+1, 0, r.x1+3, btop-1);
        b.fillRect(r.x1+1, bbot, r.x1+3, H-1);
        b.setColor("#538917"); // right
        b.fillRect(r.x2-3, 0, r.x2-1, btop-1);
        b.fillRect(r.x2-3, bbot, r.x2-1, H-1);
        b.setColor("#808080"); // outlines
        b.drawRect(r.x1, btop-5, r.x2, btop); // top
        b.drawLine(r.x1+1, 0, r.x1+1, btop-6);
        b.drawLine(r.x2-2, 0, r.x2-2, btop-6);
        b.drawRect(r.x1, bbot, r.x2, bbot+5); // bottom
        b.drawLine(r.x1+1, bbot+6, r.x1+1, H-1);
        b.drawLine(r.x2-1, bbot+6, r.x2-1, H-1);
        if (r.x1<6 && (birdy-3<btop || birdy+3>bbot))
          gameStop();
      });
      while (barriers.length && barriers[0].x2<=0) {
        barriers.shift();
        newBarrier(g.getWidth());
      }
    
      b.flip();
    }
    
    Bangle.on('touch', function(button) {
      if (!running) {
        gameStart();
      } else {
        birdvy -= 4;
      }
    });
    
    Bangle.loadWidgets();
    g.clear();
    Bangle.drawWidgets();
    b.setBgColor("#e3db9d");
    gameStart();
    setInterval(draw, 100);
    
    

    However, the emulator shows these dots instead of a clear screen. Any hints?


    1 Attachment

    • screenshot_229.jpg
  • @Hank the BJS2 only supports 3bit color. The dots you can see are from dithering the remaining colors. http://forum.espruino.com/conversations/368893/

    If you don't want that you can use the 8 solid colors (Black, White, Red, Green, Blue, Cyan, Yellow, and Magenta).

  • Is there a way to convert e.g.

    var FLOORIMG = require("heatshrink").decompress(atob("iEKxH+kklABuLAAlgAAwNFB34OLmAAO0YAO5wAOA"));
    

    to 3bpp without having the original png file?

    Also if I change

      b = Graphics.createArrayBuffer(178,178,8);
    

    to

      b = Graphics.createArrayBuffer(178,178,3);
    

    I get

    Uncaught Error: Invalid BPP

    It looks fine in B/W though:

      b = Graphics.createArrayBuffer(178,178,2,{msb:true});
      var gimg = {
          width:178,
          height:178,
          bpp:2,
          buffer:b.buffer
        };
    

    Edit:
    I now understood that setting

      var H = b.getHeight()-24;
      b.setColor("#ff0000");
      b.fillRect(0,0,b.getWidth(),H-1);
    

    instead of

      var H = b.getHeight()-24;
      b.setColor("#71c6cf");
      b.fillRect(0,0,b.getWidth(),H-1);
    

    will stop dirthering, but how can I show some shade of grey? Is that not possible?

    PS: I intended to let it run in full resolution - but that will be too slow. So I stopped developing that. I's be curious about the Grey thought :)

  • but how can I show some shade of grey? Is that not possible?

    Not without dithering - because of the 3 bits.

    On Bangle.js 2 you may not even need the separate buffer. In fact I just pushed an update to the development app loader which renders fullscreen, and direct.

    Bangle.js 2's graphics aren't super fast at the moment (particularly the fill) - it's something I've been meaning to look at. Specifically if we were willing to throw away a bit of RAM (aligning to 4 bits, not 3) things get a lot easier!

  • Sacrificing a little memory to align to 4 bit sounds like a good compromise.

  • Post a reply
    • Bold
    • Italics
    • Link
    • Image
    • List
    • Quote
    • code
    • Preview
About

Bangle.js 2 Screen resolution in Flappy Bird

Posted by Avatar for Hank @Hank

Actions