add esp32-camera
This uses the esp32-camera code instead of our own homebrewed camera code.
In theory it supports esp32, esp32-s2 and esp32-s3, as long as they have
PSRAM.
This is very basic and doesn't support changing any camera parameters,
including switching resolution or pixelformat.
This is tested on the Kaluga (ESP32-S2) and ESP32-S3-Eye boards.
First, reserve some PSRAM by putting this line in `CIRCUITPY/_env`:
```
CIRCUITPY_RESERVED_PSRAM=524288
```
and hard-reset the board for it to take effect.
Now, the following script will take a very low-resolution jpeg file and print
it in the REPL in escape coded form:
```python
import board
import esp32_camera
c = esp32_camera.Camera(
data_pins=board.CAMERA_DATA,
external_clock_pin=board.CAMERA_XCLK,
pixel_clock_pin=board.CAMERA_PCLK,
vsync_pin=board.CAMERA_VSYNC,
href_pin=board.CAMERA_HREF,
pixel_format=esp32_camera.PixelFormat.JPEG,
i2c=board.I2C(),
external_clock_frequency=20_000_000)
m = c.take()
if m is not None:
print(bytes(m))
```
Then on desktop open a python repl and run something like
```python
>>> with open("my.jpg", "wb") as f: f.write(<BIG PASTE FROM REPL>)
```
and open my.jpg in a viewer.
2022-08-04 16:11:50 -04:00
|
|
|
/*
|
|
|
|
* This file is part of the MicroPython project, http://micropython.org/
|
|
|
|
*
|
|
|
|
* The MIT License (MIT)
|
|
|
|
*
|
|
|
|
* Copyright (c) 2019 Scott Shawcroft for Adafruit Industries
|
|
|
|
*
|
|
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
* of this software and associated documentation files (the "Software"), to deal
|
|
|
|
* in the Software without restriction, including without limitation the rights
|
|
|
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
* copies of the Software, and to permit persons to whom the Software is
|
|
|
|
* furnished to do so, subject to the following conditions:
|
|
|
|
*
|
|
|
|
* The above copyright notice and this permission notice shall be included in
|
|
|
|
* all copies or substantial portions of the Software.
|
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
* THE SOFTWARE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
// Micropython setup
|
|
|
|
|
|
|
|
#define MICROPY_HW_BOARD_NAME "ESP32-S3-EYE"
|
|
|
|
#define MICROPY_HW_MCU_NAME "ESP32S3"
|
|
|
|
|
|
|
|
// Shared by the camera and accelerometer
|
|
|
|
#define DEFAULT_I2C_BUS_SDA (&pin_GPIO4)
|
|
|
|
#define DEFAULT_I2C_BUS_SCL (&pin_GPIO5)
|
|
|
|
|
|
|
|
// This is the SD card connection, not the LCD
|
|
|
|
#define DEFAULT_SPI_BUS_SCK (&pin_GPIO39)
|
|
|
|
#define DEFAULT_SPI_BUS_MISO (&pin_GPIO40)
|
|
|
|
#define DEFAULT_SPI_BUS_MOSI (&pin_GPIO38)
|
2022-08-04 16:11:51 -04:00
|
|
|
|
2022-08-04 16:11:52 -04:00
|
|
|
#define CIRCUITPY_BOARD_SPI (2)
|
|
|
|
#define CIRCUITPY_BOARD_SPI_PIN { \
|
|
|
|
{.clock = &pin_GPIO21, .mosi = &pin_GPIO47, .miso = NULL}, \
|
2022-08-05 10:59:10 -04:00
|
|
|
{.clock = &pin_GPIO39, .mosi = &pin_GPIO40, .miso = &pin_GPIO38}, \
|
2022-08-04 16:11:52 -04:00
|
|
|
}
|
|
|
|
|
2022-08-04 16:11:51 -04:00
|
|
|
#define DEFAULT_RESERVED_PSRAM (1048576)
|