Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/ebadier/bezierloader

A C++ application which can load an OBJ file and render the Bezier curves it contains
https://github.com/ebadier/bezierloader

bezier-curves cplusplus obj-files obj-format ogre3d rendering

Last synced: about 2 months ago
JSON representation

A C++ application which can load an OBJ file and render the Bezier curves it contains

Awesome Lists containing this project

README

        

![alt text](doc/bezier.jpg)

BezierLoader
============
An application which can load an OBJ format file, containing one or more Bezier curves, into some internal format.
The application should then render the curves.
Notes:
- The application is written in C++.
- The loader handles any valid Bezier curve in the OBJ format.
- The loader report an error if non-Bezier primitives are found in the file.
- This project use Ogre3D for the rendering part.
- Bezier curves are computed using a Bernstein polynomial.
- Curves are described with a set of controls points and some parameters depending on the rendering technique used:
- Constant Parametric Subdivision
- Constant Space Subdivision
- Curvature Dependent Subdivision

Repository structure
============
- bin : the last released.
- doc : documentation about the BezierLoader project.
- externals : external librairies used in this project.
- media : some assets used to render objects.
- src : the source code.
- vs2010 : a solution to compile the project with Visual Studio 2010.
- BezierLoader.vcxproj generate a static library
- BezierLoaderTest.vcxproj generate an exe to test the functionalities provided by BezierLoader static library.

Test Application
============
You can launch the last release by double-clicking on the "test.bat" file.
Check the "test.bat" file to see how to load your own .obj file.

The application load the curves in the .obj file.
Each curve is rendered with a particular random colour.
Control points are rendered as small spheres.
The curves are rendered as more or less broken lines, depending on the resolution.
You can switch and focus on each curve pressing space bar.

- Controls:
- W,S,A,D + mouse to move the camera.
- Left_Shift : speed up translation.
- Space : switch to the next curve (the camera focus automatically on the next curve).
- Enter : show all curves.
- Esc : Exit.