Blink an LED With Digital Output

by circuits in Circuits > Arduino

25774 Views, 1 Favorites, 0 Comments

Blink an LED With Digital Output

F030XFXJ3YQ2HTG.LARGE.jpg

Let's learn how to blink an LED (light emitting diode) using Arduino’s digital output. If you’re new to Arduino, this is a great place to start. We'll connect an LED to the Arduino Uno and compose a simple program to turn the LED on and off. Here in Tinkercad Circuits, you can explore the sample circuit and build your own right next to it.

  1. Click "Start Simulation" to watch the LED blink. You can use the simulator any time to test your circuits.
  2. Continue to the next step.

LED Resistor Circuit

blink wiring.gif

The LED’s legs are connected to two pins on the Arduino: ground and pin 13. The component between the LED and pin 13 is a resistor, which helps limit the current to prevent the LED from burning itself out. Without it, you’ll get a warning that the LED might burn out soon. It doesn’t matter whether the resistor comes before or after the LED in the circuit, or which way around it goes. The colored stripes identify the resistor’s value, and for this circuit, anywhere from 100 ohms to 1000 ohms will work great.

The LED, on the other hand, is polarized, which means it only works when the legs are connected a certain way. The positive leg, called the anode, usually has a longer leg, and gets wired to power, in this case coming from your Arduino’s output pin. The negative leg, called the cathode, with its shorter leg, connects to ground.

  1. In the components panel, drag a resistor and LED onto the workplane.
  2. Edit the resistor's value by adjusting it to 220 ohms in the component inspector, which appears when the resistor is selected.
  3. Back in the components panel, find and bring over an Arduino Uno board.
  4. Click once to connect a wire to a component or pin, and click again to connect the other end. Connect your resistor to either side of the LED.
  5. If you connected your resistor to the LED's anode (positive, longer), connect the resistor's other leg to Arduino's digital pin 13. If you connected your resistor to the LED's cathode (negative, shorter leg), connect the resistor's other leg to Arduino's ground pin (GND).
  6. Create another wire between the unconnected LED leg and pin 13 or ground, whichever is still not connected.
  7. Extra credit: you can learn more about LEDs in the free Instructables LEDs and Lighting class.
  8. Continue to the next step.

Simple Code With Blocks

build blocks code.gif

Let’s go through the simple code blocks controlling the blink by opening the code editor (button labeled "Code"). You can resize the code editor by clicking and dragging the left edge.

The code starts out with two gray comment blocks, which are just notes for us humans to read. The first blue output block sets the built-in LED HIGH, which is Arduino’s way of describing “on.” This output command will activate a 5V signal to anything connected to the specified pin. Next up is a a yellow command block that waits for one second, simple enough. So the program will pause while the LED is on for one second. Next after another comment is a blue output block to set the LED back to LOW, or “off,” followed by another second-long pause.

  1. Try customizing this code by changing the wait times, and clicking "Start Simulation". You can even add more output and wait blocks to create longer flashing patterns.

    HINT: Did you notice the small LED flashing on the board itself? This built in LED is also connected to pin 13, and is meant to be used for testing purposes without the need to connect any external components. It even has its own tiny resistor, soldered directly to the surface of the board.

  2. Continue to the next step.

Blink Arduino Code Explained

Screen Shot 2018-01-31 at 12.17.33 PM.png

When the code editor is open, you can click the dropdown menu on the left and select "Blocks + Text" to reveal the Arduino code generated by the code blocks. All the extra symbols are part of Arduino’s syntax, but don’t be intimidated! It takes time to learn to write proper code from scratch. We'll go through each piece here, and you can always use the blocks for comparison as you level up throughout the lessons on this site.

  1. /*
      This program blinks pin 13 of the Arduino (the
      built-in LED)
    */
    

    This first section is title block comment, describing what the program does. Block comments are bookended by an opening /* and closing */.

  2. void setup()
    {
      pinMode(13, OUTPUT);
    }
    

    Next is the code’s setup, which helps set up things your program will need later. It runs once when the program starts up, and contains everything within its curly braces { }. Our blink sketch’s setup configures pin 13 as an output, which prepares the board to send signals to it, rather than listen.

  3. void loop()
    {
      // turn the LED on (HIGH is the voltage level)
      digitalWrite(13, HIGH);
      delay(1000); // Wait for 1000 millisecond(s)
      // turn the LED off by making the voltage LOW
      digitalWrite(13, LOW);
      delay(1000); // Wait for 1000 millisecond(s)
    }
    

    The main body of the program is inside the loop, indicated by another set of curly braces { }. This part of the code will execute on repeat, so long as the board has power. The colored text following double slashes are also comments to help make the program easier to understand. The output command we’re using is called digitalWrite(), which is a function that sets a pin HIGH or LOW, on or off. To pause the program we’ll use delay(), which takes a number of milliseconds (1000ms = 1s).

  4. Continue to the next step.

Use the Blink Circuit Starter

Screen Shot 2018-01-31 at 12.23.32 PM.png

This is a circuit we think you'll want to make frequently, so it's saved as a circuit starter!

  1. Grab this circuit and code combo any time using the starter available in the components panel (dropdown menu -> Starters -> Arduino).
  2. For a more advanced version of this Arduino code, also check out the Blink Without Delay starter, which uses the current time to keep track of blink intervals instead of delay();
  3. If you added the circuit starter to the existing breadboard circuit workplane, delete the duplicate Arduino board and components by clicking on them and then clicking the trash icon (you can also press delete on your keyboard).
  4. Continue to the next step.

Programming a Physical Arduino (Optional)

FDT25F2J3KFAOB6.LARGE.jpg

To program your physical Arduino Uno, you'll need to install the free software (or plugin for the web editor), then open it up.

  1. Copy the code from the Tinkercad Circuits code window and paste it into an empty sketch in your Arduino software, or click the download button (downward facing arrow) and open the resulting file using Arduino. This beginner example is also available directly within the Arduino software under File-> Examples-> 01.Basics-> Blink.
  2. Plug in your USB cable and select your board and port in the software’s Tools menu.
  3. Upload the code and watch your onboard LED flash with the custom blink you created earlier! For a more in-depth walk-through on setting up and programming your physical Arduino Uno board, check out the free Instructables Arduino class (first lesson).
  4. Continue to the next step.

Next, Try...

freewired 3.gif

Now that you know how to blink an LED using Arduino’s digital output, you're ready to try other Arduino exercises that utilize the digitalWrite(); function. In the next lesson, you'll try using a breadboard to add more LEDs and code to control.

  1. Experiment with this simulation by adding more blocks to create flashing patterns. Can you create a program that flashes out a message using Morse Code?
  2. Continue on with the next lesson about adding more LEDs and using a solderless breadboard.