Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/txt2u/morph3d
https://github.com/txt2u/morph3d
Last synced: 2 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/txt2u/morph3d
- Owner: txt2u
- License: apache-2.0
- Created: 2024-09-06T12:20:00.000Z (4 months ago)
- Default Branch: master
- Last Pushed: 2024-09-06T12:35:59.000Z (4 months ago)
- Last Synced: 2024-12-17T06:57:58.170Z (25 days ago)
- Language: Rust
- Size: 19.5 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE-APACHE
Awesome Lists containing this project
README
# morph3d
`morph3d` is a Rust crate for loading and processing 3D model files in various formats, including OBJ, GLTF, DAE, USDZ, and STL. This crate provides functionality to extract and manipulate mesh data such as vertices, indices, texture coordinates, and normals, and apply transformations to the loaded meshes.
## Features
- **OBJ Loader**: Load and process OBJ files, including vertices, normals, texture coordinates, and transformation matrices.
- **GLTF Loader**: Load GLTF & GLB files with support for vertices, indices, texture coordinates, normals, and node matrices.### Upcomming
- **DAE Loader**: Load Collada (DAE) files and extract vertices, indices, texture coordinates, and normals.
- **USDZ and STL Support**: Soon.## Getting Started
### Installation
Add `morph3d` to your `Cargo.toml`:
```toml
[dependencies]
morph3d = "0.1.1" # Replace with the latest version
```Or use
```bash
$ cargo add morph3d
```### Usage
```rust
use morph3d::{Loader, ModelFormat, Collection};fn main() {
let mut loader = Loader::new("path/to/your/model.obj", ModelFormat::OBJ);// Load OBJ file
let obj_collection: Vec = loader.load();
// Process obj collections...
}
```### API
#### `Collection`
- `vertices: Vec<[f32; 3]>`: List of vertices in the mesh.
- `indices: Vec`: List of indices for the mesh.
- `texture_coordinates: Vec<[f32; 2]>`: List of texture coordinates.
- `normals: Vec<[f32; 3]>`: List of normals.
- `matrix: Matrix4`: Transformation matrix applied to the mesh.## Contributing
Contributions are welcome! Please open an issue or submit a pull request if you have suggestions or improvements.
## License
This crate is licensed under the MIT License OR Apache 2.0 License. Feel free to choose one of them.
## Acknowledgements
- Thanks to the Rust community and the maintainers of the `dae-parser`, `tobj`, and other libraries used in this project.