forked from xiaozhi/xiaozhi-esp32
* refactor: migrate camera module to esp-video library * refactor: migrate boards to esp-video API (1/2) * refactor: migrate boards to esp-video API (2/2) * fix: use ESP-IDF 5.5 * refactor: migrate the JPEG encoder to `esp_new_jpeg` * feat: add YUV422 support * feat: improve pixelformat and device selection process * feat: use ESP32-P4 Hardware JPEG Encoder
52 lines
1.3 KiB
C++
52 lines
1.3 KiB
C++
#pragma once
|
|
#include "sdkconfig.h"
|
|
|
|
#ifndef CONFIG_IDF_TARGET_ESP32
|
|
#include <lvgl.h>
|
|
#include <thread>
|
|
#include <memory>
|
|
#include <vector>
|
|
|
|
#include <freertos/FreeRTOS.h>
|
|
#include <freertos/queue.h>
|
|
|
|
#include "camera.h"
|
|
#include "jpg/image_to_jpeg.h"
|
|
#include "esp_video_init.h"
|
|
|
|
struct JpegChunk {
|
|
uint8_t* data;
|
|
size_t len;
|
|
};
|
|
|
|
class Esp32Camera : public Camera {
|
|
private:
|
|
struct FrameBuffer {
|
|
uint8_t *data = nullptr;
|
|
size_t len = 0;
|
|
uint16_t width = 0;
|
|
uint16_t height = 0;
|
|
v4l2_pix_fmt_t format = 0;
|
|
} frame_;
|
|
v4l2_pix_fmt_t sensor_format_ = 0;
|
|
int video_fd_ = -1;
|
|
bool streaming_on_ = false;
|
|
struct MmapBuffer { void *start = nullptr; size_t length = 0; };
|
|
std::vector<MmapBuffer> mmap_buffers_;
|
|
std::string explain_url_;
|
|
std::string explain_token_;
|
|
std::thread encoder_thread_;
|
|
|
|
public:
|
|
Esp32Camera(const esp_video_init_config_t& config);
|
|
~Esp32Camera();
|
|
|
|
virtual void SetExplainUrl(const std::string& url, const std::string& token);
|
|
virtual bool Capture();
|
|
// 翻转控制函数
|
|
virtual bool SetHMirror(bool enabled) override;
|
|
virtual bool SetVFlip(bool enabled) override;
|
|
virtual std::string Explain(const std::string& question);
|
|
};
|
|
|
|
#endif // ndef CONFIG_IDF_TARGET_ESP32
|