KEMBAR78
Arduino Intro | PDF | Arduino | Pointer (Computer Programming)
0% found this document useful (0 votes)
15 views18 pages

Arduino Intro

Uploaded by

vithulakash
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
15 views18 pages

Arduino Intro

Uploaded by

vithulakash
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 18

Introduction to Arduino

September 3, 2024
Chapter 1

IDE Installation

To become familiar with the use of Arduino boards, you will perform several experiments using
this board. In order to do this, you have to procure an Arduino Nano board and a breadboard
for making connections to it. To develop applications using these boards, you have to install
an Integrated Development Environment (IDE) for Arduino on your laptop. Procedure for
this is described in this document. After installation of IDE, you can proceed to perform the
simple experiments described here to become familiar with the use of Arduino boards.

Arduino programs are called “sketches”. These sketches are compiled on the host PC and
the resulting binary program is uploaded to the Arduino board by the IDE using the USB
interface.

Material in this document has been compiled from various tutorials available on the net for Arduino.

1.1 Arduino IDE Installation


Installation of the Integrated Development Environment (IDE) for Arduino requires
i) downloading the software and
ii) installing it using the installation utilities of your operating system.

1.2 Downloading Arduino IDE


IDE software can be downloaded from the Arduino Software page:
https://www.arduino.cc/en/software
Operating System version requirements for running the IDE are:

Windows: Win 10 and newer, 64 bits, or

Mac OS X: Version 10.14: “Mojave” or newer, 64 bits, or

Linux: 64 bit distributions

Arduino IDE 2.x is an open-source project. It is a big step from its sturdy predecessor, Ar-
duino IDE 1.x, and comes with revamped User Interface or UI, improved board and library
manager, debugger, auto-complete feature and much more. Currently, the latest version of
the IDE is 2.3.2 (This may change with time).

To download the Editor, you need to visit the Arduino software page. Go to:
https://www.arduino.cc/en/software
and click on the Download button appropriate for your operating system.
1
1.3 Installing the IDE
Installation procedure is operating system dependent.

Windows: To install Arduino IDE 2.x on a Windows computer, simply run the file down-
loaded from the software page. Follow the instructions in the installation guide. The
installation may take several minutes.

Some windows installations require that you install a special serial port driver (CH 340)
before you can communicate with Arduino cards through the USB interface. This driver
can be installed from:
https://www.wch-ic.com/downloads/CH341SER ZIP.html
A tutorial for installing it is available at:
https://learn.sparkfun.com/tutorials/how-to-install-ch340-drivers/all

MAC OS: To install the Arduino IDE 2.x on a MAC OS computer, simply copy the down-
loaded file into your application folder.

Linux: To install Arduino IDE 2.3.2 on Linux, first download the file:
arduino-ide_2.3.2_Linux_64bit.zip from the software page and place it in a direc-
tory of your choice. The file is compressed and you have to extract it in a suitable folder,
remembering that it will be executed from there. For this, open a terminal window in
this directory and unzip the file:
sudo unzip arduino-ide_2.3.2_Linux_64bit.zip. This will extract all the necessary
files from the zip archive. You will find a directory called arduino-ide_2.3.2_Linux_64bit.

Change to this directory by:


cd arduino-ide_2.3.2_Linux_64bit.
Running Arduino-IDE from this directory (for example, by double clicking on the file
name) will start the IDE program.
Optional step: add a link to the executable file
If you have a bin directory added to your path, you can place a link to this executable
file in your bin directory.
cd <path to your bin directory>
ln -s <arduino directory path>/arduino-ide_2.3.2_Linux_64bit/arduino-ide ide
Now you will be able to launch the IDE from any directory. This step is optional.
Arduino programs (called “sketches”) are compiled on the host PC and uploaded using
a serial connection to the Arduino board. Since Linux is a multi-user OS, access to com-
mon resources like the serial or USB port is controlled by the OS – otherwise multiple
users may use a resource simultaneously and destroy each others’ data. Hence, access
to common resources has to be obtained from the system administrator before you can
use these.

