วันจันทร์ที่ 23 กรกฎาคม พ.ศ. 2561

โปรเจค NodeMCU V3 กับ DHT22 แสดงอุณหภูมิและความชื้น

โปรเจค NodeMCU V3 กับ DHT22 แสดงอุณหภูมิและความชื้น

เมื่อ 5 เดือนที่ผ่านมา
โดย เจ้าของร้าน Google+


ในโปรเจคนี้เราจะสร้างเว็บเซิร์ฟเวอร์ ESP8266 โดยใช้ NodeMCU V3 กับ เซ็นเซอร์  DHT22 แสดงอุณหภูมิและความชื้น


อุปกรณ์ที่ใช้



1. NodeMCU V3 CH340G Lua WIFI ESP8266 ESP-12E

2. Micro USB Cable Wire 1m for NodeMCU

3. DHT22/AM2302 เซ็นเซอร์วัดอุณหภูมิและความชื้น

4. รีซิสเตอร์ 4.7K Ohm 1/4W 5%

5.  Breadboard 8.5CM x 5.5CM 400 holes (โฟโต้บอร์ด) จำนวน 2 ชิ้น

6. Jumper (M2M) cable 10 cm

7. รางถ่าน AA 6 ก้อน 9 โวลต์

8. แผ่นอะคริลิคใส ขนาด 10 x 12.5 เซนติเมตร



1. ประกอบ วงจร


ประกอบ  Breadboard 2 ชิ้น ลงบน แผ่นอะคริลิคใส ขนาด 10 x 12.5 เซนติเมตร
และ ประกอบ  NodeMCU V3 ลงบน Breadboard 



ประกอบวงจรตามรูป




เชื่อมต่อรางถ่าน เข้ากับ Breadboard



โดยสายสีแดง ไฟ+ ไปยังขา VIN ของ NodeMCU V3 และ สายสีดำ ไฟ- ไปยัง กราวด์ (GND) ของ Breadboard






2. ตรวจสอบการติดตั้งไดร์เวอร์ ของ NodeMCU V3 



เสียบสาย USB จากคอมพิวเตอร์ เข้ากับ NodeMCU V3



ตรวจสอบการติดตั้งไดร์เวอร์ ของ NodeMCU V3 

โดย 
คลิกขวา Computet -> Properties

 


คลิกที่ Device Manager


ที่ Ports (COM & LPT) จะพบ 
ไดร์เวอร์ ของ NodeMCU V3 

ในตัวอย่างเป็น USB -SERIAL CH340 (COM8)



(ถ้าไม่พบให้ทำการติดตั้งไดร์เวอร์ก่อน) 

ตัวอย่างการติดตั้งไดร์เวอร์ ชิฟ CH340G



3. ติดตั้ง แพลตฟอร์ม ESP8266


การจะใช้ NodeMCU ได้นั้น จำเป็นต้องติดตั้ง แพลตฟอร์ม ESP8266  เพื่อ ทำการติดต่อ ระหว่าง Arduino IDE กับ NodeMCU


ลิงค์ : ขั้นตอนการติดตั้ง แพลตฟอร์ม ESP8266


https://robotsiam.blogspot.com/2017/06/esp8266-platform-nodemcu.html



4. ติดตั้ง Library ของ DHT Sensor


การจะใช้ DHT22/AM2302 เซ็นเซอร์วัดอุณหภูมิและความชื้น ได้นั้น จำเป็นต้องติดตั้ง ไลบรารี DHT เพิ่มเข้าไปยัง Arduino IDE ของเรา


ลิงค์ : การติดตั้ง Library ของ DHT Sensor


5. อัพโหลด โค้ด


การกำหนดชื่อ Pin  นั้น  สามารถใช้ได้ 2 แบบ คือ แบบที่ 1 จะ อ้างตามชื่อ Pin บนบอร์ด NodeMCU  V3 เป็น D1 หรือ แบบที่ 2 เป็นการเทียบขา ตามรูปด้านล่าง โดยเลือกใช้ Pin เป็น  5  ก็ได้เช่นกัน



เสียบสาย USB จากคอมพิวเตอร์ เข้ากับ NodeMCU V3




เปิดโปรแกรม Arduino IDE ก๊อบปี้ โค้ด ด้านล่างไปยัง โปรแกรม ของ Arduino IDE


// Including the ESP8266 WiFi library
#include <ESP8266WiFi.h>
#include "DHT.h"

