glsl-atmosphere
Renders sky colors with Rayleigh and Mie scattering.
Install
npm install glsl-atmosphere
Example
Javascript
var quad = ; program;quad;programuniformsuSunPos = 0 01 -1;quad;
Vertex Shader
attribute vec3 aPosition; varying vec3 vPosition; void
Fragment Shader
varying vec3 vPosition; uniform vec3 uSunPos; # atmosphere = require(glsl-atmosphere) void
API
#pragma glslify: atmosphere =
vec3 atmosphere(vec3 r, vec3 r0, vec3 pSun, float iSun, float rPlanet, float rAtmos, vec3 kRlh, float kMie, float shRlh, float shMie, float g)
Returns a vec3
representing the color of the sky along a view direction.
Takes:
vec3 r
normalized ray direction, typically a ray cast from the observers eye through a pixelvec3 r0
ray origin in meters, typically the position of the viewer's eyevec3 pSun
the position of the sunfloat iSun
intensity of the sunfloat rPlanet
radius of the planet in metersfloat rAtoms
radius of the atmosphere in metersvec3 kRlh
Rayleigh scattering coefficientvec3 kMie
Mie scattering coefficientfloat shRlh
Rayleigh scale height in metersfloat shMie
Mie scale height in metersfloat g
Mie preferred scattering direction
For an Earth-like atmosphere, see the settings in the example above.