Código de Pesquisa

Tutorial ESP32 44/55 - Stream de Vídeo do Servidor Web da Câmera ESP32 via Wifi CAM-2 | Kit ESP32 da SunFounder

Tutorial ESP32 44/55 - Stream de Vídeo do Servidor Web da Câmera ESP32 via Wifi CAM-2 | Kit ESP32 da SunFounder

Neste tutorial, vamos criar uma estação meteorológica em tempo real usando o ESP32 e sua extensão de câmera. Este projeto permitirá que o ESP32 exiba dados meteorológicos, como temperatura e umidade, em uma tela LCD, enquanto também transmite vídeo via Wi-Fi. Ao final deste tutorial, você terá uma estação meteorológica totalmente funcional que se atualiza a cada 10 segundos, oferecendo informações meteorológicas valiosas ao seu alcance. Para mais clareza, consulte o vídeo (no vídeo às 00:00).

extension_bopard_camera

Hardware Explicado

Os principais componentes deste projeto incluem o microcontrolador ESP32, um display LCD e um módulo de câmera. O ESP32 é um microcontrolador poderoso que possui Wi-Fi e Bluetooth integrados, permitindo conectá-lo à internet e comunicá-lo com outros dispositivos. O módulo de câmera possibilita a transmissão de vídeo, enquanto o display LCD apresenta informações sobre o clima ao usuário.

O LCD utilizado neste projeto é um display de 20x4 caracteres, que pode mostrar uma quantidade significativa de informações de uma só vez. Ele está conectado ao ESP32 para exibir a temperatura, umidade e outros dados meteorológicos obtidos de uma API online. O ESP32 também inclui um sistema de gerenciamento de bateria, permitindo que funcione sem fio.

Detalhes da Ficha Técnica

Fabricante Espressif
Número da peça ESP32-WROOM-32
Tensão de lógica/IO 3,3 V
Tensão de alimentação 3,0 - 3,6 V
Corrente de saída (por GPIO) 12 mA
Corrente de pico (por GPIO) 40 mA
Orientação de frequência PWM 1 kHz
Limites de lógica de entrada 0,3 * VDD a 0,7 * VDD
Queda de tensão / RDS(on)/ saturação 0,1 V (típ.)
Limites térmicos 125 °C
Pacote QFN48
Notas / variantes Inclui opções de PSRAM

  • Assegure um fornecimento de energia adequado (3,0 - 3,6 V).
  • Utilize dissipadores de calor para aplicações de alta corrente.
  • Tenha cuidado com os limites de corrente do GPIO (12 mA por pino).
  • Conecte o LCD e a câmera corretamente para evitar uma má comunicação.
  • Verifique as credenciais do Wi-Fi e as chaves da API para problemas de conectividade.

Instruções de Fiação

Para conectar o ESP32 ao módulo LCD e à câmera, comece conectando os pinos de alimentação e terra. Conecte o pino de terra do ESP32 ao terra do LCD e da câmera. Em seguida, conecte o pino de 5V do ESP32 ao VCC do LCD. Para a câmera, conecte o fio marrom ao terra, o fio vermelho ao 5V, o fio amarelo ao GPIO 21 e o fio laranja ao GPIO 22. Certifique-se de que as conexões estão seguras para evitar problemas durante a operação.

Em seguida, conecte o LCD aos pinos GPIO apropriados. Os pinos específicos podem variar com base na sua configuração, mas normalmente, você conectará os pinos de controle aos GPIO designados no ESP32. Certifique-se de consultar o datasheet ou o diagrama de pinos para o seu modelo específico de LCD para confirmar a fiação correta. Após completar essas conexões, verifique novamente toda a fiação em busca de conexões soltas ou incorretas.

Exemplos de Código e Passo a Passo

No código, primeiro incluímos as bibliotecas necessárias para lidar com as funcionalidades da câmera e do Wi-Fi. Os identificadores essenciais são declarados, incluindossidepasswordpara as credenciais do Wi-Fi. A configuração da câmera é feita usando ocamera_config_testrutura, onde definimos vários parâmetros como formato de pixel e tamanho do quadro.

const char* ssid = "SSID";
const char* password = "PASSWORD";

void setup() {
  Serial.begin(115200);
  camera_config_t config;
  // ... (configuration settings)
  esp_err_t err = esp_camera_init(&config);
  // Check for errors
}

