Update projects/espnow/rc car/receiver/receiver.ino

This commit is contained in:
Ghassan Yusuf 2025-10-07 13:04:52 +03:00
parent 6582129043
commit a5b1684ec9

View File

@ -2,8 +2,9 @@
#include <esp_now.h>
#include <ESP32Servo.h>
Servo leftServo1, leftServo2, rightServo1, rightServo2;
int leftServoPin1 = 12, leftServoPin2 = 13, rightServoPin1 = 14, rightServoPin2 = 15;
Servo leftServoA, leftServoB, rightServoA, rightServoB;
int leftPins[2] = {12, 13};
int rightPins[2] = {14, 15};
typedef struct {
int speed;
@ -11,45 +12,44 @@ typedef struct {
} CommandPacket;
typedef struct {
int leftServoSpeed;
int rightServoSpeed;
int batteryLevel;
int leftSpeed;
int rightSpeed;
int battery;
} TelemetryPacket;
CommandPacket command;
uint8_t controllerAddr[] = {0x24, 0x6F, 0x28, 0x33, 0xDE, 0xB4}; // Remote MAC
TelemetryPacket telemetry;
uint8_t remoteAddr[] = {0x24, 0x6F, 0x28, 0x33, 0xDE, 0xB4}; // MAC of remote
void onCommandRecv(const uint8_t * mac, const uint8_t *incomingData, int len) {
memcpy(&command, incomingData, sizeof(command));
int leftSpeed = constrain(command.speed + command.turn, -255, 255);
int rightSpeed = constrain(command.speed - command.turn, -255, 255);
// Map speed value to servo position (0-180 for continuous rotation speed control)
int leftPWM = map(leftSpeed, -255, 255, 0, 180);
int rightPWM = map(rightSpeed, -255, 255, 0, 180);
int left = constrain(command.speed + command.turn, -255, 255);
int right = constrain(command.speed - command.turn, -255, 255);
leftServo1.write(leftPWM);
leftServo2.write(leftPWM);
rightServo1.write(rightPWM);
rightServo2.write(rightPWM);
int pwmLeft = map(left, -255, 255, 0, 180);
int pwmRight = map(right, -255, 255, 0, 180);
// Store for telemetry
telemetry.leftServoSpeed = leftSpeed;
telemetry.rightServoSpeed = rightSpeed;
leftServoA.write(pwmLeft);
leftServoB.write(pwmLeft);
rightServoA.write(pwmRight);
rightServoB.write(pwmRight);
telemetry.leftSpeed = left;
telemetry.rightSpeed = right;
}
TelemetryPacket telemetry;
void setup() {
Serial.begin(115200);
leftServo1.attach(leftServoPin1);
leftServo2.attach(leftServoPin2);
rightServo1.attach(rightServoPin1);
rightServo2.attach(rightServoPin2);
leftServoA.attach(leftPins[0]);
leftServoB.attach(leftPins[1]);
rightServoA.attach(rightPins[0]);
rightServoB.attach(rightPins[1]);
WiFi.mode(WIFI_STA);
esp_now_init();
esp_now_peer_info_t peerInfo;
memcpy(peerInfo.peer_addr, controllerAddr, 6);
memcpy(peerInfo.peer_addr, remoteAddr, 6);
peerInfo.channel = 0;
peerInfo.encrypt = false;
esp_now_add_peer(&peerInfo);
@ -58,10 +58,9 @@ void setup() {
unsigned long lastTelemetrySent = 0;
void loop() {
// Telemetry every 500 ms
if (millis() - lastTelemetrySent > 500) {
telemetry.batteryLevel = analogRead(36); // Replace with battery calculation if needed
esp_now_send(controllerAddr, (uint8_t*)&telemetry, sizeof(telemetry));
telemetry.battery = analogRead(36); // Replace with proper battery voltage calculation
esp_now_send(remoteAddr, (uint8_t*)&telemetry, sizeof(telemetry));
lastTelemetrySent = millis();
}
}
}