When you start the IDE on your PC, you have to select a board (so that the “sketch”
will be compiled according to specifics of your board) and a port, which will be used to
communicate with your board.

It is possible that when you upload a sketch - (after selecting your board and the serial
port), - you get an error:
“Error opening serial port ...”, or
2
“can’t open device ”/dev/ttyUSB0”: Permission denied
If you get this error, you need to set serial port permissions. To do this:
Open a terminal and run ls -l on the problem device. For this, type:
ls -l /dev/ttyACM*
or
ls -l /dev/ttyUSB*

you will get something like:

crw-rw—- 1 root dialout 188, 0 5 apr 23.01 ttyACM0


or
crw-rw—-. 1 root dialout 188, 0 Nov 8 11:44 /dev/ttyUSB0
The “0” at the end of ACM/USB might be a different number depending on the actual
serial line of USB port being used, or multiple entries might be returned. We want to
find the group owner of the tty – in this case, it is “dialout”.

Now we just need to add our user to the group: This is done by:

sudo usermod -a -G dialout <username>


where <username> is your Linux user name. This will add you to the group “dialout”
which owns this serial line. You will need to log out and log in again for this change to
take effect.

After this procedure, you should be able to proceed normally and upload the sketch to
your board or use the Serial Monitor.

1.4 Compiling and uploading Arduino programs


Arduino programs are called “sketches”. These sketches are compiled on a PC or laptop and
then the binary is uploaded to the Arduino card using the USB port.

If you are able to compile Arduino code but the IDE cannot upload the code to the Ar-
duino card, check if the proper serial driver is installed if you are using Windows and proper
permissions are set on the serial line if you are using Linux. If you are still unable to upload
the code, it is possible that the processor used on your card has an old version of bootloader
code. (Boot loader is a pre-loaded program on the micro-controller which enables it to use
the USB port to receive compiled programs and to store them in the program memory). In
this case, you have to set the processor type as “ATmega328P (Old Bootloader)”.

You can do this by going to the Tools tab on the IDE and clicking on “processor”. Choose
“ATmega328P (Old Bootloader)” from the choices offered. Now the upload will go through.

3
Chapter 2

Arduino Hardware and Library


Functions

2.1 Arduino board pinout


2.1.1 Arduino Nano board

Picture on the left


shows an Arduino Nano
board.
Pins are brought out
to pins on the sides of
the board. Pin names
are silk-screened on the
board next to the pins.

The nano board can be plugged


into a breadboard just like a large
IC.

The board can be powered by the USB interface. (It uses a mini-USB connector). It can also
be powered by supplying an external DC voltage between 7 and 12 V, fed to its Vin pin.

4
2.1.2 Arduino Uno board
The picture below shows an Arduino Uno board.
Pins are brought out to the connectors on the sides of the board and pin names are silk-screened
on the board next to the connector sockets.

The Uno board has an additional connector, which allows it to be powered by a wall plug type
DC source supplying a DC voltage in the range 7 to 12 V.

Pin names for Uno and Nano are practically identical.

5
Pinout for Arduino Nano
Pin Category Pin Name Details
Power:
Vin Input voltage to Arduino
when using an external power source.
5V Regulated power supply used to power
microcontroller, other components
3.3 V 3.3 V supply generated by
on-board voltage regulator.
Max current: 50 mA.
GND ground pins.
I/O Pins:
Digital Pins 0 - 13 Digital input or output pins
Pulse Width Modulation 3, 5, 6, 9, 11 8-bit PWM output.
Analog Pins A0 – A7 Used to provide analog input
in the range of 0-5 V
Analog Ref AREF To provide reference voltage
for input voltage.
Serial 0(Rx), 1(Tx) Receive and Transmit TTL serial data.
SPI 11 (MOSI), 12 (MISO) Used for SPI communication
10 (SS), 13 (SCLK)
I2C interface A4 (SDA), A5 (SCA) for “two wire interface” (TWI)
or I2C communication
External Interrupts 2, 3 To trigger an interrupt
Reset Reset Resets the microcontroller.
Inbuilt LED 13 To turn on the inbuilt LED

