https://adventure.ports.network
Developers to Join
adventures
/how-to
Simple Project TO START CODING.
1X LED LIGHT (RGB LED LIGHT-CATHODE)
1X ESP32 MICROCONTROLLER
Parts required to this project
1X USB CABLE TO CONNECT YOUR ESP32 TO YOUR PC .
3 X WIRES
3 X RESISTORS ( 220 ohms )
1 X CAPACITOR (10UF )
HARDWARE
SOFTWARE
ARDUINO IDE SOFTWARE
ARDUINO LIBRARY :
wifi.h
1 X BREAD BOARD ( 400 DOTS )
Wireless Web Server to turn ON/OFF Led Light
(STA MODE )
ASSEMBLY THE PARTS
CHECK THE IMAGES TO ASSEMBLY THE PARTS:
( All parts required )
( RGB LED Light (CATHODE) )
( 220 ohm Resistors )
(10uf Capacitor )
Image 3
Image 2
Image 4
Image 1
( Wiring )
Image 5
COMPILING AND UPLOADING THE CODE
AFTER INSTALL THE ARDUINO IDE SOFTWARE,
SOME LIBRARIES ARE REQUIRED TO GET THE WEBSERVER WORKING .
GO TO ARDUINO HOMEPAGE AND DOWNLOAD THE ARDUINO IDE SOFTWARE .
EASY STEP TO STEP , HOW TO UPLOAD THE CODE TO THE ESP32 BOARD .
STEP 1
STEP 2
STEP 3
INSTALL THE ARDUINO IDE SOFTWARE  TO YOUR COMPUTER
LIBRARY REQUIRED
wifi.h
// Load Wi-Fi library
#include <WiFi.h>
// Replace with your network credentials
const char* ssid = "SSID*******";
const char* password = "PASSWORD*******";
//
// Set web server port number to 80
WiFiServer server(80);
// Variable to store the HTTP request
String header;
// Auxiliary variables to store the current output state
String outputLEDstate = "off";
// Assign output variables to GPIO pins
//Setup the Led Light - Assign output variables to GPIO pins
uint8_t ledR = 16;
uint8_t ledG = 17;
uint8_t ledB = 5;
uint8_t ledArray[3] = {1, 2, 3}; // three led channels
const boolean invert = false; // set true if common anode, false if common cathode - "d-o-t.link uses common cathode".
uint8_t color = 0;          // a value from 0 to 255 representing the hue
uint32_t R, G, B;           // the Red Green and Blue color components
uint8_t brightness = 255;  // 255 is maximum brightness, but can be changed.  Might need 256 for common anode to fully turn off.
//
// Current time
unsigned long currentTime = millis();
// Previous time
unsigned long previousTime = 0;
// Define timeout time in milliseconds (example: 2000ms = 2s)
const long timeoutTime = 2000;
//
void setup() {
  Serial.begin(115200);
  delay(10);
  //
  //Setup the Led light
  ledcAttachPin(ledR, 1); // assign RGB led pins to channels
  ledcAttachPin(ledG, 2);
  ledcAttachPin(ledB, 3);
  ledcSetup(1, 12000, 8); // 12 kHz PWM, 8-bit resolution
  ledcSetup(2, 12000, 8);
  ledcSetup(3, 12000, 8);
  //
  // Connect to Wi-Fi network with SSID and password
  Serial.print("Connecting to ");
  Serial.println("Wifi Network ");
  Serial.println(ssid);
  WiFi.begin(ssid, password);
  while (WiFi.status() != WL_CONNECTED) {
    delay(500);
    Serial.print(".");
  }
  // Print local IP address and start web server
  Serial.println("");
  Serial.println("WiFi connected.");
  Serial.println("IP address: ");
  Serial.println(WiFi.localIP());
  server.begin();
}
void loop(){
  WiFiClient client = server.available();   // Listen for incoming clients
  if (client) {                             // If a new client connects,
    currentTime = millis();
    previousTime = currentTime;
    Serial.println("New Client.");          // print a message out in the serial port
    String currentLine = "";                // make a String to hold incoming data from the client
    while (client.connected() && currentTime - previousTime <= timeoutTime) {  // loop while the client's connected
      currentTime = millis();
      if (client.available()) {             // if there's bytes to read from the client,
        char c = client.read();             // read a byte, then
        Serial.write(c);                    // print it out the serial monitor
        header += c;
        if (c == '\n') {                    // if the byte is a newline character
          // if the current line is blank, you got two newline characters in a row.
          // that's the end of the client HTTP request, so send a response:
          if (currentLine.length() == 0) {
            // HTTP headers always start with a response code (e.g. HTTP/1.1 200 OK)
            // and a content-type so the client knows what's coming, then a blank line:
            client.println("HTTP/1.1 200 OK");
            client.println("Content-type:text/html");
            client.println("Connection: close");
            client.println();
            // turns the GPIOs on and off
            if (header.indexOf("GET /led/on") >= 0) {
              Serial.println("GPIO Status | on");
              outputLEDstate = "on";
              // Section to Control the Led Light .
              // check the color hue chart to change the color of the LED. Lots of colors to play with.
              ledcWrite(1, 255); // change the value from 0 to 255, and change the color hue .
              ledcWrite(2, 20);  // change the value from 0 to 255, and change the color hue .
              ledcWrite(3, 10);  // change the value from 0 to 255, and change the color hue .
             
            } else if (header.indexOf("GET /led/off") >= 0) {
              Serial.println("GPIO Status | off");
              outputLEDstate = "off";
              ledcWrite(1, 0); // 0 to turn the led off.
              ledcWrite(2, 0); // 0 to turn the led off.
              ledcWrite(3, 0); // 0 to turn the led off.
            }
            // Display the HTML web page - Powered by logicmetry.co.uk - d-o-t.link
            client.println("<!doctype html>");
            client.println("<html>");
            client.println("<head>");
            client.println("<meta charset=\"utf-8\">");
            client.println("<head><meta name=\"d-o-t-link\" content=\"width=device-width, initial-scale=2\">");
            client.println("<title>d-o-t.link</title>");
            // CSS to style the on/off buttons and other HTML elements
            client.println("<style>");
            client.println("html { font-family: Calibri; display: inline-block;  text-align: center;}");
            client.println(".box {");
            client.println("position:relative;");
            client.println("margin:auto;");
            client.println("margin-top:0px;");
            client.println("width:350px;");
            client.println("height:100px;");
            client.println("border: none;");
            client.println("}");
            client.println(".links {");
            client.println("position:relative;");
            client.println("width:200px;");
            client.println("height:100px;");
            client.println("border: none;");
            client.println("background: url() no-repeat;");
            client.println("background-size: auto;");
            client.println("cursor: pointer;");
            client.println("z-index:10;");
            client.println("}");
            client.println(".links:active {");
            client.println("transform:scale(1.1);");
            client.println("}");
            client.println(".links1 {");
            client.println("margin-left:0px;");
            client.println("left:0%;");
            client.println("top:0%;");
            client.println("filter: grayscale(100%);");
            client.println("}");
            client.println(".links2 {");
            client.println("margin-left:0px;");
            client.println("left:19%;");
            client.println("top:0%;");
            client.println("filter: grayscale(10%);");
            client.println("}");
            client.println(".battery{");
            client.println("position:relative;");
            client.println("left:170px;");
            client.println("top:-97px;");
            client.println("width:200px;");
            client.println("height:100px;");
            client.println("border: none;");
            client.println("background: url() no-repeat;");
            client.println("cursor: pointer;");
            client.println("z-index: 20;");
            client.println("}");
            client.println(".spn1 {");
            client.println("position:relative;");
            client.println("left:25px ;");
            client.println("top:30px ;");
            client.println("color: black;");
            client.println("font-size:30px;");
            client.println("box-sizing:border-box;");
            client.println("}");
            client.println(".txtbox {");
            client.println("position:relative;");
            client.println("left:0px ;");
            client.println("top:-100% ;");
            client.println("color: black;");
            client.println("font-size:30px;");
            client.println("display:inline-block;");
            client.println("border:1p solid black;");
            client.println("box-sizing:border-box;");
            client.println("}");
            client.println(".txtbox1 {");
            client.println("background-color: lightgray;");
            client.println("}");
            client.println(".txtbox2 {");
            client.println("background-color: lightgreen;");
            client.println("}");
            client.println("@keyframes move1 {");
            client.println("from {left: 0%;}");
            client.println("to {left: 19%;}");
            client.println("}");
            client.println("@keyframes move2 {");
            client.println("from {left: 19%;}");
            client.println("to {left: 0%;}");
            client.println("}");
            client.println(".edit-text {");
            client.println("-webkit-user-select: none;");
            client.println("-ms-user-select: none;");
            client.println("user-select: none;");
            client.println("}");
            client.println("</style>");
            client.println("</head>");
            // Web Page Heading
            client.println("<body>");
            client.println("<h1>Web Server</h1>");
            // Display current state, and ON/OFF buttons for GPIOs 
            client.println("<p>Status " + outputLEDstate + "</p>");
            // If the outputLEDstate is off, it displays the ON button 
            if (outputLEDstate=="off") {
            client.println("<div id=\"divbox\"class=\"box\">");
            client.println("<div id=\"div1\"class=\"links links1 edit-text\" onclick=\"clickfunction()\"><span id=\"spn\" class=\"spn1\">link</span></div>");
            client.println("<div id=\"div2\"class=\"battery\" ></div>");
            client.println("<p id=\"txt\"class=\"txtbox txtbox1\">DISCONNECTED</p>");
            client.println("</div>");
            // java script - the java script is in this section to make the code easier to read .
            client.println("<script>");
            client.println("const element = document.getElementById(\"div1\");");
            client.println("const text = document.getElementById(\"txt\");");
            client.println("function clickfunction() {");
            client.println("element.style.animation = \"move1 0.5s 1\";");
            client.println("}");
            client.println("element.addEventListener(\"animationend\", clickfunction2);");
            client.println("function clickfunction2() {");
            client.println("text.innerHTML = \"CONNECTED\";");
            client.println("text.style.backgroundColor = \"lightgreen\";");
            client.println("element.style.left = \"19%\";");
            client.println("element.style.filter = \"grayscale(10%)\";");
            client.println("window.location.href = \"/led/on\";");
            client.println("}");
            client.println("</script>");
            } else {
            client.println("<div id=\"divbox\"class=\"box\">");
            client.println("<div id=\"div1\"class=\"links links2 edit-text\" onclick=\"clickfunction()\"><span id=\"spn\" class=\"spn1\">link</span></div>");
            client.println("<div id=\"div2\"class=\"battery\" ></div>");
            client.println("<p id=\"txt\"class=\"txtbox txtbox2\">CONNECTED</p>");
            client.println("</div>");
            // java script - the java script is in this section to make the code easier to read.
            client.println("<script>");
            client.println("const element = document.getElementById(\"div1\");");
            client.println("const text = document.getElementById(\"txt\");");
            client.println("function clickfunction() {");
            client.println("element.style.animation = \"move2 0.5s 1\";");
            client.println("}");
            client.println("element.addEventListener(\"animationend\", clickfunction2);");
            client.println("function clickfunction2() {");
            client.println("text.innerHTML = \"DISCONNECTED\";");
            client.println("text.style.backgroundColor = \"lightgray\";");
            client.println("element.style.left = \"0%\";");
            client.println("element.style.filter = \"grayscale(100%)\";");
            client.println("window.location.href = \"/led/off\";");
            client.println("}");
            client.println("</script>");
            }
            client.println("</body>");
            client.println("</html>");
            // The HTTP response ends with another blank line
            client.println();
            // Break out of the while loop
            break;
          } else { // if you got a newline, then clear currentLine
            currentLine = "";
          }
        } else if (c != '\r') {  // if you got anything else but a carriage return character,
          currentLine += c;      // add it to the end of the currentLine
        }
      }
    }
    // Clear the header variable
    header = "";
    // Close the connection
    client.stop();
    Serial.println("Client disconnected.");
    Serial.println("");
  }
}
COPY AND PASTE THE CODE IN THE ARDUINO IDE SOFTWARE
STEP 4
CHANGE THE SSID AND THE PASSWORD TO YOUR WIFI .
STEP 5
STEP 6
UPLOAD THE CODE .
STEP 7
Open the Serial Monitor in the Arduino IDE Software to Find the IP address of the ESP32 board.
Select the Baud rate of 115200 from the dropdown list in the bottom right corner of the Serial monitor, as the picture .
STEP 8
a - Reset the Esp32 board by pressing the EN[RST] button on the board.
  b - Wait for the ESP32 board to connect to the Wifi network.
    c - The Serial Monitor will display messages to indicate the connection progress .
STEP 9
STEP 10
Once the Esp32 board is connected to the Wifi network, the Serial Monitor will display the IP address of the ESP32 board .
Connecting to the ESP32 WEB SERVER and Testing
Open the webbrowser on your computer or mobile device and enter the Ip address of the ESP32 board given in the Serial Monitor .
Web Browser URL address bar
(example)
(example)
(example)
i-o-s.link start page .
Click on i-o-s.link to connect and turn on the Led light .
have fun