Tutorial: using the button to turn on the LED

Posted on
  • This is a fairly simple tutorial to demonstrate how you can use the button BTN1 to turn on one or more LEDs.

    First, let's turn on LED1:

    LED1.write(1);
    

    Next, let us create a function that will alternate between turning LED1 on and off:

    var next_state = 1;
    function swap() {
      LED1.write(next_state);
      next_state = !next_state;
    }
    

    we can now simply type swap(); to turn the LED on when it was off or vice versa. The next step is to keep a watch for that button and whether the user pressed it. For this, we have the function setWatch. However, this will be triggered twice: once when the button is pressed down, and once when the user releases the button. We only want our LED to change when the user presses down the button, so we need another function:

    function swap_on_down() {
      if (digitalRead(BTN1) == 1) swap();
    }
    

    This function is very easy, and will just verify whether BTN1 is pressed down. As such, it won't call the function swap when the user removes his/her finger from the button. This is exactly what we want! Now we can use the setWatch and let it call swap_on_down:

    setWatch(swap_on_down, BTN1, true);
    

    The last true option is provided so that this watch will keep on calling our function on successive presses on the button instead of only once. Try it, and you should see the red LED go on and off, each time you press the button.

    Maybe even more fun is alternating the colours. The idea here is that, when we press the button, the red light comes on. When we press the button again, the green lights goes on. Next time, the blue goes on, after which another press of the button will turn the red light back on etc. As one added tough, we can add that all LEDS turn off after the user stopped pressing the button for 5 seconds.

    // keep track of the next LED
    var next_LED = 1;
    // keep track of the ID, see later
    var timeout_ID = 0;
    function swap() {
      // remove the timeout to turn of all LEDs when the user pressed the button
      clearTimeout(timeout_ID);
      // determine which LED to turn on/off
      switch(next_LED) {
        case 1:
          LED1.write(1);
          LED3.write(0);
          break;
        case 2:
          LED2.write(1);
          LED1.write(0);
          break;
        case 3:
          LED3.write(1);
          LED2.write(0);
          break;
      }
      // determine the next LED to turn on
      next_LED = Math.wrap(next_LED, 3) + 1;
      // prepare a timeout to turn off all LEDs after a while
      // we capture the ID here, so that we can use it in a next call to this function
      timeout_ID = setTimeout(function () { LED1.write(0); LED2.write(0); LED3.write(0); }, 5000);
    }
    

    As you will see, this works as expected but returns an ERROR: Unknown Timeout at some times (when all LEDs are off). Sadly, there is nothing to be done about that using this code, but you are always welcome to improve upon it :).

  • This is great! It would be nice if there was a dedicated Tutorials section on this forum to make it easier to find later on. Or maybe even it will make its way into the Tutorials section on the website..

  • Thanks! And yes, good plan - I'll make a tutorials section.

    Cunningly the Espruino documentation (https://github.com/espruino/EspruinoDocs) and the forum use the same markdown syntax so you can just copy and paste your post (via 'Edit') into a new tutorial. Kim: are you ok with this? I'd be very happy to add your post.

    Just some stuff that might be helpful:

    • Your ERROR: Unknown Timeout error could be solved by adding timeout_ID=undefined to the Timeout call itself, and then if (timeout_ID!==undefined) clearTimeout(...)

    • setWatch can be called like setWatch(swap_on_down, BTN1, {repeat:true,edge:"rising"}); so that it only calls your swap_on_down function when the button becomes pressed.

  • Thanks for your suggestions. I'll test them towards the evening and update the tutorial accordingly. If you want, I can add the updated version to Github directly, I just didn't know that you could post tutorials through Github. Regardless, it's probably best to suggest tutorials on the forum first, just to get this kind of useful feedback!

  • Great, thanks! I've stuck some info on submitting tutorials here: http://www.espruino.com/Writing+Tutorials

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

Tutorial: using the button to turn on the LED

Posted by Avatar for Kim @Kim

Actions