Skip to content

CoreElectronics/CE-Arducam-MicroPython

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

53 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

This is the Repo for the Core Electronics port of the Arducam Mega Cameras for the Raspberry Pi Pico (Micropython)

Status: Experimental This driver is very much experimental at the moment. Expect frequent, breaking updates. This project is featured in the 27-July-2023 episode of The Factory - Core Electronics' Engineering and Product Development vlog.

Contributions:

Thank you to @chrisrothwell1 for getting burst reads working - significantly removing the same time for each image (#9)

Thank you to @wil-liammacleod for adding debug mode, a pin reference for the ESP32-S3 and testing on MicroPython 1.24 (#11)

Watch the video

Project Status:

  • Confirmed working on 3MP Camera and 5MP Camera
  • SOLVED: Photos have a green hue, camera_idx identifies the two versions - https://forum.arducam.com/t/mega-3mp-micropython-driver/5708
  • Can set resolution
  • Can set remaining filters and modes
  • Able to set multiple adjustments at the same time (see issue#3)
  • Class moved to separate file
  • Burst read - decrease time to save photo
  • Set SPI Speed higher - decrease time to save photo - Recommended speed from ArduCam 800000 baud, need to implement a check on init
  • Confirm a micro SD card can use the same SPI bus (Micropython compatibility) - requires camera to release SPI bus, bulk reading/writing into bytearray would speed this up
  • Confirm working with the latest Micropython version - Version 1.24 tested
  • Filemanager also handles subfolders for images - Requires examples
  • Confirm that different file formats output correctly (RGB=BMP, YGV?)
  • Confirm that pixel RGB values can be extrapolated from BMP format for machine learning applications

Details

Camera(spi_bus=, cs=, skip_sleep=False, debug_text_enabled=False) The Cameras initialisation method.

Parameter Type Range Default Description
spi_bus SPI Device dependent N/A The SPI Bus the camera is connected to.
cs Pin Device dependent N/A The Pin the CS wire is connected to.
skip_sleep Boolean True, False False Skips the auto-white-balance on the 5MP Mega
debug_text_enabled Boolean True, False False If enabled, prints the status of the camera

Camera.capture_jpg() Capture a JPG photo with the provided settings.

Camera.save_JPG(filename, progress_bar=True) Requires Camera.capture_jpg() to be run first, saves the JPG to the filename provided (it should include the filetype extension .jpg. Note: This function can over-write other photos, we recommend using the filemanager.

Parameter Type Range Default Description
filename str N/A 'image.jpg' The file path for the image.
progress_bar Boolean True, False True Prints a progress bar as the image saves.

License

This project is open source - please review the LICENSE.md file for further licensing information.

If you have any technical questions, or concerns about licensing, please contact technical support on the Core Electronics forums.