// Uncomment one of the lines below for whatever DHT sensor type you're using!
//#define DHTTYPE DHT11   // DHT 11
//#define DHTTYPE DHT21   // DHT 21 (AM2301)
#define DHTTYPE DHT22   // DHT 22  (AM2302), AM2321

// Replace with your network details
const char* ssid = "YOUR_NETWORK_NAME";
const char* password = "YOUR_NETWORK_PASSWORD";

// Web Server on port 80
WiFiServer server(80);

// DHT Sensor
const int DHTPin = 5; // D1
// Initialize DHT sensor.
DHT dht(DHTPin, DHTTYPE);

// Temporary variables
static char celsiusTemp[7];
static char fahrenheitTemp[7];
static char humidityTemp[7];

// only runs once on boot
void setup() {
  // Initializing serial port for debugging purposes
  Serial.begin(115200);
  delay(10);

  dht.begin();
  
  // Connecting to WiFi network
  Serial.println();
  Serial.print("Connecting to ");
  Serial.println(ssid);
  
  WiFi.begin(ssid, password);
  
  while (WiFi.status() != WL_CONNECTED) {
    delay(500);
    Serial.print(".");
  }
  Serial.println("");
  Serial.println("WiFi connected");
  
  // Starting the web server
  server.begin();
  Serial.println("Web server running. Waiting for the ESP IP...");
  delay(10000);
  
  // Printing the ESP IP address
  Serial.println(WiFi.localIP());
}

// runs over and over again
void loop() {
  // Listenning for new clients
  WiFiClient client = server.available();
  
  if (client) {
    Serial.println("New client");
    // bolean to locate when the http request ends
    boolean blank_line = true;
    while (client.connected()) {
      if (client.available()) {
        char c = client.read();
        
        if (c == '\n' && blank_line) {
            // Sensor readings may also be up to 2 seconds 'old' (its a very slow sensor)
            float h = dht.readHumidity();
            // Read temperature as Celsius (the default)
            float t = dht.readTemperature();
            // Read temperature as Fahrenheit (isFahrenheit = true)
            float f = dht.readTemperature(true);
            // Check if any reads failed and exit early (to try again).
            if (isnan(h) || isnan(t) || isnan(f)) {
              Serial.println("Failed to read from DHT sensor!");
              strcpy(celsiusTemp,"Failed");
              strcpy(fahrenheitTemp, "Failed");
              strcpy(humidityTemp, "Failed");         
            }
            else{
              // Computes temperature values in Celsius + Fahrenheit and Humidity
              float hic = dht.computeHeatIndex(t, h, false);       
              dtostrf(hic, 6, 2, celsiusTemp);             
              float hif = dht.computeHeatIndex(f, h);
              dtostrf(hif, 6, 2, fahrenheitTemp);         
              dtostrf(h, 6, 2, humidityTemp);
              // You can delete the following Serial.print's, it's just for debugging purposes
              Serial.print("Humidity: ");
              Serial.print(h);
              Serial.print(" %\t Temperature: ");
              Serial.print(t);
              Serial.print(" *C ");
              Serial.print(f);
              Serial.print(" *F\t Heat index: ");
              Serial.print(hic);
              Serial.print(" *C ");
              Serial.print(hif);
              Serial.print(" *F");
              Serial.print("Humidity: ");
              Serial.print(h);
              Serial.print(" %\t Temperature: ");
              Serial.print(t);
              Serial.print(" *C ");
              Serial.print(f);
              Serial.print(" *F\t Heat index: ");
              Serial.print(hic);
              Serial.print(" *C ");
              Serial.print(hif);
              Serial.println(" *F");
            }
            client.println("HTTP/1.1 200 OK");
            client.println("Content-Type: text/html");
            client.println("Connection: close");
            client.println();
            // your actual web page that displays temperature and humidity
            client.println("<!DOCTYPE HTML>");
            client.println("<html>");
            client.println("<head></head><body><h1>RobotSiam - Temperature and Humidity</h1><h3>Temperature in Celsius: ");
            client.println(celsiusTemp);
            client.println("*C</h3><h3>Temperature in Fahrenheit: ");
            client.println(fahrenheitTemp);
            client.println("*F</h3><h3>Humidity: ");
            client.println(humidityTemp);
            client.println("%</h3><h3>");
            client.println("</body></html>");     
            break;
        }
        if (c == '\n') {
          // when starts reading a new line
          blank_line = true;
        }
        else if (c != '\r') {
          // when finds a character on the current line
          blank_line = false;
        }
      }
    }  
    // closing the client connection
    delay(1);
    client.stop();
    Serial.println("Client disconnected.");
  }
}   



