Skip to content
forked from Master-J/DecalCo

Shader based decal solution for the Godot game engine

License

Notifications You must be signed in to change notification settings

bengtsts/DecalCo

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

11 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

DecalCo

What is DecalCO?

DecalCO is a shader based solution for the Godot game engine. Decals are a great tool used to add details to a 3d object without having to add more details to its geometry or using really large texture maps.

You can use decal to add things like bullet holes, blood splashes, water puddles in your scenes.

System requirements

Godot game engine version 3.2. DecalCO should work with 3.1 version of the Godot game engine too but not confirmed yet. The 3.0 version of the Godot game engine isn't supported because of an engine bug concerning the depth buffer.

Features

DecalCO's decals offer the following features :

  • Texture mapping (albedo, specular, emission, normal map)
  • Flipbook animation (useful to animate things like rain drops)
  • Shadow mapping
  • Multiple lights.

Intallation

  • Download DecalCO's source code
  • Unzip it and copy the "decalco" folder into your Godot's project folder.

DecalCO is also available on the Godot game engine's Asset Library, you can also download and install it directly from the engine's editor.

How to use DecalCO?

DecalCO uses a node based approach to make things easier.

To add a new decal to your scene, open the "Add Node" window and search for the "Decal" Node . adddecal

DecalCO's decals are projected along their negative local Z axis, make sure this axis is perpendicular (like in the screenshot below) with the surface the decal is projected on to avoid wrong projections. projection

If you want to project a decal in a corner, you can try doing the following : projectionAngle

A demo scene showcasing how you can use this plugin and its features is available in the examples folder. demo

Performance

Because the engine currently doesn't offer per instance uniforms for materials, each decals you add to your scene will have it's own material instance (so 1 decal = 1 unique material, 5 decal = 5 unique materials), this is required to make scaling and rotating work.

Having a dozen decals in your camera's view frustum shouldn't be a problem but don't expect high performances with hundreds of displayed decals.

Known issues and limitations

  • GLES2.0 projections update with a delay when the camera moves.
  • GLES2.0 normal maps may look considerably worse than they do with GLES3.0 depending on viewing angle and light setup.
  • GLES2.0 in DecalCo uses DEPTH_TEXTURE which may not work on some old hardware; especially mobile, as stated in the official documentation.
  • PBR lighting not supported because of some hacks necessary for the shader to work, PBR could be done if things like the iradiance texture is exposed to the light shader.
  • Specular lighting only works with a single light.
  • Decal wrapping on sharp angles produce ugly results, this could be solved by cliping the decal on those spots but will require to compute the face normal using the screen texture which would make the shader even less efficient than it already is.

About

Shader based decal solution for the Godot game engine

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • GLSL 63.6%
  • GDScript 36.4%