metaforce/hecl
Jack Andersen bc055b9126 Merge branch 'master' of ssh://gitlab.axiodl.com:6431/AxioDL/hecl 2017-12-22 19:39:48 -10:00
..
bintoc UWP fixes 2017-12-06 18:09:27 -10:00
blender Minor log removal 2017-12-22 19:39:03 -10:00
driver Update boo; Add initial GUI mode support 2017-12-15 18:13:20 -08:00
extern Update boo 2017-12-21 18:17:20 -08:00
extra added extract tool 2015-06-11 23:08:49 -10:00
include/hecl Update boo; Add initial GUI mode support 2017-12-15 18:13:20 -08:00
lib Update boo; Add initial GUI mode support 2017-12-15 18:13:20 -08:00
test UWP support 2017-12-05 17:22:31 -10:00
.gitignore Update boo 2016-01-15 13:35:06 -10:00
.gitmodules Update submodules 2017-12-02 20:01:16 -08:00
CMakeLists.txt UWP fixes 2017-12-06 18:09:27 -10:00
DataSpecRegistry.hpp.in Humungous refactor 2016-03-04 13:02:44 -10:00
Doxyfile implemented lba VFS 2015-05-21 22:21:44 -10:00
LICENSE Update LICENSE date 2017-01-07 14:14:20 -10:00
README.md Update README.md 2016-01-25 10:22:04 -10:00
bootstrap.sh bootstrap tweak 2015-06-25 09:56:15 -10:00

README.md

HECL (high-level, extensible combiner language)

HECL is a toolkit for building custom asset pipelines, assisting the development of conversion tools and runtime loaders.

The most significant feature is the intermediate HECL language, using an expressive command syntax to represent cross-platform shaders. This includes a common source representation and intermediate binary representation. Complete vertex and fragment shader programs are generated for supported platforms and may be built on-demand as part of a 3D application runtime.

# Combiner 1: Opaque *Diffuse* and *Emissive*
HECLOpaque(Texture(0, UV(0)) * Lighting() + Texture(1, UV(0)))

# Combiner 2: Alpha-blended single-texture
# (both texture-accesses folded to a single sample operation)
HECLAlpha(Texture(0, UV(0)), Texture(0, UV(0)).a)

# Combiner 3: Additive-blended single-texture
# (modern graphics APIs require blending configuration along with all shader configs)
HECLAdditive(Texture(0, UV(0)), Texture(0, UV(0)).a)

Beyond shaders, HECL also defines a rigged mesh format called HMDL. Meshes using this encoding interact with HECL, with pose transforms applied via the vertex shader.

For asset pipelines, HECL provides a project system with dependency-resolution much like an IDE or make. Assets in their editable representation are cooked in-bulk and whenever the source file is updated. Currently, blender is the only-supported input format for rigged meshes with node-materials.

Supported Backends

  • GLSL 330 (with optional SPIR-V conversion)
  • HLSL (Shader Model 4)
  • Metal 1.1
  • GX (complete TexCoordGen and TEV configs in intermediate structures)