I'm new to PlatformIO and ESP32 development. I've acquired an ESP32-CAM board which uses a OV2640 camera module, and I've been trying to get the standard Arduino web camera stream (CameraWebServer) example working. I've set up a PlatformIO project using the Arduino framework, and included the esp32-camera dependency.
Using PlatformIO, I've been getting the 'Detected camera not supported' error. I initially thought I had a dead camera module, and as a sanity check, I tried to compile and upload the same code using the Arduino IDE - and to my surprise, it worked straight away.
I have only a single source code file in my project - main.cpp - and it's copied straight from the the Arduino example code. All I've done is put my own WiFi SSID/password in and uncommented the AI_THINKER board line.
#include "esp_camera.h"
#include <WiFi.h>
//
// WARNING!!! Make sure that you have either selected ESP32 Wrover Module,
// or another board which has PSRAM enabled
//
// Select camera model
//define CAMERA_MODEL_WROVER_KIT
//#define CAMERA_MODEL_ESP_EYE
//#define CAMERA_MODEL_M5STACK_PSRAM
//#define CAMERA_MODEL_M5STACK_WIDE
#define CAMERA_MODEL_AI_THINKER
#include "camera_pins.h"
const char* ssid = "[my wifi ssid]";
const char* password = "[my wifi password]";
void startCameraServer();
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_sscb_sda = SIOD_GPIO_NUM;
config.pin_sscb_scl = SIOC_GPIO_NUM;
config.pin_pwdn = PWDN_GPIO_NUM;
config.pin_reset = RESET_GPIO_NUM;
config.xclk_freq_hz = 20000000;
config.pixel_format = PIXFORMAT_JPEG;
//init with high specs to pre-allocate larger buffers
if(psramFound()){
config.frame_size = FRAMESIZE_UXGA;
config.jpeg_quality = 10;
config.fb_count = 2;
} else {
config.frame_size = FRAMESIZE_SVGA;
config.jpeg_quality = 12;
config.fb_count = 1;
}
#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 blightness just a bit
s->set_saturation(s, -2);//lower the saturation
}
//drop down frame size for higher initial frame rate
s->set_framesize(s, FRAMESIZE_QVGA);
#if defined(CAMERA_MODEL_M5STACK_WIDE)
s->set_vflip(s, 1);
s->set_hmirror(s, 1);
#endif
WiFi.begin(ssid, password);
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() {
// put your main code here, to run repeatedly:
delay(10000);
}
Using PIO, I'm able to successfully upload the code to the board, however I get this error from the serial monitor:
rst:0x10 (RTCWDT_RTC_RESET),boot:0x13 (SPI_FAST_FLASH_BOOT)
configsip: 0, SPIWP:0xee
clk_drv:0x00,q_drv:0x00,d_drv:0x00,cs0_drv:0x00,hd_drv:0x00,wp_drv:0x00
mode:DIO, clock div:2
load:0x3fff0018,len:4
load:0x3fff001c,len:1044
load:0x40078000,len:10124
load:0x40080400,len:5828
entry 0x400806a8
[E][camera.c:1113] camera_probe(): Detected camera not supported.
[E][camera.c:1379] esp_camera_init(): Camera probe failed with error 0x20004
Camera init failed with error 0x20004
Using the Arduino IDE and the stock code from File > Examples > ESP32, it works well and I'm able to see the camera stream. The serial monitor output is as follows:
rst:0x10 (RTCWDT_RTC_RESET),boot:0x13 (SPI_FAST_FLASH_BOOT)
configsip: 0, SPIWP:0xee
clk_drv:0x00,q_drv:0x00,d_drv:0x00,cs0_drv:0x00,hd_drv:0x00,wp_drv:0x00
mode:DIO, clock div:1
load:0x3fff0018,len:4
load:0x3fff001c,len:1216
ho 0 tail 12 room 4
load:0x40078000,len:9720
ho 0 tail 12 room 4
load:0x40080400,len:6352
entry 0x400806b8
................
WiFi connected
Starting web server on port: '80'
Starting stream server on port: '81'
Camera Ready! Use 'http://192.168.0.37' to connect
I think I might have set up my PIO project wrong somewhere, or have some missing dependencies. Any help would be gladly appreciated - I'd be grateful if someone could point me in the right direction.
Hi,
I'm new to PlatformIO and ESP32 development. I've acquired an ESP32-CAM board which uses a OV2640 camera module, and I've been trying to get the standard Arduino web camera stream (CameraWebServer) example working. I've set up a PlatformIO project using the Arduino framework, and included the
esp32-camera
dependency.Using PlatformIO, I've been getting the 'Detected camera not supported' error. I initially thought I had a dead camera module, and as a sanity check, I tried to compile and upload the same code using the Arduino IDE - and to my surprise, it worked straight away.
My
platformio.ini
file is as follows:I have only a single source code file in my project - main.cpp - and it's copied straight from the the Arduino example code. All I've done is put my own WiFi SSID/password in and uncommented the AI_THINKER board line.
Using PIO, I'm able to successfully upload the code to the board, however I get this error from the serial monitor:
Using the Arduino IDE and the stock code from File > Examples > ESP32, it works well and I'm able to see the camera stream. The serial monitor output is as follows:
I think I might have set up my PIO project wrong somewhere, or have some missing dependencies. Any help would be gladly appreciated - I'd be grateful if someone could point me in the right direction.