ESP32 Điều Khiển Servo Motor qua Web
Hướng dẫn này sẽ chỉ bạn cách sử dụng ESP32 để điều khiển servo motor qua web từ trình duyệt trên smartphone hoặc PC của bạn. Chúng ta sẽ sử dụng WebSocket để điều khiển servo motor một cách mượt mà và động thông qua giao diện web đồ họa.
Video dưới đây là một minh họa:
Vậy tại sao lại sử dụng WebSocket? Ý tưởng là như thế này:
- Không có WebSocket, mỗi lần bạn muốn thay đổi góc của servo, bạn phải reload trang. Không tốt lắm!
- Nhưng với WebSocket, chúng ta thiết lập một kết nối đặc biệt giữa trang web và ESP32. Điều này có nghĩa là chúng ta có thể gửi giá trị góc đến ESP32 ở background, mà không cần reload trang. Điều đó làm cho servo chuyển động mượt mà và theo thời gian thực. Khá tuyệt phải không?
Bắt đầu thôi!
Phần Cứng Cần Thiết
| 1 | × | mô-đun phát triển ESP-WROOM-32 | ||
| 1 | × | Alternatively, ESP32 Uno-form board | ||
| 1 | × | Alternatively, ESP32 S3 Uno-form board | ||
| 1 | × | Cáp USB Type-C | ||
| 1 | × | động cơ servo | ||
| 1 | × | breadboard (Bo mạch thí nghiệm) | ||
| 1 | × | Dây Jumper | ||
| 1 | × | (Tùy chọn) DC Power Jack | ||
| 1 | × | (Khuyến nghị) Screw Terminal Expansion Board for ESP32 | ||
| 1 | × | (Khuyến nghị) Breakout Expansion Board for ESP32 | ||
| 1 | × | (Khuyến nghị) Power Splitter for ESP32 |
Or you can buy the following kits:
| 1 | × | DIYables ESP32 Starter Kit (ESP32 included) | ||
| 1 | × | DIYables Sensor Kit (30 sensors/displays) | ||
| 1 | × | DIYables Sensor Kit (18 sensors/displays) |
Về Servo Motor và WebSocket
Chúng tôi có các tutorial chuyên biệt về servo motor và WebSocket. Mỗi tutorial chứa thông tin chi tiết và hướng dẫn từng bước về pinout phần cứng, nguyên lý hoạt động, kết nối dây với ESP32, code ESP32... Tìm hiểu thêm tại các liên kết sau:
- Tutorial ESP32 - Servo Motor
- Tutorial ESP32 - WebSocket
Cách Thức Hoạt Động
Code ESP32 tạo ra cả web server và WebSocket Server. Đây là cách nó hoạt động:
- Khi bạn nhập địa chỉ IP của ESP32 vào trình duyệt web, nó yêu cầu trang web (User Interface) từ ESP32.
- Web server của ESP32 phản hồi bằng cách gửi nội dung trang web (HTML, CSS, JavaScript).
- Trình duyệt web của bạn sau đó hiển thị trang web.
- Code JavaScript trong trang web thiết lập kết nối WebSocket đến WebSocket server trên ESP32.
- Một khi kết nối WebSocket này được thiết lập, nếu bạn xoay handle trên trang web, code JavaScript sẽ gửi giá trị góc đến ESP32 thông qua kết nối WebSocket này ở background.
- WebSocket server trên ESP32, khi nhận được giá trị góc, sẽ điều khiển servo motor tương ứng.
Tóm lại, kết nối WebSocket cho phép điều khiển góc servo motor mượt mà và theo thời gian thực.
Sơ Đồ Kết Nối giữa Servo Motor và ESP32

