ESP8266 - Touch Sensor

This tutorial instructs you how to use the capacitive touch sensor with ESP8266. In detail, we will learn:

Hardware Preparation

1×ESP8266 NodeMCU
1×USB Cable Type-C
1×Touch Sensor
1×Jumper Wires
1×Breadboard
1×(Recommended) Screw Terminal Expansion Board for ESP8266
1×(Recommended) Power Splitter For ESP8266 Type-C

Or you can buy the following sensor kits:

1×DIYables Sensor Kit (30 sensors/displays)
1×DIYables Sensor Kit (18 sensors/displays)
Disclosure: Some of the links provided in this section are Amazon affiliate links. We may receive a commission for any purchases made through these links at no additional cost to you.
Additionally, some of these links are for products from our own brand, DIYables.

Overview of Touch Sensor

A capacitive touch sensor, also known as a touch button or touch switch, is commonly used to control devices, such as a touchable lamp. It has the same purpose as a button, but is used in place of a button on many modern devices due to its sleek appearance.

The Touch Sensor Pinout

The touch sensor has three pins:

  • GND pin: This should be connected to the ground voltage (0V).
  • VCC pin: This should be connected to the VCC voltage (5V or 3.3V).
  • SIGNAL pin: This is an output pin. It will be LOW when not touched and HIGH when touched. This pin should be connected to an ESP8266 input pin.
Touch Sensor pinout

How It Works

  • When the sensor is not being interacted with, the SIGNAL pin of the sensor is at a LOW level.
  • However, when the sensor is touched, the SIGNAL pin of the sensor is at a HIGH level.

ESP8266 - Touch Sensor

The SIGNAL pin of the touch sensor is connected to an input pin of an ESP8266. We can determine if the touch sensor has been touched by examining the state of the ESP8266's pin.

Wiring Diagram

The wiring diagram between ESP8266 NodeMCU and touch sensor

This image is created using Fritzing. Click to enlarge image

See more in ESP8266's pinout and how to supply power to the ESP8266 and other components.

How To Program For Touch Sensor

  • Set the ESP8266 pin to the digital input mode using the pinMode() function. For example:
pinMode(D7, INPUT);
  • Read the state of the ESP8266 pin through the digitalRead() function.
int inputState = digitalRead(D7);

※ NOTE THAT:

There are two commonly used scenarios:

  • The first: If the input state is HIGH, carry out one action. If the input state is LOW, execute the opposite action.
  • The second: If the input state changes from LOW to HIGH (or HIGH to LOW), perform an action.

We select one of them based on the purpose of the application. For example, if we want to use a touch sensor to control an LED:

  • If the goal is to have the LED be ON when the sensor is touched and OFF when the sensor is NOT touched, we SHOULD use the first scenario.
  • If the goal is to have the LED toggle between ON and OFF each time we touch the sensor, we SHOULD use the second scenario.

Touch Sensor - ESP8266 Code

The tutorial provides two sample code:

  • ESP8266 reads the value from the touch sensor and prints it on the Serial Monitor.
  • ESP8266 detects whether the sensor is touched or released.

ESP8266 reads the value from the touch sensor and print to the Serial Monitor

/* * This ESP8266 NodeMCU code was developed by newbiely.com * * This ESP8266 NodeMCU code is made available for public use without any restriction * * For comprehensive instructions and wiring diagrams, please visit: * https://newbiely.com/tutorials/esp8266/esp8266-touch-sensor */ #define SENSOR_PIN D7 // The ESP8266 NodeMCU input pin that connects to the sensor's SIGNAL pin void setup() { // Initialize the Serial to communicate with the Serial Monitor. Serial.begin(9600); // initialize the ESP8266 NodeMCU's pin as an input pinMode(SENSOR_PIN, INPUT); } void loop() { // read the state of the the input pin: int state = digitalRead(SENSOR_PIN); // print state to Serial Monitor Serial.println(state); }

Detailed Instructions

To get started with ESP8266 on Arduino IDE, follow these steps:

  • Check out the how to setup environment for ESP8266 on Arduino IDE tutorial if this is your first time using ESP8266.
  • Wire the components as shown in the diagram.
  • Connect the ESP8266 board to your computer using a USB cable.
  • Open Arduino IDE on your computer.
  • Choose the correct ESP8266 board, such as (e.g. NodeMCU 1.0 (ESP-12E Module)), and its respective COM port.
  • Copy the code and open it in the Arduino IDE.
  • Click the Upload button in the IDE to transfer the code to the ESP8266.
  • Place your finger on the sensor and then remove it.
  • Check the output in the Serial Monitor.
COM6
Send
0 0 0 1 1 1 1 1 1 0 0
Autoscroll Show timestamp
Clear output
9600 baud  
Newline  

ESP8266 detects the sensor is touched or released

/* * This ESP8266 NodeMCU code was developed by newbiely.com * * This ESP8266 NodeMCU code is made available for public use without any restriction * * For comprehensive instructions and wiring diagrams, please visit: * https://newbiely.com/tutorials/esp8266/esp8266-touch-sensor */ #define SENSOR_PIN D7 // The ESP8266 NodeMCU input pin that connects to the sensor's SIGNAL pin int prev_state = LOW; // The previous state from the input pin int touch_state; // The current reading from the input pin void setup() { // Initialize the Serial to communicate with the Serial Monitor. Serial.begin(9600); // initialize the ESP8266 NodeMCU's pin as an input pinMode(SENSOR_PIN, INPUT); } void loop() { // read the state of the the input pin: touch_state = digitalRead(SENSOR_PIN); if(prev_state == LOW && touch_state == HIGH) Serial.println("The sensor is touched"); else if(prev_state == HIGH && touch_state == LOW) Serial.println("The sensor is released"); // save the the last state prev_state = touch_state; }

Detailed Instructions

  • Copy the code and open it with the Arduino IDE.
  • Click the Upload button on the Arduino IDE to compile and upload the code to the ESP8266.
  • Keep your finger touching the sensor.
  • Check out the result on the Serial Monitor.
COM6
Send
The sensor is touched
Autoscroll Show timestamp
Clear output
9600 baud  
Newline  
  • Remove your finger from the sensor.
  • Check the Serial Monitor for the result.
COM6
Send
The sensor is touched The sensor is released
Autoscroll Show timestamp
Clear output
9600 baud  
Newline  

Video Tutorial

Function References

※ OUR MESSAGES

  • As freelancers, We are AVAILABLE for HIRE. See how to outsource your project to us
  • Please feel free to share the link of this tutorial. However, Please do not use our content on any other websites. We invested a lot of effort and time to create the content, please respect our work!