Lập trình & Điều khiển Động Cơ – Bài 7: Điều khiển xe robot bằng điện thoại qua WiFi (Web Remote)

(Khóa học: Lập trình & Điều khiển Động Cơ từ Cơ Bản tới Nâng Cao)


📘 Giới thiệu

Ở các bài trước, xe robot của bạn đã tự tránh vật cản.

Bây giờ, chúng ta sẽ điều khiển robot thủ công bằng điện thoại, thông qua mạng WiFi của ESP32.

Bài học này giúp bạn hiểu cách tạo giao diện web đơn giản (Web Remote) để gửi lệnh điều khiển tiến – lùi – rẽ – dừng tới robot. Đây là bước đầu tiên để phát triển robot điều khiển từ xa qua Internet hoặc ứng dụng di động.

⚙️ 1. Nguyên lý hoạt động

  • ESP32 hoạt động như Web Server nội bộ (Access Point hoặc STA).
  • Khi bạn truy cập địa chỉ IP của ESP32 từ điện thoại, trang web hiển thị các nút:
    🔼 Tiến | 🔽 Lùi | ◀️ Trái | ▶️ Phải | ⏹️ Dừng
  • Khi nhấn nút, lệnh được gửi qua HTTP → ESP32 nhận và điều khiển L298N → động cơ hoạt động tương ứng.

🌐 2. Sơ đồ kết nối phần cứng

ESP32 PinL298N PinChức năng
GPIO26IN1Motor trái chiều 1
GPIO27IN2Motor trái chiều 2
GPIO25IN3Motor phải chiều 1
GPIO33IN4Motor phải chiều 2
GPIO14ENAPWM Motor trái
GPIO32ENBPWM Motor phải
5V, GNDL298N 5V, GNDNối nguồn chung

💻 3. Code mẫu: Web điều khiển xe robot qua WiFi

/*
 * Bài 7 - IoTLabs Motor Course
 * Điều khiển xe robot bằng Web Server qua WiFi (ESP32)
 */

#include <WiFi.h>
#include <WebServer.h>

const char* ssid = "IoTLabs_Robot";
const char* password = "12345678";

WebServer server(80);

#define IN1 26
#define IN2 27
#define IN3 25
#define IN4 33
#define ENA 14
#define ENB 32

#define PWM_FREQ 5000
#define PWM_RES 8

void setupMotors() {
  pinMode(IN1, OUTPUT); pinMode(IN2, OUTPUT);
  pinMode(IN3, OUTPUT); pinMode(IN4, OUTPUT);
  ledcSetup(0, PWM_FREQ, PWM_RES);
  ledcSetup(1, PWM_FREQ, PWM_RES);
  ledcAttachPin(ENA, 0);
  ledcAttachPin(ENB, 1);
}

void goForward() {
  digitalWrite(IN1, HIGH); digitalWrite(IN2, LOW);
  digitalWrite(IN3, HIGH); digitalWrite(IN4, LOW);
  ledcWrite(0, 200); ledcWrite(1, 200);
}

void goBackward() {
  digitalWrite(IN1, LOW); digitalWrite(IN2, HIGH);
  digitalWrite(IN3, LOW); digitalWrite(IN4, HIGH);
  ledcWrite(0, 200); ledcWrite(1, 200);
}

void turnLeft() {
  digitalWrite(IN1, LOW); digitalWrite(IN2, HIGH);
  digitalWrite(IN3, HIGH); digitalWrite(IN4, LOW);
  ledcWrite(0, 200); ledcWrite(1, 200);
}

void turnRight() {
  digitalWrite(IN1, HIGH); digitalWrite(IN2, LOW);
  digitalWrite(IN3, LOW); digitalWrite(IN4, HIGH);
  ledcWrite(0, 200); ledcWrite(1, 200);
}

void stopMotor() {
  digitalWrite(IN1, LOW); digitalWrite(IN2, LOW);
  digitalWrite(IN3, LOW); digitalWrite(IN4, LOW);
  ledcWrite(0, 0); ledcWrite(1, 0);
}

String htmlPage() {
  String html = "<html><body style='text-align:center;'>";
  html += "<h2>🚗 IoTLabs Robot Control</h2>";
  html += "<button onclick=\"location.href='/forward'\">⬆ Tiến</button><br><br>";
  html += "<button onclick=\"location.href='/left'\">⬅ Trái</button>";
  html += "<button onclick=\"location.href='/stop'\">⏹ Dừng</button>";
  html += "<button onclick=\"location.href='/right'\">Phải ➡</button><br><br>";
  html += "<button onclick=\"location.href='/back'\">⬇ Lùi</button>";
  html += "</body></html>";
  return html;
}

void setup() {
  Serial.begin(115200);
  setupMotors();

  WiFi.softAP(ssid, password);
  Serial.println("Access Point Started!");
  Serial.println(WiFi.softAPIP());

  server.on("/", []() { server.send(200, "text/html", htmlPage()); });
  server.on("/forward", []() { goForward(); server.send(200, "text/html", htmlPage()); });
  server.on("/back", []() { goBackward(); server.send(200, "text/html", htmlPage()); });
  server.on("/left", []() { turnLeft(); server.send(200, "text/html", htmlPage()); });
  server.on("/right", []() { turnRight(); server.send(200, "text/html", htmlPage()); });
  server.on("/stop", []() { stopMotor(); server.send(200, "text/html", htmlPage()); });

  server.begin();
}

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

Kết quả:

  • Điện thoại kết nối WiFi: IoTLabs_Robot → Mở trình duyệt nhập IP (ví dụ: 192.168.4.1).
  • Giao diện xuất hiện 5 nút điều khiển.
  • Khi nhấn, robot di chuyển tương ứng theo lệnh.

🧠 4. Giải thích

  • WiFi.softAP() tạo mạng WiFi riêng của ESP32.
  • WebServer server(80) khởi tạo server trên cổng 80.
  • Mỗi server.on() là một endpoint cho một nút bấm.
  • Giao diện được sinh trực tiếp bằng HTML gửi từ ESP32.

🎯 5. Mục tiêu học tập

  • Hiểu cách ESP32 tạo web server điều khiển thiết bị.
  • Thiết kế giao diện điều khiển robot đơn giản qua WiFi.
  • Chuẩn bị cho bài sau: Điều khiển robot qua Internet (IoT Cloud).

🧩 6. Hoạt động mở rộng

  • Thêm thanh trượt (slider) điều chỉnh tốc độ PWM.
  • Tích hợp hiển thị trạng thái (đang tiến/lùi/dừng) trên web.
  • Thiết kế giao diện đẹp hơn với CSS hoặc Bootstrap.

📦 7. Linh kiện cần thiết

Linh kiệnSố lượngGhi chú
ESP32 DevKit 38 Pin1Bộ điều khiển
L298N Motor Driver1Cầu H kép
Motor DC 3–6V2Trái và phải
Nguồn pin 7.4V hoặc 9V1Cấp nguồn động cơ
Điện thoại hoặc laptop1Kết nối WiFi

🚀 8. Kết luận

Bạn đã biến xe robot thành một thiết bị IoT điều khiển qua mạng WiFi.
Khi hiểu cơ chế giao tiếp HTTP và WebServer, bạn có thể phát triển hệ thống điều khiển qua Internet hoặc tích hợp AI điều khiển bằng giọng nói.

Comments

Để lại một bình luận

Email của bạn sẽ không được hiển thị công khai. Các trường bắt buộc được đánh dấu *