This is the research prototype implementing the occluding contours extraction method described in the following publication:
Computing Smooth Surface Contours with Accurate Topology. Pierre Bénard, Aaron Hertzmann, Michael Kass. ACM Transactions on Graphics, 2014
Disclaimer: This version of the mesh generation code is not exactly the same as the one used for producing the results in the paper. We had to switch to OpenSubdiv to be able to release it. The precision of the root-finding procedure is lower, which may impact the tessellation.
Note: This is research software. As such, it may fail to run, crash, or otherwise not perform as expected. It is not intended for regular use in any kind of production pipeline.
The code is based on a skimmed and tweaked version of OpenSubdiv and a heavily modified version of Freestyle (included). The mesh generation algorithm is implemented as a RifFilter; you will either need Pixar's RenderMan or 3Delight Studio Pro (free licence available) to build and run it.
Required:
- cmake version 2.8.6 minimum
- Qt5 libraries version 5.4 minimum (Freestyle)
- libQGLViewer version 2.7 minimum (Freestyle)
- SWIG with Python 2.7(Freestyle)
Optional:
Tested on Linux (gcc 4.8) and OS X (clang), not tested on Windows.
Clone the repository:
git clone https://github.com/benardp/contours
Generate Makefiles and build the project:
Assuming that you want the binaries installed into a "build" directory at the root of the source tree :
cd contours
mkdir build
cd build
cmake ..
make
make install
We provide scripts to run the mesh generation algorithm and contours extraction code on a sequence of RIB files. We provide two test sequences (torus and Stanford Bunny) on the project web page; you can export other shots using RenderMan or 3Delight for Maya, or 3Dlight/Blender.
The settings are specified in build/scripts/settings.py
. You need to
provide the local paths to the input and output shots directories on
your machine through the variables mainTestShotFolder
and
mainOutputFolder
(mandatory). The shot
parameter allows you to
choose the sequence that you want to process; it needs to match
the name of the subdirectory containing the RIB files.
Then, to run the code:
# from the "build" directory
cd scripts
python npr.py
The output PLY meshes and curves (EPS, PDF and, on OS X, PNG files)
are saved in a subdirectory of mainOutputFolder
.