This is a demo version of the embedded software running on a Yakasaur Rover. This project is a work in progress and might be a bit messy in its current state. The primary purpose of this software is to learn enough ESP-IDF as a proof-of-concept for building a Yakasaur Rover. The project is currently configured to work with a specific board, but it can be easily modified to work with other boards.
- Work in Progress: This repository is currently a demo and might be a bit unorganized. It's actively being developed, so expect frequent changes.
- ESP-IDF: The project is built using esp-idf and includes a devcontainer for a build environment.
- Configuration: All secrets and configurations are sourced from
local.h
. This file is mandatory for the project to function correctly. A template namedlocal.h.sample
is provided to help you set up your ownlocal.h
file. Ensure you never commit thelocal.h
file to the repository. - Yak GDS Integration: This demo assumes that Yakasaur will connect to an API server named Yak GDS. You can find the repository for Yak GDS here.
- Related Repositories and Resources:
- Clone the Repository:
git clone --recursive https://github.com/rhettg/Yakasaur-espidf.git
This should likely go into your platform.io folder, which for me is ~/Documents/PlatformIO/Projects/
Use --recursive
to ensure the submodules (esp32-camera
) are cloned as well.
-
Build and Open in Devcontainer
-
Setup Configuration:
- Copy the
local.h.sample
file tolocal.h
. - Fill in the required details such as wifi and api endpoints.
- Copy the
-
Integration with Yak GDS:
- Ensure the Yak GDS server is running and accessible.
- The Yakasaur will attempt to connect to the Yak GDS server using the URL provided in the
local.h
file.
-
Build and Upload Image
- Use
idf.py build
to create firmware. - Flash your device.
- Use the Serial Monitor to view the output of the program.
- Use
-
Control Yakasaur Remotely:
- Using Yak GDS, send commands to your "Rover".
Feedback, issues, and pull requests are always welcome! If you encounter any problems or have suggestions, please open an issue on the GitHub repository.
Remember, this is a work in progress, and your contributions can help improve it!