ก่อนการอัพโหลดต้องแก้ไขโค้ด ตรงสีแดงให้ถูกต้องก่อน โดย

ssid = "ชื่อwifiที่ต้องการเชื่อมต่อ"
password =  "รหัสผ่าน"

 

เลือก Port ในตัวอย่างเป็น "COM8"



เลือก Board : NodeMCU 1.0 (ESP-12E Module)



อัพโหลด.... (ควรต่อไฟเข้า 9 
โวลต์ ที่ขา VIN และ GND  ขณะอัพโหลดด้วย)


รอจนกระทั่ง Done uploading. 100%


ไปที่ Serial Monitor




เลือก Both NL & CR และ เลือก 115200 baud



กดปุ่ม RST (อยู่ด้านล่างซ้ายมือ) 1 ครั้ง



Serial Monitor จะแสดง ไอพี ของ NodeMCU V3 ในตัวอย่างคือ 192.168.1.40



ไปที่ บราวเซอร์ ที่ URL ป้อน 192.168.1.40 ที่ได้จาก Serial Monitor ด้านบน

(ไอพีที่ได้แต่ละครั้งอาจจะไม่เหมือนกัน ให้ตรวจสอบทุกครั้ง)


เมื่อกลับไปดูที่ Serial Monitor จะ แสดงอุณหภูมิและความชื้น เพิ่มเข้ามา แสดงว่าโปรเจคของเรานั้นพร้อมทำงานแล้ว


6. ทดสอบการทำงานของโปรเจค


ถอด
สาย USB จากคอมพิวเตอร์ ออกจาก NodeMCU V3


 
ไปที่ บราวเซอร์ ที่ URL ป้อน 192.168.1.40 ที่ได้จาก Serial Monitor ด้านบน 

ใช้ ไดร์เป่าผม เป่าลมร้อน ไปที่ DHT22  กด F5 หรือ refresh บราวเซอร์ จะแสดง อุณหภูมิ ที่เพิ่มขึ้น และ เมื่อเปลี่ยนมาเป่าลมเย็น กด F5 หรือ refresh บราวเซอร์ ก็จะแสดง อุณหภูมิ ที่ลดลง 



วีดีโอผลลัพธ์การทำงานของ โปรเจค NodeMCU V3 กับ DHT22 แสดงอุณหภูมิและความชื้น

โปรเจค NodeMCU + Relay ควบคุมอุปกรณ์ไฟฟ้า ผ่าน WiFi

โปรเจค NodeMCU + Relay ควบคุมอุปกรณ์ไฟฟ้า ผ่าน WiFi

เมื่อ 5 เดือนที่ผ่านมา
โดย เจ้าของร้าน Google+



โปรเจค นี้จะเป็นการนำ  ESP8266 NodeMCU V3 และ Relay 
ควบคุมการเปิดปิด อุปกรณ์ไฟฟ้า AC 220V  ผ่าน WiFi ด้วยโทรศัพท์ Android และแสดง ไอพี ของ NodeMCU ที่ OLED Display

ควบคุมทุกสรรพสิ่งภายในบ้านของคุณด้วย ESP8266 NodeMCU หรือ Home Automation ระบบนี้เป็นระบบที่ใช้ควบคุมอุปกรณ์ไฟฟ้าต่างๆผ่าน WiFi โดยที่สามารถควบคุมได้ผ่านระบบอินทราเน็ต (ที่ใช้ WiFi  หรือ วง แลน หรือใช้ เราเตอร์ เดียวกัน เท่านั้น) โดยที่ใช้ NodeMCU เป็น Server Controller


.

อุปกรณ์ที่ใช้



1. NodeMCU V3 CH340G Lua WIFI ESP8266 ESP-12E

2. Micro USB Cable Wire 1m for NodeMCU

3. NodeMcu Breadboard for NodeMCU V3

4. Blue OLED Display 0.96 inch 128X64 Module

5. Relay 4 Channel 5V DC Solid State Active High Module

6. Adapter DC 9V 1A Power Supply

7. Jumper (F2F) cable 20cm Female to Female

8. เสารองแผ่นพีซีบีโลหะแบบเหลี่ยม 8 mm.

9. เสารองแผ่นพีซีบีแบบโลหะ ยาว 25 มม.

10.

11.

.


1. ประกอบวงจร

 

การเชื่อมต่อระหว่าง NodeMcu Breadboard กับ Blue OLED Display

 

 

