Conexión de Componentes en ESP32

2:20

General (prev)
Chat History
Project
Aquí tienes un ejemplo de código unificado para un ESP32 que integra las tres funcionalidades que mencionas: control de ventiladores mediante sensores BH1750 (simulando lectura de temperatura), control de una bomba (a través de un sensor de humedad del suelo) y movimiento de dos servomotores basado en un sensor de luz (BH1750).
Nota importante:
  • El sensor BH1750 sólo opera en dos direcciones (normalmente 0x23 y 0x5C). En este ejemplo se asume que dispones de tres sensores BH1750 (uno para cada función), asignando la dirección adicional 0x5D para el sensor de luz usado en los servos. En la práctica, para usar tres sensores necesitarás un multiplexor I²C o un sensor alternativo.
  • La conversión de lectura de luz a temperatura es simplemente simulada mediante la función readSimulatedTemperature(); para un diseño real deberás usar un sensor de temperatura adecuado.
Puedes copiar y ajustar este código según tus requerimientos:

Cpp


#include 
#include 
#include 

// =========================
// PARTE 1: CONTROL DE VENTILADORES
// =========================
const int fan1Pin = 5;             // Pin para el ventilador 1
const int fan2Pin = 12;            // Pin para el ventilador 2
const float tempThreshold = 35.0;  // Umbral de "temperatura" (en °C, simulado)

// Direcciones I2C para sensores BH1750 de temperatura simulada
#define CRITICO_ADDR 0x23
#define AMBIENTE_ADDR 0x5C

BH1750 sensorCritico;    // Sensor para temperatura crítica
BH1750 sensorAmbiente;   // Sensor para temperatura ambiente

// Función para simular la conversión de lux a temperatura  
float readSimulatedTemperature(BH1750 &sensor) {
  float lux = sensor.readLightLevel();
  // Simulación: se mapea el rango de lux (0 a 1000) a un rango de temperatura (20 °C a 40 °C)
  long mappedValue = map((long)lux, 0, 1000, 20, 40);
  return (float)mappedValue;
}

// =========================
// PARTE 2: SENSOR DE HUMEDAD Y CONTROL DE BOMBA
// =========================
const int sensorHumedadPin = 36;  // Pin ADC para el sensor FC-28 (humedad del suelo)
const int relePin = 15;           // Pin para controlar el relé (bomba de agua)

// Umbrales para la humedad del suelo (ajusta según tus pruebas)
const int humedadSeco = 2000;     
const int humedadHumedo = 1000;    

// =========================
// PARTE 3: CONTROL DE SERVOMOTORES CON SENSOR DE LUZ
// =========================
// Nota: Se asume un tercer BH1750 con dirección 0x5D. En la práctica se requiere un multiplexor I2C o sensor alternativo.
#define LIGHT_ADDR 0x5D
BH1750 sensorLight;  // Sensor de luz para control de servos

Servo servo1;
Servo servo2;
const int servo1Pin = 13;  // Pin para Servo 1
const int servo2Pin = 26;  // Pin para Servo 2

// Posiciones de los servos y tiempos
const int posStop = 90;         // Posición de reposo
const int pos1Forward = 0;      // Servo1: posición "adelante"
const int pos1Backward = 180;   // Servo1: posición "atrás"
const int pos2Forward = 180;    // Servo2: posición "adelante" (invertido)
const int pos2Backward = 0;     // Servo2: posición "atrás" (invertido)
const int moveTime = 3000;      // Duración del movimiento (en ms)
const float lightThreshold = 50.0; // Umbral de luz (en lux) para cambiar de modo

// =========================
// SETUP
// =========================
void setup() {
  Serial.begin(115200);
  Wire.begin();

  // Inicializar sensores BH1750 para el control de ventiladores
  if (!sensorCritico.begin(CRITICO_ADDR)) {
    Serial.println("Error iniciando sensorCritico BH1750");
  }
  if (!sensorAmbiente.begin(AMBIENTE_ADDR)) {
    Serial.println("Error iniciando sensorAmbiente BH1750");
  }
  
  // Inicializar el sensor de luz para servos
  if (!sensorLight.begin(LIGHT_ADDR)) {
    Serial.println("Error iniciando sensorLight BH1750");
  }
  
  // Configurar pines de salida para ventiladores
  pinMode(fan1Pin, OUTPUT);
  pinMode(fan2Pin, OUTPUT);
  digitalWrite(fan1Pin, LOW);
  digitalWrite(fan2Pin, LOW);
  
  // Configurar pines para el sensor de humedad y el relé (bomba)
  pinMode(sensorHumedadPin, INPUT);
  pinMode(relePin, OUTPUT);
  digitalWrite(relePin, LOW);
  
  // Inicializar servos
  ESP32PWM::allocateTimer(0);
  ESP32PWM::allocateTimer(1);
  ESP32PWM::allocateTimer(2);
  ESP32PWM::allocateTimer(3);
  
  servo1.setPeriodHertz(50);
  servo1.attach(servo1Pin, 500, 2400);
  
  servo2.setPeriodHertz(50);
  servo2.attach(servo2Pin, 500, 2400);
  
  // Poner servos en posición de reposo
  servo1.write(posStop);
  servo2.write(posStop);
  
  Serial.println("Sistema unificado de control iniciado");
}