Este trecho inicializa a câmera e verifica se há algum erro durante a configuração. Se a câmera falhar ao inicializar, uma mensagem de erro é exibida no monitor serial.

Em seguida, lidamos com a conexão Wi-Fi e iniciamos o servidor de câmeras. O loop de conexão continua até que uma conexão Wi-Fi bem-sucedida seja estabelecida, o que é crucial para obter dados meteorológicos da API.

WiFi.begin(ssid, password);
while (WiFi.status() != WL_CONNECTED) {
  delay(500);
  Serial.print(".");
}
startCameraServer();

Nesta seção, iniciamos a conexão Wi-Fi e imprimimos pontos no monitor serial até que a conexão seja estabelecida. Uma vez conectado, o servidor da câmera é iniciado, permitindo a transmissão de vídeo.

O código completo será carregado abaixo do artigo, onde você pode ver como todas as partes se juntam.

Demonstração / O que Esperar

Uma vez que tudo esteja conectado e o código esteja carregado, você pode esperar que o ESP32 se conecte à rede Wi-Fi e comece a buscar dados meteorológicos a cada 10 segundos. As leituras de temperatura e umidade serão exibidas na tela LCD. Além disso, a câmera transmitirá vídeo via Wi-Fi, que pode ser acessado pelo endereço IP local impresso no monitor serial. Se a conexão Wi-Fi falhar, o ESP32 irá notificá-lo através da saída serial (no vídeo às 10:00).

Marcas de Tempo do Vídeo

  • 00:00 Início
  • 1:42 Introdução ao ESP32-Cam
  • 4:30 Código Arduino explicado
  • 7:35 Selecionando a placa ESP32 e a porta COM no Arduino IDE
  • 9:17 Demonstração
  • 12:06 Demonstração em Telefone Móvel

Imagens

ESP32-40-micro-sd-card-2
ESP32-40-micro-sd-card-2
extension_bopard_camera
extension_bopard_camera
845-ESP32 Tutorial 44/55- Arduino code for camera web sever
Idioma: C++
#include "esp_camera.h"
#include <WiFi.h>

//
// WARNING!!! PSRAM IC required for UXGA resolution and high JPEG quality
//            Ensure ESP32 Wrover Module or other board with PSRAM is selected
//            Partial images will be transmitted if image exceeds buffer size
//
//            You must select partition scheme from the board menu that has at least 3MB APP space.
//            Face Recognition is DISABLED for ESP32 and ESP32-S2, because it takes up from 15 
//            seconds to process single frame. Face Detection is ENABLED if PSRAM is enabled as well

// ===================
// Select camera model
// ===================
//#define CAMERA_MODEL_WROVER_KIT // Has PSRAM
// #define CAMERA_MODEL_ESP_EYE // Has PSRAM
//#define CAMERA_MODEL_ESP32S3_EYE // Has PSRAM
//#define CAMERA_MODEL_M5STACK_PSRAM // Has PSRAM
//#define CAMERA_MODEL_M5STACK_V2_PSRAM // M5Camera version B Has PSRAM
//#define CAMERA_MODEL_M5STACK_WIDE // Has PSRAM
//#define CAMERA_MODEL_M5STACK_ESP32CAM // No PSRAM
//#define CAMERA_MODEL_M5STACK_UNITCAM // No PSRAM
#define CAMERA_MODEL_AI_THINKER // Has PSRAM
//#define CAMERA_MODEL_TTGO_T_JOURNAL // No PSRAM
//#define CAMERA_MODEL_XIAO_ESP32S3 // Has PSRAM
// ** Espressif Internal Boards **
//#define CAMERA_MODEL_ESP32_CAM_BOARD
//#define CAMERA_MODEL_ESP32S2_CAM_BOARD
//#define CAMERA_MODEL_ESP32S3_CAM_LCD

#include "camera_pins.h"

// Replace the next variables with your SSID/Password combination
const char* ssid = "SSID";
const char* password = "PASSWORD";

void startCameraServer();
void setupLedFlash(int pin);