การเชื่อมต่อระหว่าง NodeMcu Breadboard กับ Relay 4 Channel

 

 

 















ประกอบ NodeMCU เข้ากับ 
Breadboard



ภาพรวมการประกอบ

 


2. อัพโหลดโปรแกรม

 

 

เชื่อมต่อ สาย USB ระหว่าง คอมพิวเตอร์ กับ  NodeMCU 


ป้อนไฟ 9 โวลต์ จาก อะแด็ปเตอร์ เข้าสู่ ซัพพลาย ของ Breadboard NodeMCU V3



2.1 ตรวจสอบการติดตั้งไดร์เวอร์ ของ NodeMCU V3 


โดย 
คลิกขวา Computet -> Properties


 
คลิกที่ Device Manager


ที่ Ports (COM & LPT) จะพบ 
ไดร์เวอร์ ของ NodeMCU V3

ในตัวอย่างเป็น USB -SERIAL CH340 (COM8)



(ถ้าไม่พบให้ทำการติดตั้งไดร์เวอร์ก่อน) 
 


2.2 ติดตั้ง แพลตฟอร์ม ESP8266


การจะใช้ NodeMCU ได้นั้น จำเป็นต้องติดตั้ง แพลตฟอร์ม ESP8266  เพื่อ ทำการติดต่อ ระหว่าง Arduino IDE กับ NodeMCU


ลิงค์ : ขั้นตอนการติดตั้ง แพลตฟอร์ม ESP8266



2.3 ติดตั้ง Library ของ  Blue OLED Display



ดาวน์โหลด Library ของ  Blue OLED Display Module


 2.3.1 ดาวน์โหลด ไลบรารี่ Adafruit-GFX-Library


https://github.com/adafruit/Adafruit-GFX-Library

เพิ่ม ไลบรารี่ Adafruit-GFX-Library เข้าที่ Arduino IDE 
โดย ไปที่ Sketch -> Include Library -> Add.ZIP 
Library....




เลือกซิปไฟล์ Adafruit-GFX-library-master ที่ดาวน์โหลดมา


เมื่อตรวจสอบ ที่ Sketch -> Include Library -> จะพบ Adafruit GFX Library เพิ่มเข้ามาที่ Arduino IDE


2.3.2 ดาวน์โหลด ไลบรารี่ Adafruit_SSD1306


https://github.com/adafruit/Adafruit_SSD1306


เพิ่ม ไลบรารี่ Adafruit_SSD1306 เข้าที่ Arduino IDE

โดย ไปที่ Sketch -> Include Library -> Add.ZIP 
Library....



เลือก ซิปไฟล์ Adafruit_SDD1306-master ที่ดาวน์โหลดมา




เมื่อตรวจสอบ ที่ Sketch -> Include Library -> จะพบ Adafruit_SDD1306  เพิ่มเข้ามาที่ Arduino IDE



2.3.4 ดาวน์โหลด ไลบรารี่ ESP_Adafruit_SSD1306

การใช้งาน OLED Display กับ ESP8266 นั้น จำเป็นต้องติดตั้ง ไลบรารี่ ESP_Adafruit_SSD1306 เพิ่มเข้ามาอีกหนึ่งขั้นตอน


ดาวน์โหลด ไลบรารี่ ESP_Adafruit_SSD1306

https://github.com/cmmakerclub/ESP_Adafruit_SSD1306


เพิ่ม ไลบรารี่ ESP_Adafruit_SSD1306 เข้าที่ Arduino IDEโดย 

ไปที่ Sketch -> Include Library -> Add.ZIP 
Library....



เลือก ซิปไฟล์ ESP_Adafruit_SSD1306-master ที่ดาวน์โหลดมา




ถึงขัั้นตอนนี้ Arduino IDE ของเราก็พร้อมที่จะทำงานในขั้นตอนต่อไป



2.4 อัพโหลดโปรแกรม-ควบคุมอุปกรณ์ไฟฟ้า


การใช้งาน Digital I/O ของ ESP8266 
NodeMCU V3 นั้น สามารถ ใช้งานคำสั่ง digitalWrite, digitalRead ได้เช่นเดียวกับการใช้งาน Digital I/O ของ Arduino โดยกำหนดหมายเลขของ Pin เช่นตัวอย่าง Pin ที่  14 หรือจะกำหนดชื่อ Pin โดยอ้างตามชื่อ Pin บนบอร์ด NodeMCU  V3 เป็น D5 ก็ได้เช่นกัน