2.2 Language Reference


Arduino programming language can be divided in three main parts: functions, values (vari-
ables and constants), and structure.

2.3 functions
2.3.1 For controlling the Arduino board and performing computations:
Digital I/O: digitalRead( ), digitalWrite( ), pinMode( )
Analog I/O: analogRead( ), analogReference( ) analogWrite( )
on Zero, Due and MKR Family: analogReadResolution( ), analogWriteResolution( )

2.3.2 Advanced I/O:


noTone( ), tone( )
pulseIn( ), pulseInLong( ), shiftIn( ), shiftOut( )
Time, delay( ), delayMicroseconds( ), micros( ), millis( ),

6
2.3.3 Math:
abs( ), constrain( ), map( ), max( ), min( ), pow( ), sq( ), sqrt( )
Trigonometry:
cos( ), sin( ), tan( )

2.3.4 Characters:
isAlpha( ), isAlphaNumeric( ), isAscii( ), isControl( ), isDigit( ), isGraph( )
isHexadecimalDigit( ), isLowerCase( ), isPrintable( ), isPunct( ), isSpace( )
isUpperCase( ), isWhitespace( )

2.3.5 Random Numbers:


random( ), randomSeed( )

2.3.6 Bits and Bytes:


bit( ), bitClear( ), bitRead( ), bitSet( ), bitWrite( )
highByte( ), lowByte( )

2.3.7 Interrupt controls:


interrupts( ), noInterrupts( )

2.3.8 External Interrupts:


attachInterrupt( ), detachInterrupt( )

2.3.9 Communication:
Serial, SPI, Stream, Wire, USB, Keyboard, Mouse

2.4 Variables:
Arduino data types and constants:
Constants:
HIGH | LOW
INPUT | OUTPUT | INPUT PULLUP
LED BUILTIN
true | false
Floating Point Constants, Integer Constants
Conversion:
(unsigned int), (unsigned long)
byte( ), char( ), float( ), int( ), long( ), word( )

7
2.4.1 Data Types:

array, bool, boolean, byte, char, double, float, int, long, short,
size t, string, String( ), unsigned char
unsigned int, unsigned long, void, word,
Variable Scope and Qualifiers:
const, scope, static, volatile, Utilities, PROGMEM, sizeof( ).

2.5 Structure:
The elements of Arduino (C++) code: Sketch, loop( ), setup( )
Control Structure: break, continue, do...while, else, for, goto, if
return, switch...case, while,
Further Syntax:
#define (define), #include (include) /* */ (block comment), // (single line comment)
; (semicolon), {} (curly braces)
Arithmetic Operators:
% (remainder), * (multiplication), + (addition), - (subtraction), / (division)
= (assignment operator)
Comparison Operators:
== (equal to), != (not equal to), < (less than), <= (less than or equal to)
> (greater than), >= (greater than or equal to)
Boolean Operators:
! (logical not), && (logical and), || (logical or)
Pointer Access Operators:
& (reference operator), * (dereference operator)
Bitwise Operators:
& (bitwise and), << (bitshift left), >> (bitshift right),
^ (bitwise xor), | (bitwise or), ~ (bitwise not)
Compound Operators:
%= (compound remainder), &= (compound bitwise and)
= (compound multiplication), ++ (increment), += (compound addition)
– (decrement), -= (compound subtraction), /= (compound division)
^= (compound bitwise xor), | = (compound bitwise or)

8
Chapter 3

Example Experiments with Arduino

Arduino IDE comes with a number of example programs which are available from the File/Examples
menu on the IDE. We’ll use some of these readymade programs to familiarize ourselves with
the use of Arduino boards.

3.1 Bare Minimum code example


The bare minimum of code needed to start an Arduino sketch:

This example contains the bare minimum of code you need for a sketch to compile properly
on Arduino Software (IDE): the setup( ) method and the loop( ) method.

3.1.1 Hardware Required


Arduino Board

3.1.2 Circuit
Only your Arduino Board is needed for this example.