This image is created using Fritzing. Click to enlarge image
Nếu bạn chưa rõ cách cấp nguồn cho ESP32 và các linh kiện khác, xem: Cách Cung Cấp Nguồn Điện Cho ESP32.
Để đơn giản, sơ đồ kết nối trên được sử dụng cho mục đích thử nghiệm hoặc học tập, và cho servo motor có mô-men xoắn nhỏ. Trong thực tế, chúng tôi khuyên bạn nên sử dụng nguồn điện bên ngoài cho servo motor. Sơ đồ kết nối dưới đây cho thấy cách kết nối servo motor với nguồn điện bên ngoài.

This image is created using Fritzing. Click to enlarge image
Dưới đây là kết nối thực tế giữa servo motor và ESP32.

Code ESP32
Nội dung trang web (HTML, CSS, JavaScript) được lưu trữ riêng biệt trong file index.h. Vì vậy, chúng ta sẽ có hai file code trong Arduino IDE:
- File .ino chứa code ESP32, tạo web server và WebSocket Server, và điều khiển servo motor
- File .h chứa nội dung trang web.
Các Bước Nhanh
- Nếu đây là lần đầu bạn sử dụng ESP32, hãy xem ESP32 - Cài Đặt Phần Mềm.
- Thực hiện kết nối dây như hình trên.
- Kết nối board ESP32 với PC của bạn qua cáp micro USB
- Mở Arduino IDE trên PC của bạn.
- Chọn đúng board ESP32 (ví dụ: ESP32 Dev Module) và cổng COM.
- Mở Library Manager bằng cách click vào icon Library Manager trên thanh điều hướng bên trái của Arduino IDE.
- Tìm kiếm "DIYables ESP32 WebServer", sau đó tìm thư viện Web Server được tạo bởi DIYables.
- Click nút Install để cài đặt thư viện Web Server.

- Gõ ESP32Servo vào ô tìm kiếm, sau đó tìm thư viện servo của Kevin Harrington, John K. Bennett.
- Click nút Install để cài đặt thư viện servo motor cho ESP32.

- Trên Arduino IDE, tạo sketch mới, Đặt tên cho nó, ví dụ: newbiely.com.ino
- Copy code dưới đây và mở với Arduino IDE
- Sửa thông tin WiFi (SSID và password) trong code để phù hợp với thông tin mạng của bạn.
- Tạo file index.h trên Arduino IDE bằng cách:
- Click vào nút ngay dưới icon serial monitor và chọn New Tab, hoặc sử dụng phím Ctrl+Shift+N.
- Đặt tên file là index.h và click nút OK
- Copy code dưới đây và dán vào index.h.
- Bây giờ bạn có code trong hai file: newbiely.com.ino và index.h
- Click nút Upload trên Arduino IDE để upload code lên ESP32
- Mở Serial Monitor
- Kiểm tra kết quả trên Serial Monitor.
- Ghi nhớ địa chỉ IP được hiển thị, và nhập địa chỉ này vào thanh địa chỉ của trình duyệt web trên smartphone hoặc PC của bạn.
- Bạn sẽ thấy trang web như dưới đây:
- Code JavaScript của trang web tự động tạo kết nối WebSocket đến ESP32.
- Bây giờ bạn có thể điều khiển góc servo motor qua giao diện web.
- Nếu bạn chỉnh sửa nội dung HTML trong file index.h và không thay đổi gì trong file newbiely.com.ino, khi bạn compile và upload code lên ESP32, Arduino IDE sẽ không cập nhật nội dung HTML.
- Để làm cho Arduino IDE cập nhật nội dung HTML trong trường hợp này, hãy thực hiện thay đổi trong file newbiely.com.ino (ví dụ: thêm dòng trống, thêm comment....)



Để tiết kiệm bộ nhớ của ESP32, các hình ảnh của servo motor KHÔNG được lưu trữ trên ESP32. Thay vào đó, chúng được lưu trữ trên internet, vì vậy, điện thoại hoặc PC của bạn cần có kết nối internet để tải hình ảnh cho trang điều khiển web.
※ Lưu ý:
Giải Thích Code Từng Dòng
Code ESP32 ở trên có giải thích từng dòng. Hãy đọc các comment trong code!