เปิดโปรแกรม Arduino (IDE) และ ก็อปปี้ โค้ดด้านล่างนี้ ไปวางไว้ในส่วนเขียนโปรแกรม



#include <ESP8266WiFi.h>
#include <WiFiClient.h>
#include <ESP8266WebServer.h>
#include <ESP8266mDNS.h>
#include <Adafruit_GFX.h>
#include <ESP_Adafruit_SSD1306.h>

#define OLED_RESET 4
Adafruit_SSD1306 display(OLED_RESET);



#if (SSD1306_LCDHEIGHT != 64)
#error("Height incorrect, please fix Adafruit_SSD1306.h!");
#endif

const char* ssid = "YOUR_NETWORK_NAME";
const char* password = "YOUR_NETWORK_PASSWORD";

ESP8266WebServer server(80);

const int output1 = 14; // D5
const int output2 = 12; // D6
const int output3 = 13; // D7
const int output4 = 15; // D8

boolean device1 = false;
boolean device2 = false;
boolean device3 = false;
boolean device4 = false;

void handleRoot() {
  //digitalWrite(led, 1);
  //server.send(200, "text/plain", "hello from esp8266!");
  //digitalWrite(led, 0);

  String cmd;   
      cmd += "<!DOCTYPE HTML>\r\n";
      cmd += "<html>\r\n";
      //cmd += "<header><title>ESP8266 Webserver</title><h1>\"ESP8266 Web Server Control\"</h1></header>";
      cmd += "<head>";
      cmd += "<meta http-equiv='refresh' content='5'/>";
      cmd += "</head>";
    
      if(device1){
        cmd +=("<br/>Device1  : ON");
      }
      else{
        cmd +=("<br/>Device1  : OFF");
      }
    
      if(device2){
        cmd +=("<br/>Device2  : ON");
      }
      else{
        cmd +=("<br/>Device2  : OFF");
      }
          
       if(device3){
        cmd +=("<br/>Device3  : ON");
      }
      else{
        cmd +=("<br/>Device3  : OFF");
      }
    
      if(device4){
        cmd +=("<br/>Device4  : ON");
      }
      else{
        cmd +=("<br/>Device4  : OFF");
      }
          
      cmd += "<html>\r\n";
      server.send(200, "text/html", cmd);
}

void handleNotFound(){
  //digitalWrite(led, 1);
  String message = "File Not Found\n\n";
  message += "URI: ";
  message += server.uri();
  message += "\nMethod: ";
  message += (server.method() == HTTP_GET)?"GET":"POST";
  message += "\nArguments: ";
  message += server.args();
  message += "\n";
  for (uint8_t i=0; i<server.args(); i++){
    message += " " + server.argName(i) + ": " + server.arg(i) + "\n";
  }
  server.send(404, "text/plain", message);
  //digitalWrite(led, 0);
}