// =========================
// LOOP PRINCIPAL
// =========================
void loop() {
  // ----- Bloque 1: Control de Ventiladores (simulación de temperatura con BH1750) -----
  float tempCritica = readSimulatedTemperature(sensorCritico);
  float tempAmbiente = readSimulatedTemperature(sensorAmbiente);
  Serial.print("Temp Critica: ");
  Serial.print(tempCritica);
  Serial.print(" °C | Temp Ambiente: ");
  Serial.print(tempAmbiente);
  Serial.println(" °C");
  
  if (tempCritica > tempThreshold) {
    digitalWrite(fan1Pin, HIGH);
    digitalWrite(fan2Pin, HIGH);
    Serial.println("Temp critica alta - Ventiladores ENCENDIDOS");
  } else {
    digitalWrite(fan1Pin, LOW);
    digitalWrite(fan2Pin, LOW);
    Serial.println("Temp critica normal - Ventiladores APAGADOS");
  }
  
  delay(2000);
  
  // ----- Bloque 2: Control de Humedad y Bomba -----
  int lecturaHumedad = analogRead(sensorHumedadPin);
  Serial.print("Lectura de humedad: ");
  Serial.println(lecturaHumedad);
  
  if (lecturaHumedad > humedadSeco) {
    digitalWrite(relePin, HIGH);
    Serial.println("Suelo seco - Relé ACTIVADO (bomba encendida)");
  } 
  else if (lecturaHumedad < humedadHumedo) {
    digitalWrite(relePin, LOW);
    Serial.println("Suelo húmedo - Relé DESACTIVADO (bomba apagada)");
  }
  
  delay(2000);
  
  // ----- Bloque 3: Control de Servomotores basado en Sensor de Luz -----
  float lux = sensorLight.readLightLevel();
  Serial.print("Nivel de luz (servo): ");
  Serial.print(lux);
  Serial.println(" lx");
  
  if(lux > lightThreshold) {
    Serial.println("Modo con luz - Movimiento en Sentido A");
    servo1.write(pos1Forward);
    servo2.write(pos2Forward);
    delay(moveTime);
    stopServos();
  } 
  else {
    Serial.println("Modo sin luz - Movimiento en Sentido B");
    servo1.write(pos1Backward);
    servo2.write(pos2Backward);
    delay(moveTime);
    stopServos();
  }
  
  delay(1000); // Pausa breve antes de iniciar la siguiente iteración
}

// Función para detener los servos (posición de reposo)
void stopServos() {
  servo1.write(posStop);
  servo2.write(posStop);
  delay(100);
}

Este código integra en un solo sketch las tres tareas principales:
  • Control de ventiladores: Se leen dos sensores BH1750 para simular la temperatura. Si la “temperatura crítica” supera el umbral definido, se encienden dos ventiladores.
  • Control de bomba por humedad: Se realiza una lectura analógica del sensor de humedad del suelo y se activa o desactiva un relé (que puede accionar la bomba) según los umbrales definidos.
  • Control de servos mediante sensor de luz: Se emplea un tercer BH1750 para leer el nivel de luz y mover dos servos en función de esa lectura.
Si necesitas ajustar algún detalle, como los umbrales, pines o la conversión de luminosidad a temperatura, házmelo saber. ¿Te ayudo a integrar o modificar alguna parte en particular?
292 days

Ready.