3.1.3 Code
The bare minimum of code needed to start an Arduino sketch:

This example does nothing – it just illustrates the software structure of a sketch developed
for Arduino. It contains the bare minimum of code you need for a sketch to compile properly
on Arduino Software (IDE): the setup( ) method and the loop( ) method.

This code won’t actually do anything, but it’s structure is useful for copying and pasting
to get you started on any sketch of your own. It also shows you how to include comments in
your code.

void setup ( ) {
// put your set up code here to run once:
}

void loop ( ) {
// put your main code here, to run repeatedly:
}

9
The setup( ) function is called when a sketch starts. Use it to initialize variables, pin modes,
start using libraries, etc. The setup function will only run once, after each powerup or reset
of the board.

After creating a setup( ) function, the loop( ) function does precisely what its name sug-
gests, and is called repetitively from an endless loop. The function allows your program to
change and respond as it runs. Code in the loop( ) section of your sketch is used to actively
control the board.

Any line that starts with two slashes (//) will not be read by the compiler, so you can
write anything you want after it. The two slashes may be put after functional code to keep
comments on the same line. Commenting your code like this can be particularly helpful in
explaining, both to yourself and others, how your program functions step by step.

3.2 Blinking an LED:


This example shows the simplest thing you can do with an Arduino to see physical output: it
blinks the on-board LED.

3.2.1 Hardware Required


Arduino Board, and (optional) LED, 220 Ω resistor

3.2.2 Circuit
This example uses the built-in LED that most Arduino boards have. The LED is connected
to a digital pin and the pin number may vary from board type to board type. To make your
life easier, we have a constant that is specified in every board descriptor file. This constant is
LED_BUILTIN and allows you to control the built-in LED easily. Here is the correspondence
between the constant and the digital pin:
Boards 101 Due, Intel Edison, Intel Galileo Gen2, Leonardo and Micro, LilyPad, LilyPad
USB, MEGA2560, Mini, Nano, Pro, Pro Mini, UNO, Yún and Zero connect D13 to the LED.
Gemma board connects the LED to D1 and MKR1000 connects it to D6.
If you want to light an external LED with this sketch, you need to
build this circuit, where you connect one end of the resistor to the UNO or D13 220
digital pin correspondent to the LED_BUILTIN constant. Connect Nano
the long leg of the LED (the positive leg, called the anode) to
the other end of the resistor. Connect the short leg of the LED Arduino
Board
(the negative leg, called the cathode) to the GND. In the diagram
below we show an UNO board that has D13 as the LED_BUILTIN
value.
The value of the resistor in series with the LED may be of a different value than 220 Ω; the
LED will light up also with values up to 1K Ω.

3.2.3 Code
/*
Blink Turns an LED on for one second, then off for one second, repeatedly.

Most Arduinos have an on-board LED you can control. On the UNO, MEGA and ZERO
10
it is attached to digital pin 13, on MKR1000 on pin 6. LED_BUILTIN is set to
the correct LED pin independent of which board is used.
If you want to know what pin the on-board LED is connected to on your Arduino
model, check the Technical Specs of your board at:
https://www.arduino.cc/en/Main/Products
*/

// the setup function runs once when you press reset or power the board
void setup( ) {
// initialize digital pin LED_BUILTIN as an output.
pinMode(LED_BUILTIN, OUTPUT);
}

// the loop function runs over and over again forever


void loop( ) {
digitalWrite(LED_BUILTIN, HIGH);// turn the LED on (HIGH is the voltage level)
delay(1000); // wait for a second
digitalWrite(LED_BUILTIN, LOW); // turn the LED off by making the voltage LOW
delay(1000); // wait for a second
}

3.3 Digital Read Serial


Read a switch, print the state out to the Arduino Serial Monitor.

This example shows you how to monitor the state of a switch by establishing serial com-
munication between your Arduino and your computer over USB.

3.3.1 Hardware Required


Arduino Board, a momentary switch, button, or toggle switch, 10K Ω resistor, hook-up wires
and breadboard.

3.3.2 Circuit
5V
When the push button is open (unpressed) there is no connection
between the two legs of the push button, so the pin is connected to UNO or Pin 2
ground (through the 10KΩ pull-down resistor) and reads as LOW, Nano
or ‘0’. When the button is closed (pressed), it makes a connection Arduino 10K
between its two legs, connecting the pin to 5 volts, so that the pin Board
reads as HIGH, or ‘1’.

3.3.3 code
In the program below, the very first thing that you do (in the setup function) is to begin serial
communications, at 9600 bits of data per second, between your board and your computer with
the line:

11
Serial.begin(9600);

Next, initialize digital pin 2, the pin that will read the output from your button, as an input:

pinMode(2,INPUT);

Now that your setup has been completed, move into the main loop of your code. When
your button is pressed, 5 volts will freely flow to pin 2 and when it is not pressed, pin 2 will
be connected to ground through the 10 K Ω resistor. This is a digital input, meaning that the
switch can only be in either an on state (seen by your Arduino as a ‘1’, or HIGH) or an off
state (seen by your Arduino as a ‘0’, or LOW), with nothing in between.

The first thing you need to do in the main loop of your program is to establish a variable
to hold the information coming in from your switch. Since the information coming in from the
switch will be either a ‘1’ or a ‘0’, you can use an int datatype. Call this variable ‘sensorValue’,
and set it to equal whatever is being read on digital pin 2. You can accomplish this with just
one line of code:

int sensorValue = digitalRead(2);

Once the board has read the input, make it print this information back to the computer
as a decimal value. You can do this with the command Serial.println( ) in our last line of code:

Serial.println(sensorValue);

Now, when you open your Serial Monitor in the Arduino Software (IDE), you will see a
stream of ’0’s if your switch is open, or ‘1’s if your switch is closed.

/*
DigitalReadSerial
Reads a digital input on pin 2, prints the result to the Serial Monitor
*/

// digital pin 2 has a push button attached to it. Give it a name:


int pushButton = 2;

// the setup routine runs once when you press reset:


void setup( ) {
// initialize serial communication at 9600 bits per second:
Serial.begin(9600);
// make the pushbutton’s pin an input:
pinMode(pushButton, INPUT);
}

// the loop routine runs over and over again forever:


void loop( ) {
// read the input pin:
int buttonState = digitalRead(pushButton);
// print out the state of the button:
Serial.println(buttonState);
delay(1); // delay in between reads for stability
}
12
3.4 Fading a LED
This example demonstrates the use of analog output to fade an LED. We use of the analog-
Write( ) function to fade-in and fade-out an LED.

AnalogWrite uses pulse width modulation (PWM). In PWM, we turn something on and
off very quickly, controlling the ratio of on and off durations. The ratio of the two durations
determines the average value at the output. Thus we can generate an average value on the
output pin which is not the supply voltage or ground, but can be adjusted to any value in
between. Hence it is called “analogWrite”. We can use this technique to create a fading effect.

3.4.1 Hardware Required


Arduino board, LED, 220Ω resistor, hook-up wires, breadboard,

3.4.2 Circuit

UNO or 470
Connect the anode (the longer, positive leg) of your LED to D9
Nano
digital output pin 9 on your board through a 220 Ω resistor.
Arduino
Connect the cathode (the shorter, negative leg) directly to Board
LED
ground.

3.4.3 Code
After declaring pin 9 to be your LED Pin, there is nothing to do in the setup( ) function of
your code. The analogWrite( ) function that you will be using in the main loop of your code
requires two arguments: One telling the function which pin to write to, and one indicating
what PWM value to write.

In order to fade your LED off and on, gradually increase your PWM value from 0 (all the
way off) to 255 (all the way on), and then back to 0 once again to complete the cycle. In the
sketch below, the PWM value is set using a variable called ‘brightness’. Each time through the
loop, it increases by the value of the variable ‘fadeAmount’. If brightness is at either extreme
of its value (either 0 or 255), then fadeAmount is changed to its negative. In other words, if
fadeAmount is 5, then it is set to -5. If it’s -5, then it’s set to 5. The next time through the
loop, this change causes brightness to change direction as well.

The function analogWrite( ) can change the PWM value very fast, so the delay at the end
of the sketch controls the speed of the fade. Try changing the value of the delay and see how
it changes the fading effect.

/*
Fade

This example shows how to fade an LED on pin 9 using the analogWrite( )
function.
The analogWrite( ) function uses PWM, so if you want to change the pin
you’re using, be sure to use another PWM capable pin. On most Arduinos,
the PWM pins are identified with a "~" sign, like ~3, ~5, ~6, ~9, ~10
and ~11.
*/
13
int led = 9; // the PWM pin the LED is attached to
int brightness = 0; // how bright the LED is
int fadeAmount = 5; // how many points to fade the LED by

// the setup routine runs once when you press reset:


void setup( ) {
// declare pin 9 to be an output:
pinMode(led, OUTPUT);
}

// the loop routine runs over and over again forever:


void loop( ) {
// set the brightness of pin 9:
analogWrite(led, brightness);

// change the brightness for next time through the loop:


brightness = brightness + fadeAmount;

// reverse the direction of the fading at the ends of the fade:


if (brightness <= 0 || brightness >= 255) {
fadeAmount = -fadeAmount;
}
// wait for 30 milliseconds to see the dimming effect
delay(30);
}

3.5 Reading an analog voltage


This example shows you how to read an analog input on analog pin 0, convert it into voltage,
and print it out to the serial monitor of the Arduino Software (IDE).

3.5.1 Hardware Required


Arduino Board, 10KΩ potentiometer.

3.5.2 Circuit
Connect three wires from the potentiometer to your board. The
first goes to ground from one of the outer pins of the potentiome-
5V
ter. The second goes to 5 volts from the other outer pin of the 13
12 Arduino
Potentiometer

11 UNO/nano
potentiometer. The third goes from the middle pin of the poten- 10 board
10 K

9 A0
tiometer to analog input 0. By turning the shaft of the poten- 8
7
A1
A2
470

6 A3
tiometer, you change the amount of resistance on either side of 5 A4
LED

4 A5
the wiper which is connected to the center pin of the potentiome- 3
Tx
Gnd

ter. This changes the voltage at the center pin, which will be read Rx

using an analog to digital converter.


When the resistance between the center and the side connected to 5 volts is close to zero (and
the resistance on the other side is close to 10 KΩ), the voltage at the center pin nears 5 volts.
When the resistances are reversed, the voltage at the center pin nears 0 volts, or ground. This
voltage is the analog voltage that you’re reading as an input.

14
The microcontroller of the board has a circuit inside called an analog-to-digital converter
or ADC that reads this changing voltage and converts it to a number between 0 and 1023.
When the shaft is turned all the way in one direction, there are 0 volts going to the pin, and
the input value is 0. When the shaft is turned all the way in the opposite direction, there
are 5 volts going to the pin and the input value is 1023. In between, analogRead( ) returns
a number between 0 and 1023 that is proportional to the amount of voltage being applied to
the pin.

3.5.3 Code
In the program below, the very first thing that you do will in the setup function is to begin
serial communications, at 9600 bits of data per second, between your board and your computer
with the line:
Serial.begin(9600);
Next, in the main loop of your code, you need to establish a variable to store the resistance
value (which will be between 0 and 1023, perfect for an int datatype) coming in from your
potentiometer:
int sensorValue = analogRead(A0);
To change the values from 0-1023 to a range that corresponds to the voltage the pin is reading,
you’ll need to create another variable, a float, and do a little math. To scale the numbers
between 0.0 and 5.0, divide 5.0 by 1023.0 and multiply that by sensorValue :
float voltage= sensorValue * (5.0 / 1023.0);
Finally, you need to print this information to your serial window. You can do this with the
command Serial.println( ) in your last line of code:
Serial.println(voltage)
Now, when you open your Serial Monitor in the Arduino IDE (by clicking on the icon on the
right side of the top green bar or pressing Ctrl+Shift+M), you should see a steady stream of
numbers ranging from 0.0 - 5.0. As you turn the pot, the values will change, corresponding
to the voltage coming into pin A0.

/*
ReadAnalogVoltage
Reads an analog input on pin 0, converts it to voltage,
and prints the result to the Serial Monitor.
Graphical representation is available using Serial Plotter
(Tools > Serial Plotter menu).
Attach the center pin of a potentiometer to pin A0, and
the outside pins to +5 V and ground.
*/
// the setup routine runs once when you press reset:
void setup( ) {
// initialize serial communication at 9600 bits per second:
Serial.begin(9600);
}

// the loop routine runs over and over again forever:


void loop( ) {
// read the input on analog pin 0:
int sensorValue = analogRead(A0);
//Convert the analog reading (which goes from 0 - 1023) to a voltage (0 - 5 V):
float voltage = sensorValue * (5.0 / 1023.0);
// print out the value you read:

15
Serial.println(voltage);
}

3.6 Reading the timer


Sometimes you need to do two things at once. For example you might want to blink an LED
while reading a button press. In this case, you can’t use delay( ), because Arduino pauses
your program during the delay( ). If the button is pressed while Arduino is paused waiting
for the delay( ) to pass, your program will miss the button press.

This sketch demonstrates how to blink an LED without using delay( ). It turns the LED
on and then makes note of the time. Then, each time through loop( ), it checks to see if the
desired blink time has passed. If it has, it toggles the LED on or off and makes note of the
new time. In this way the LED blinks continuously while the sketch execution never lags on
a single instruction.

3.6.1 Hardware Required


Arduino Board, LED, 220 Ω resistor.

3.6.2 Circuit
To build the circuit, connect one end of the resistor to pin
UNO or 220
13 of the board. Connect the long leg of the LED (the D13
Nano
positive leg, called the anode) to the other end of the resistor.
Arduino
Connect the short leg of the LED (the negative leg, called Board
the cathode) to the board GND, as shown in the schematic.
Or else, you can just use the inbuilt LED on the board.

3.6.3 Code
The code uses the millis( ) function, a command that returns the number of milliseconds since
the board started running its current sketch, to blink an LED.

/*
Blink without Delay

Turns on and off a light emitting diode (LED) connected to a digital pin,
without using the delay( ) function. This means that other code can run
at the same time without being interrupted by the LED code.

The circuit:
- Use the onboard LED.
- Note: Most Arduinos have an on-board LED you can control. On the UNO, MEGA
and ZERO it is attached to digital pin 13, on MKR1000 on pin 6.
LED_BUILTIN is set to the correct LED pin independent of which board is
used. If you want to know what pin the on-board LED is connected to on
your Arduino model, check the Technical Specs of your board at:
https://www.arduino.cc/en/Main/Products
*/

16
// constants won’t change. Used here to set a pin number:
const int ledPin = LED_BUILTIN;// the number of the LED pin

// Variables will change:


int ledState = LOW; // ledState used to set the LED

// Generally, you should use "unsigned long" for variables that hold time
// The value will quickly become too large for an int to store
unsigned long previousMillis = 0;// will store last time LED was updated

// constants won’t change:


const long interval = 1000; // interval at which to blink (milliseconds)

void setup( ) {
// set the digital pin as output:
pinMode(ledPin, OUTPUT);
}

void loop( ) {
// here is where you’d put code that needs to be running all the time.

// check to see if it’s time to blink the LED; that is, if the difference
// between the current time and last time you blinked the LED is bigger than
// the interval at which you want to blink the LED.
unsigned long currentMillis = millis( );

if (currentMillis - previousMillis >= interval) {


// save the last time you blinked the LED
previousMillis = currentMillis;

// if the LED is off turn it on and vice-versa:


if (ledState == LOW) {
ledState = HIGH;
} else {
ledState = LOW;
}

// set the LED with the ledState of the variable:


digitalWrite(ledPin, ledState);
}
}

17

You might also like