void setup(void){
  pinMode(output1, OUTPUT);
  pinMode(output2, OUTPUT);
  pinMode(output3, OUTPUT);
  pinMode(output4, OUTPUT);

  digitalWrite(output1, LOW);
  digitalWrite(output2, LOW);
  digitalWrite(output3, LOW);
  digitalWrite(output4, LOW);
  
  Serial.begin(115200);
  WiFi.begin(ssid, password);
  Serial.println("");


  // by default, we'll generate the high voltage from the 3.3v line internally! (neat!)
  //display.begin(SSD1306_SWITCHCAPVCC, 0x3D);      // initialize with the I2C addr 0x3D (for the 128x64)
  display.begin(SSD1306_SWITCHCAPVCC, 0x78>>1);     // init done

  display.clearDisplay();                 // Clear the buffer.
  
  display.setTextSize(2);
  display.setTextColor(WHITE);
  //display.setTextColor(BLACK, WHITE);   // 'inverted' text
  display.setCursor(0,0);
  display.println("  ESP8266");

  display.setTextSize(3);                                  //Size4 = 5 digit , size3 = 7 digits
  //display.setTextColor(BLACK, WHITE);   // 'inverted' text
  display.setTextColor(WHITE);
  display.setCursor(0,18);
  display.println("Control");
  
  display.setTextSize(1);
  display.setTextColor(WHITE);
  //display.setTextColor(BLACK, WHITE); // 'inverted' text
  display.setCursor(0,52);
  display.println("Version 0.1");

  display.display();
  delay(2000);

    display.clearDisplay();
  
    display.setTextSize(2);
    display.setTextColor(WHITE);
    //display.setTextColor(BLACK, WHITE); // 'inverted' text
    display.setCursor(0,0);
    display.println("Connecting");


  // Wait for connection
  while (WiFi.status() != WL_CONNECTED) {
    delay(500);
    Serial.print(".");

    display.print(".");
    display.display();
  }
  Serial.println("");
  Serial.print("Connected to ");
  Serial.println(ssid);
  Serial.print("IP address: ");
  Serial.println(WiFi.localIP());

  display.clearDisplay();   
  display.setTextSize(1);       display.setTextColor(WHITE); 
  display.setCursor(0,0);       display.println(ssid); 
  display.setTextSize(2);       display.setTextColor(WHITE);
  display.setCursor(0,18);      display.println(WiFi.localIP());
  //display.setCursor(0,36);      display.println(WiFi.localIP());

  display.display();



  if (MDNS.begin("esp8266")) {
    Serial.println("MDNS responder started");
  }

  server.on("/", handleRoot);

  server.on("/status1=1", [](){
    server.send(200, "text/plain", "device1 = ON");
    digitalWrite(output1, HIGH);
    device1 = true;
  });

  server.on("/status1=0", [](){
    server.send(200, "text/plain", "device1 = OFF");
    digitalWrite(output1, LOW);
    device1 = false;
  });

  server.on("/status2=1", [](){
    server.send(200, "text/plain", "device2 = ON");
    digitalWrite(output2, HIGH);
    device2 = true;
  });

  server.on("/status2=0", [](){
    server.send(200, "text/plain", "device2 = OFF");
    digitalWrite(output2, LOW);
    device2 = false;
  });

  server.on("/status3=1", [](){
    server.send(200, "text/plain", "device3 = ON");
    digitalWrite(output3, HIGH);
    device3 = true;
  });

  server.on("/status3=0", [](){
    server.send(200, "text/plain", "device3 = OFF");
    digitalWrite(output3, LOW);
    device3 = false;
  });

  server.on("/status4=1", [](){
    server.send(200, "text/plain", "device4 = ON");
    digitalWrite(output4, HIGH);
    device4 = true;
  });

  server.on("/status4=0", [](){
    server.send(200, "text/plain", "device4 = OFF");
    digitalWrite(output4, LOW);
    device4 = false;
  });

  server.onNotFound(handleNotFound);
  server.begin();
  Serial.println("HTTP server started");
}

void loop(void){
  server.handleClient();
}


...

ก่อนการอัพโหลดต้องแก้ไขโค้ด ตรงสีแดงให้ถูกต้องก่อน โดย


"
YOUR_NETWORK_NAME" คือ ชื่อWiFiที่ต้องการเชื่อมต่อ


"
YOUR_NETWORK_PASSWORD" คือ รหัสผ่าน





เลือก Port ในตัวอย่างเป็น "COM8"



เลือก Board : NodeMCU 1.0 (ESP-12E Module)


อัพโหลด....



รอจนกระทั่ง Done uploading. 100%


OLED Display จะแสดง ไอพี ของ  
NodeMCU V3 ในตัวอย่างเป็น 192.168.1.41



...

5. ติดตั้งแอพควบคุม


ใช้สมาร์ทโฟน Android ไปที่  Play Store

ค้นหา esp8266 wifi control เลือกแอพ ด้านบนตามรูป





การติดตั้ง..เหมือน
แอพทั่วๆไป

เมื่อเปิด.. แอพขึ้นมา 
คลิกที่ CONNECT



แอพจะให้ป้อน IP Address และ Port



IP Address ป้อน IP ที่ได้จาก OLED Display ในตัวอย่างเป็น 192.168.1.41
และ Port เป็น 80 -> SAVE



แอพ จะ แสดงการเชื่อมต่อ กับ IP 192.168.1.41
คลิกที่ CONNECT TO


จะแสดง ปุ่ม ในการควบคุม



โดยเมื่อ ให้ POWER ON 
LED ของ Relay ช่องที่1 จะติด



เมื่อ แตะ ให้ POWER ON ทั้ง 4


LED ของ Relay ช่องที่ 1 ถึง 4 จะติด

งานที่ 5

การบริหารงานคุณภาพเทคโนโลยีและสารสนเทศคือ   ISO 9001-2000  ในด้านคุณภาพการผลิตและบริการ ซึ่งเป็นมาตราฐานสากลที่องค์กรธุรกิจทั่วโลกให้คว...