Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nthnn/goblin3d
Graphics engine for rendering 3D wireframe on monochromatic displays and TFT LCDs without any dependency required for Arduino platform.
https://github.com/nthnn/goblin3d
3d-engine 3d-graphics 3d-renderer 3d-wireframe arduino-display arduino-library
Last synced: about 2 months ago
JSON representation
Graphics engine for rendering 3D wireframe on monochromatic displays and TFT LCDs without any dependency required for Arduino platform.
- Host: GitHub
- URL: https://github.com/nthnn/goblin3d
- Owner: nthnn
- License: mit
- Created: 2024-08-11T14:20:41.000Z (5 months ago)
- Default Branch: main
- Last Pushed: 2024-08-18T16:07:17.000Z (5 months ago)
- Last Synced: 2024-08-18T17:32:09.727Z (5 months ago)
- Topics: 3d-engine, 3d-graphics, 3d-renderer, 3d-wireframe, arduino-display, arduino-library
- Language: C
- Homepage: https://nthnn.github.io/goblin3d/
- Size: 28.5 MB
- Stars: 2
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
Goblin3D
![Arduino CI](https://github.com/nthnn/goblin3d/actions/workflows/arduino_ci.yml/badge.svg)
![Arduino Lint](https://github.com/nthnn/goblin3d/actions/workflows/arduino_lint.yml/badge.svg)
![SDL2 Port CI](https://github.com/nthnn/goblin3d/actions/workflows/sdl2_ci.yml/badge.svg)
![Arduino Release](https://img.shields.io/badge/Library%20Manager-v0.0.2-red?logo=Arduino)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://github.com/nthnn/goblin3d/blob/main/LICENSE)**Goblin3D** is a lightweight, dependency-free graphics engine designed for rendering 3D wireframes on monochromatic displays and TFT LCDs using the Arduino platform. Goblin3D is perfect for embedded systems where resources are limited but 3D rendering capabilities are desired.
Goblin3D demo with ESP32 on TFT and OLED.> [!NOTE]
> This library is also compatible with desktop environments.## Features
- **3D Wireframe Rendering**: Render basic 3D shapes as wireframes on displays.
- **Flexible Display Support**: Compatible with various display types, including OLEDs and TFT LCDs.
- **No External Dependencies**: Goblin3D is a standalone library that does not require any additional libraries, making it easy to integrate into any Arduino project.
- **Customizable Objects**: Easily define and manipulate custom 3D objects with your own vertices and edges.
- **Rotation and Scaling**: Support for rotating and scaling objects in 3D space.
- **Directly `*.obj` Rendering**: Goblin3D can render `*.obj` files made with Blender directly from SD card.
Goblin3D port with SDL2## Installation
### Arduino Library Manager
1. Open the Arduino IDE.
2. Go to **Sketch** > **Include Library** > **Manage Libraries...**
3. Search for **Goblin3D**.
4. Click **Install**.### Manual Installation
1. Download the latest release from the [Releases](https://github.com/nthnn/goblin3d/releases) page.
2. Unzip the downloaded file.
3. Move the `Goblin3D` folder to your Arduino libraries directory (typically `~/Documents/Arduino/libraries/` on Windows and Linux, `~/Documents/Arduino/libraries/` on macOS).
4. Restart the Arduino IDE.## Getting Started
### Quick Start
Goblin3D SDL2 port example is availble on Docker to try it out.
```bash
docker pull nthnn/goblin3d
docker run -it -e DISPLAY=$DISPLAY -v /tmp/.X11-unix:/tmp/.X11-unix goblin3d
```### Basic Usage
Here’s a simple example of how to use Goblin3D to load an `*.obj` file from SD card to TFT ILI9341 display.
```cpp
#include // Include the SPI library for SPI communication
#include // Include the SD card library for loading files
#include // Include the TFT_eSPI for display driver
#include // Include the Goblin3D library for 3D rendering#define SD_CS 2 // SD card chip select pin
#define SD_SCK 14 // SD card SPI clock pin
#define SD_MOSI 13 // SD card SPI MOSI pin
#define SD_MISO 12 // SD card SPI MISO pinTFT_eSPI tft = TFT_eSPI(320, 240); // Initialize the TFT display with 320x240 resolution
SPIClass sdSpi(HSPI); // SPI instance for SD card
goblin3d_obj_t obj; // Declare a 3D object using the Goblin3D structure/*
* This function will be passed to Goblin3D's
* render function to draw edges between 3D
* points onto the 2D display.
*/
void drawLine(uint16_t x1, uint16_t y1, uint16_t x2, uint16_t y2) {
tft.drawLine(x1, y1, x2, y2, TFT_WHITE); // Draw a white line between the given coordinates
}void setup() {
// Initialize SD card
sdSpi.begin(SD_SCK, SD_MISO, SD_MOSI, SD_CS);
if(!SD.begin(SD_CS, sdSpi, 80000000)) {
Serial.begin(115200); // Start serial communication for debugging
Serial.println("Card mount failed."); // Print error message if initialization failswhile(true); // Halt execution if initialization fails
}// Load the /monkey.obj file as Goblin3D object
if(!goblin3d_parse_obj_file("/monkey.obj", &obj)) {
Serial.begin(115200); // Start serial communication for debugging
Serial.println("Failed to initialize object."); // Print error message if initialization failswhile(true); // Halt execution if initialization fails
}// Set the scaling factor for the 3D object
obj.scale_size = 230.0;
// Set the initial X and Y offset to center the object on the display
obj.x_offset = 160;
obj.y_offset = 120;// Initialize the TFT display with black background color
tft.init();
tft.fillScreen(ILI9341_BLACK);
}void loop() {
// Continuously update the rotation angles for a rotating effect
obj.x_angle_deg = fmod(obj.x_angle_deg + 1.0, 360.0); // Increment X rotation
obj.y_angle_deg = fmod(obj.y_angle_deg + 1.0, 360.0); // Increment Y rotation
obj.z_angle_deg = fmod(obj.z_angle_deg + 1.0, 360.0); // Increment Z rotationgoblin3d_precalculate(&obj); // Perform rendition pre-calculations
tft.startWrite(); // Start the rendition SPI transaction
tft.fillScreen(ILI9341_BLACK); // Clear the display before drawing the new frame
goblin3d_render(&obj, &drawLine); // Render the object on the TFT display
tft.endWrite(); // End the SPI transactiondelay(10); // Sleep after ending the transaction
}
```## Exporting from Blender
Follow these steps to export a 3D scene from Blender in a format compatible with Goblin3D:
1. **Open the Export Menu**
In Blender, navigate to the top menu bar and select `File > Export > Wavefront (.obj)`. This will allow you to export your 3D scene in the OBJ format, which Goblin3D can read and render as a wireframe.
2. **Configure the Export Settings**
Before saving the file, ensure that the `Vertex Groups` option is selected. This will export the vertex information needed for wireframe rendering.
Optionally, you can check the `Triangulate Faces` option to convert all faces into triangles, which is commonly used in wireframe rendering to ensure consistent results across different models.
3. **Save the OBJ File**
When saving, you do not need to include the Material File (*.mtl) since Goblin3D only renders the wireframe, and materials are not required for this purpose. Simply save the OBJ file, and it's ready for use with Goblin3D.
## Use Cases
1. **Low-Power Displays**
Goblin3D can be used for rendering 3D wireframe graphics on low-power, monochrome displays (e.g., OLEDs, TFTs) in embedded systems, which often lack the resources for full shading or texture mapping.
2. **Wearable Devices**
It can be integrated into wearable tech with small displays, such as smartwatches, where simple 3D visualizations like fitness progress or notifications might be shown in wireframe.
3. **3D Modeling Previews**
Designers can use Goblin3D to quickly preview 3D models in a wireframe format, providing a sense of object geometry before moving to a more detailed rendering process.
4. **Retro 3D Games**
Goblin3D can be used to develop retro-style 3D games on resource-constrained devices, where wireframe graphics give a nostalgic feel while minimizing resource usage.
## Contribution and Feedback
Contributions and feedback are all welcome to enhance this library. If you encounter any issues, have suggestions for improvements, or would like to contribute code, please do so.
## License
Copyright 2024 - Nathanne Isip
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.