U1
U4
U2
U3


  • Ground
    A common return path for electric current. Commonly known as ground.
  • Net Portal
    Wirelessly connects nets on schematic. Used to organize schematics and separate functional blocks. To wirelessly connect net portals, give them same designator. #portal
  • Power Net Portal
    Wirelessly connects power nets on schematic. Identical to the net portal, but with a power symbol. Used to organize schematics and separate functional blocks. To wirelessly connect power net portals, give them the same designator. #portal #power
  • Generic Resistor
    A generic fixed resistor for rapid developing circuit topology. Save precious design time by seamlessly add more information to this part (value, footprint, etc.) as it becomes available. Standard resistor values: 1.0Ω 10Ω 100Ω 1.0kΩ 10kΩ 100kΩ 1.0MΩ 1.1Ω 11Ω 110Ω 1.1kΩ 11kΩ 110kΩ 1.1MΩ 1.2Ω 12Ω 120Ω 1.2kΩ 12kΩ 120kΩ 1.2MΩ 1.3Ω 13Ω 130Ω 1.3kΩ 13kΩ 130kΩ 1.3MΩ 1.5Ω 15Ω 150Ω 1.5kΩ 15kΩ 150kΩ 1.5MΩ 1.6Ω 16Ω 160Ω 1.6kΩ 16kΩ 160kΩ 1.6MΩ 1.8Ω 18Ω 180Ω 1.8KΩ 18kΩ 180kΩ 1.8MΩ 2.0Ω 20Ω 200Ω 2.0kΩ 20kΩ 200kΩ 2.0MΩ 2.2Ω 22Ω 220Ω 2.2kΩ 22kΩ 220kΩ 2.2MΩ 2.4Ω 24Ω 240Ω 2.4kΩ 24kΩ 240kΩ 2.4MΩ 2.7Ω 27Ω 270Ω 2.7kΩ 27kΩ 270kΩ 2.7MΩ 3.0Ω 30Ω 300Ω 3.0KΩ 30KΩ 300KΩ 3.0MΩ 3.3Ω 33Ω 330Ω 3.3kΩ 33kΩ 330kΩ 3.3MΩ 3.6Ω 36Ω 360Ω 3.6kΩ 36kΩ 360kΩ 3.6MΩ 3.9Ω 39Ω 390Ω 3.9kΩ 39kΩ 390kΩ 3.9MΩ 4.3Ω 43Ω 430Ω 4.3kΩ 43KΩ 430KΩ 4.3MΩ 4.7Ω 47Ω 470Ω 4.7kΩ 47kΩ 470kΩ 4.7MΩ 5.1Ω 51Ω 510Ω 5.1kΩ 51kΩ 510kΩ 5.1MΩ 5.6Ω 56Ω 560Ω 5.6kΩ 56kΩ 560kΩ 5.6MΩ 6.2Ω 62Ω 620Ω 6.2kΩ 62KΩ 620KΩ 6.2MΩ 6.8Ω 68Ω 680Ω 6.8kΩ 68kΩ 680kΩ 6.8MΩ 7.5Ω 75Ω 750Ω 7.5kΩ 75kΩ 750kΩ 7.5MΩ 8.2Ω 82Ω 820Ω 8.2kΩ 82kΩ 820kΩ 8.2MΩ 9.1Ω 91Ω 910Ω 9.1kΩ 91kΩ 910kΩ 9.1MΩ #generics #CommonPartsLibrary
  • Generic Capacitor
    A generic fixed capacitor ideal for rapid circuit topology development. You can choose between polarized and non-polarized types, its symbol and the footprint will automatically adapt based on your selection. Supported options include standard SMD sizes for ceramic capacitors (e.g., 0402, 0603, 0805), SMD sizes for aluminum electrolytic capacitors, and through-hole footprints for polarized capacitors. Save precious design time by seamlessly add more information to this part (value, footprint, etc.) as it becomes available. Standard capacitor values: 1.0pF 10pF 100pF 1000pF 0.01uF 0.1uF 1.0uF 10uF 100uF 1000uF 10,000uF 1.1pF 11pF 110pF 1100pF 1.2pF 12pF 120pF 1200pF 1.3pF 13pF 130pF 1300pF 1.5pF 15pF 150pF 1500pF 0.015uF 0.15uF 1.5uF 15uF 150uF 1500uF 1.6pF 16pF 160pF 1600pF 1.8pF 18pF 180pF 1800pF 2.0pF 20pF 200pF 2000pF 2.2pF 22pF 20pF 2200pF 0.022uF 0.22uF 2.2uF 22uF 220uF 2200uF 2.4pF 24pF 240pF 2400pF 2.7pF 27pF 270pF 2700pF 3.0pF 30pF 300pF 3000pF 3.3pF 33pF 330pF 3300pF 0.033uF 0.33uF 3.3uF 33uF 330uF 3300uF 3.6pF 36pF 360pF 3600pF 3.9pF 39pF 390pF 3900pF 4.3pF 43pF 430pF 4300pF 4.7pF 47pF 470pF 4700pF 0.047uF 0.47uF 4.7uF 47uF 470uF 4700uF 5.1pF 51pF 510pF 5100pF 5.6pF 56pF 560pF 5600pF 6.2pF 62pF 620pF 6200pF 6.8pF 68pF 680pF 6800pF 0.068uF 0.68uF 6.8uF 68uF 680uF 6800uF 7.5pF 75pF 750pF 7500pF 8.2pF 82pF 820pF 8200pF 9.1pF 91pF 910pF 9100pF #generics #CommonPartsLibrary
  • Generic Inductor
    A generic fixed inductor for rapid developing circuit topology. *You can now change the footprint and 3D model at the top level anytime you want. This is the power of #generics
  • Terminal
    Terminal
    An electrical connector acting as reusable interface to a conductor and creating a point where external circuits can be connected.
  • RMCF0805JT47K0
    47 kOhms ±5% 0.125W, 1/8W Chip Resistor 0805 (2012 Metric) Automotive AEC-Q200 Thick Film #forLedBlink
  • 875105359001
    10uF Capacitor Aluminum Polymer 20% 16V SMD 5x5.3mm #forLedBlink #commonpartslibrary #capacitor #aluminumpolymer #radialcan
  • CTL1206FYW1T
    Yellow 595nm LED Indication - Discrete 1.7V 1206 (3216 Metric) #forLedBlink

Inspect

Confident Blush Time Machine

Confident Blush Time Machine
Description

Created
Last updated by josedjade
1 Contributor(s)
josedjade

Controls

Properties

Availability & Pricing

DistributorQty 1
Arrow$2.93
Digi-Key$4.80
Mouser$4.53
Verical$4.11

Assets