Pushbutton (Digital Input)
Let's learn how to read a pushbutton using Arduino's digital input! We'll connect up a simple circuit using a solderless breadboard and use some simple Arduino code to control a single LED.
So far you've learned to control LEDs with code, which is one use for Arduino's outputs. This lesson builds on outputs by adding an input. Your Arduino board can be programmed to listen to electrical signals and take actions based on those inputs. A pushbutton is one kind of switch, a mechanical device that connects or breaks a circuit.
Explore the sample circuit here in the workplane by starting the simulation and testing the pushbutton. In this lesson, you'll build this circuit yourself along side the sample. To optionally build the physical circuit, gather up your Arduino Uno board, USB cable, solderless breadboard, an LED, resistors (one from 100-1K ohms and one 10K ohm), pushbutton, and breadboard wires.
- Continue to the next step.
Build the Circuit
Take a look at the sample circuit in the workplane. Remember that the breadboard rows are connected inside, so you can plug in components and wires to make quick temporary connections. To better understand what's going on, it's useful to also take a look at a free-wired version of the sample circuit, pictured here. In this step, you will build your own version of this circuit along side the sample in the workplane.
- Identify the pushbutton, LED, two resistors, and wires connected to the Arduino in the Tinkercad Circuits workplane.
- Drag an Arduino Uno and breadboard from the components panel to the workplane, next to the existing circuit.
- Connect breadboard power (+) and ground (-) rails to Arduino 5V and ground (GND), respectively, by clicking to create wires.
- Extend power and ground rails to their respective buses on the opposite edge of the breadboard by creating a red wire between both power buses and a black wire between both ground buses.
- Plug the LED into two different breadboard rows so that the cathode (negative, shorter leg) connects to one leg of a resistor (anywhere from 100-1K ohms is fine).
HINT:
The resistor can go in either orientation because resistors aren't polarized, unlike LEDs, which must be connected in a certain way to function.
- Connect other resistor leg to ground.
- Wire up the LED anode (positive, longer leg) to Arduino pin 13.
- Drag a pushbutton from the components panel to the center of your breadboard, and place it across the center column break so that its legs are plugged into four different breadboard rows.
- Click to create a wire connecting one button leg to power.
- Connect the diagonally opposite leg to Arduino digital pin 2.
- Create and position a high value resistor (such as 10K) between that same button leg and ground.
- Continue to the next step.
Pull-Down Resistor
Why do we need a resistor in order to read the switch? At rest, the two sides of this switch are not connected to one another. You can hover over the switch pins to see their Terminal labels. The switch is normally open, meaning at rest, Terminal 12 and Terminal 22 are not connected to Terminal 11 and Terminal 21 of the pushbutton. Arduino pin 2 is connected through a beefy 10K resistor to ground. When the button is pressed, the switch leads are connected, which allows pin 2 to be connected to 5V power, with no resistor. Since electricity takes the path of least resistance, the pin will sense the connection to power strongly, and ignore the weak (10K) connection to ground.
But when no other signal is present (when the switch isn't being pressed), that weak connection to ground is all the pin can sense. So the resistor is "pulling the pin down" to ground, and so it's called a pull-down resistor. Without one, pin 2 would be not connected to anything until the button is pressed. This is called "floating", and can result in random noise from static electricity and electromagnetic interference. Similarly a resistor can be used to tie a pin to power, which is called a pull-up resistor.
- Add a multimeter component to the workplane and wire it up to Arduino pin 2 and ground.
- Click Start Simulation and click to press/hold the pushbutton to observe the digital signal being picked up by pin 2.
- Continue to the next step.
Code With Blocks
Let's use the code blocks editor to listen to the pushbutton, then make a decision about whether to light up an LED based on the pushbutton's state: pressed or not pressed.
- Click the "Code" button to open the code editor.
- Click on the Variables category in the code editor. Create a new variable called
buttonState
. - Drag out a "set" block.
- We’ll store the state of our pushbutton to our variable
buttonState
. Click on the Input block category, drag out the the “read digital pin” block, and place it into the “set” block after the word “to”. - Since our pushbutton is connected to the Arduino on Pin 2, change the dropdown of the “read digital pin” block to 2. Now your blocks should read “set buttonState to read digital pin 2” which sets our
buttonState
variable to read our pushbutton state! - Click the Control category and drag out an if then block.
- Configure it to evaluate whether
buttonState
is equal toHIGH
using a Math comparator block. Drag out the Math comparator block into your if statement to check whether our variablebuttonState
is equal toHIGH
. - We want to turn our LED on if the button is pressed - otherwise, we want our LED to be off. Under the Output block category, find the “set built-in LED to HIGH” block. Try adding two of these blocks to our if statement so that the LED will only be on when the pushbutton is pressed.
HINT:
set built-in LED should be HIGH when the buttonState is HIGH - otherwise, set built-in LED should be LOW.
- Continue to the next step.
Pushbutton Arduino Code Explained
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. Follow along as we explore the code in more detail.
-
int buttonState = 0;
Before the
setup()
, we create a variable to store the current state of the button. It’s calledint
because it’s an integer, or any whole number. -
void setup() { pinMode(2, INPUT); pinMode(13, OUTPUT); }
Inside the setup, pins are configured using the
pinMode()
function. Pin 2 is configured as an input, so we can "listen" to the electrical state of the pushbutton. Pin 13 is configured as an output to control the LED. -
void loop() { // read the state of the pushbutton buttonState = digitalRead(2);
Anything after a set of slashes
//
is a comment, just for us humans to read, and is not included in the program when the Arduino runs it. In the main loop, a function calleddigitalRead();
checks the state of pin 2 (which will be either 5V aka HIGH or ground aka LOW), and stores that state in thebuttonState
variable we created at the top. -
// check if pushbutton is pressed. if it is, the // button state is HIGH if (buttonState == HIGH) { digitalWrite(13, HIGH); } else { digitalWrite(13, LOW); } delay(10); // Delay a little bit to improve simulation performance }
Below two more comment rows is an if statement that checks to see if
buttonState
is HIGH (==
is a comparison operator, not to be confused with=
, which is an assignment operator). If the condition is met, the built-in LED is set HIGH (on). If not, the code contained inside theelse {
is executed instead: the built-in LED is set LOW (off). If statements can exist alone, or with one or more else statements. - Continue to the next step.
Button Circuit Starter
This circuit is also available as a circuit starter. You can use this circuit starter anytime you want to read a pushbutton or other kind of switch or digital input.
- Grab this circuit and code combo any time using the starter available in the components panel (dropdown menu -> Starters -> Arduino).
- If you added the circuit starter to the existing breadboard circuit workplane, delete the duplicate Arduino board and components by clicking on them (or shift+drag to select within a box) and then clicking the trash icon (you can also press delete on your keyboard).
- Continue to the next step.
HINT:
The circuit starter has the same code as the sample circuit for this lesson, but lacks a breadboard and relies on the Uno's internal LED wired to pin 13 instead of an additional LED.
Build a Physical Arduino Circuit (Optional)
To program your physical Arduino Uno, you'll need to install the free software (or plugin for the web editor), then open it up.
- Wire up the Arduino Uno circuit by plugging in components and wires to match the connections shown here in Tinkercad Circuits. For a more in-depth walk-through on working with your physical Arduino Uno board, check out the free Instructables Arduino class (a similar circuit is described in the third lesson).
- 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. You can also find this example in the Arduino software by navigating to File -> Examples -> 02.Digital -> Button.
- Plug in your USB cable and select your board and port in the software’s Tools menu.
- Upload the code and watch your LED light up when you press the button!
- Continue to the next step.
Next, Try...
Now that you’ve learned to detect a pushbutton and use if statements to evaluate its state, you're ready practice more coding and explore new digital inputs.
- Can you figure out a way to swap the logic in your circuit, so that the LED is lit by default and goes dark when the button is pressed?
HINT:
There are three different ways to do this: try switching what the if statement is evaluating for, or swapping the LED pin states inside the if and else. Or switch the wiring instead!
- Continue on to the next lesson where you'll learn to read a potentiometer using
analogRead()
. - Try swapping out your pushbutton for other digital inputs such as a PIR motion sensor or tilt switch.
- Learn how to monitor your Arduino's digital and analog inputs through the computer using the Serial Monitor.