Skip to content
forked from jpcy/xatlas

Mesh parameterization library

License

Notifications You must be signed in to change notification settings

prideout/xatlas

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

xatlas

Travis CI Build Status License: MIT

A cleaned up version of thekla_atlas.

Mesh charting, parameterization and atlas packing. Suitable for generating unique texture coordinates for baking lightmaps.

Changes from thekla_atlas

  • Smaller code size - from about 18 KLOC to 8 KLOC
  • Easier to integrate and build - a single source/header file pair instead of around 120 files and 10 directories.
  • Atlas resolution option for outputting multiple atlases.
  • Flexible data description API for input meshes.
  • Better tolerance of bad input geometry. Zero length edges and zero area faces are ignored.

How to use

  1. Create an atlas with xatlas::Create.
  2. Add one or more meshes with xatlas::AddMesh. Mesh geometry should be manifold.
  3. Call xatlas::ComputeCharts. Meshes are segmented into roughly disk-shaped charts.
  4. Call xatlas::ParameterizeCharts. Charts are flattened into 2D parameterizations.
  5. Call xatlas::PackCharts. Charts are packed into one or more atlases. You can call xatlas::PackCharts multiple times to tweak options like unit to texel scale and resolution.
  6. The xatlas::Atlas instance created in the first step now contains the result: meshes with a new UV channel that cross-reference input meshes. The number of vertices has likely increased compared to the input meshes, as the new UV channel duplicates some vertices that were previously shared between triangles. The number and coherence of indices remain unchanged, some are changed to reference vertices that were duplicated.
  7. Cleanup with xatlas::Destroy.

TODO

  • Adding meshes: check for overlapping and intersecting geometry
  • Charting: simplified/faster code path for dealing with co-planar connected faces
  • Parameterization: use a better hole filling argorithm for non-planar holes
  • Packing: bilinear-aware rasterization
  • Packing: faster brute-force packing

Links

Ignacio Castaño's blog post on thekla_atlas

Microsoft's UVAtlas

Ministry of Flat - Commercial automated UV unwrapper.

Lightmapper - Hemicube based lightmap baking. The example model texture coordinates were generated by thekla_atlas.

aobaker - Ambient occlusion baking. Uses thekla_atlas.

Gazebo model by Teh_Bucket

Tunnel scene by LMHPoly

About

Mesh parameterization library

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 55.0%
  • C 41.7%
  • Lua 1.5%
  • Scala 1.1%
  • SuperCollider 0.6%
  • Shell 0.1%