void setup() {
  Serial.begin(115200);
  Serial.setDebugOutput(true);
  Serial.println();

  camera_config_t config;
  config.ledc_channel = LEDC_CHANNEL_0;
  config.ledc_timer = LEDC_TIMER_0;
  config.pin_d0 = Y2_GPIO_NUM;
  config.pin_d1 = Y3_GPIO_NUM;
  config.pin_d2 = Y4_GPIO_NUM;
  config.pin_d3 = Y5_GPIO_NUM;
  config.pin_d4 = Y6_GPIO_NUM;
  config.pin_d5 = Y7_GPIO_NUM;
  config.pin_d6 = Y8_GPIO_NUM;
  config.pin_d7 = Y9_GPIO_NUM;
  config.pin_xclk = XCLK_GPIO_NUM;
  config.pin_pclk = PCLK_GPIO_NUM;
  config.pin_vsync = VSYNC_GPIO_NUM;
  config.pin_href = HREF_GPIO_NUM;
  config.pin_sccb_sda = SIOD_GPIO_NUM;
  config.pin_sccb_scl = SIOC_GPIO_NUM;
  config.pin_pwdn = PWDN_GPIO_NUM;
  config.pin_reset = RESET_GPIO_NUM;
  config.xclk_freq_hz = 20000000;
  config.frame_size = FRAMESIZE_UXGA;
  config.pixel_format = PIXFORMAT_JPEG; // for streaming
  // config.pixel_format = PIXFORMAT_RGB565; // for face detection/recognition
  config.grab_mode = CAMERA_GRAB_WHEN_EMPTY;
  config.fb_location = CAMERA_FB_IN_PSRAM;
  config.jpeg_quality = 12;
  config.fb_count = 1;
  
  // if PSRAM IC present, init with UXGA resolution and higher JPEG quality
  //                      for larger pre-allocated frame buffer.
  if(config.pixel_format == PIXFORMAT_JPEG){
    if(psramFound()){
      config.jpeg_quality = 10;
      config.fb_count = 2;
      config.grab_mode = CAMERA_GRAB_LATEST;
    } else {
      // Limit the frame size when PSRAM is not available
      config.frame_size = FRAMESIZE_SVGA;
      config.fb_location = CAMERA_FB_IN_DRAM;
    }
  } else {
    // Best option for face detection/recognition
    config.frame_size = FRAMESIZE_240X240;
#if CONFIG_IDF_TARGET_ESP32S3
    config.fb_count = 2;
#endif
  }

#if defined(CAMERA_MODEL_ESP_EYE)
  pinMode(13, INPUT_PULLUP);
  pinMode(14, INPUT_PULLUP);
#endif

  // camera init
  esp_err_t err = esp_camera_init(&config);
  if (err != ESP_OK) {
    Serial.printf("Camera init failed with error 0x%x", err);
    return;
  }

  sensor_t * s = esp_camera_sensor_get();
  // initial sensors are flipped vertically and colors are a bit saturated
  if (s->id.PID == OV3660_PID) {
    s->set_vflip(s, 1); // flip it back
    s->set_brightness(s, 1); // up the brightness just a bit
    s->set_saturation(s, -2); // lower the saturation
  }
  // drop down frame size for higher initial frame rate
  if(config.pixel_format == PIXFORMAT_JPEG){
    s->set_framesize(s, FRAMESIZE_QVGA);
  }

#if defined(CAMERA_MODEL_M5STACK_WIDE) || defined(CAMERA_MODEL_M5STACK_ESP32CAM)
  s->set_vflip(s, 1);
  s->set_hmirror(s, 1);
#endif

#if defined(CAMERA_MODEL_ESP32S3_EYE)
  s->set_vflip(s, 1);
#endif

// Setup LED FLash if LED pin is defined in camera_pins.h
#if defined(LED_GPIO_NUM)
  setupLedFlash(LED_GPIO_NUM);
#endif

  WiFi.begin(ssid, password);
  WiFi.setSleep(false);

  while (WiFi.status() != WL_CONNECTED) {
    delay(500);
    Serial.print(".");
  }
  Serial.println("");
  Serial.println("WiFi connected");

  startCameraServer();

  Serial.print("Camera Ready! Use 'http://");
  Serial.print(WiFi.localIP());
  Serial.println("' to connect");
}

void loop() {
  // Do nothing. Everything is done in another task by the web server
  delay(10000);
}

Recursos e referências

Arquivos📁

Nenhum arquivo disponível.