2013-02-22 00:07:31 -05:00
|
|
|
/*
|
2015-01-02 17:43:11 -05:00
|
|
|
* Copyright 2011-2015 Branimir Karadzic. All rights reserved.
|
2013-02-22 00:07:31 -05:00
|
|
|
* License: http://www.opensource.org/licenses/BSD-2-Clause
|
|
|
|
*/
|
|
|
|
|
2014-04-29 22:52:10 -04:00
|
|
|
#ifndef BGFX_SHADER_H_HEADER_GUARD
|
|
|
|
#define BGFX_SHADER_H_HEADER_GUARD
|
2013-02-22 00:07:31 -05:00
|
|
|
|
2013-04-11 00:42:00 -04:00
|
|
|
#if !defined(BGFX_CONFIG_MAX_BONES)
|
|
|
|
# define BGFX_CONFIG_MAX_BONES 32
|
|
|
|
#endif // !defined(BGFX_CONFIG_MAX_BONES)
|
|
|
|
|
2013-02-22 00:07:31 -05:00
|
|
|
#ifndef __cplusplus
|
|
|
|
|
|
|
|
#if BGFX_SHADER_LANGUAGE_HLSL
|
|
|
|
# define dFdx(_x) ddx(_x)
|
|
|
|
# define dFdy(_y) ddy(-_y)
|
2013-04-05 23:40:50 -04:00
|
|
|
# define inversesqrt(_x) rsqrt(_x)
|
|
|
|
# define fract(_x) frac(_x)
|
2014-04-29 22:52:10 -04:00
|
|
|
|
|
|
|
# define bvec2 bool2
|
|
|
|
# define bvec3 bool3
|
|
|
|
# define bvec4 bool4
|
2013-02-22 00:07:31 -05:00
|
|
|
|
|
|
|
# if BGFX_SHADER_LANGUAGE_HLSL > 3
|
|
|
|
struct BgfxSampler2D
|
|
|
|
{
|
|
|
|
SamplerState m_sampler;
|
|
|
|
Texture2D m_texture;
|
|
|
|
};
|
|
|
|
|
|
|
|
vec4 bgfxTexture2D(BgfxSampler2D _sampler, vec2 _coord)
|
|
|
|
{
|
|
|
|
return _sampler.m_texture.Sample(_sampler.m_sampler, _coord);
|
|
|
|
}
|
|
|
|
|
|
|
|
vec4 bgfxTexture2DLod(BgfxSampler2D _sampler, vec2 _coord, float _level)
|
|
|
|
{
|
|
|
|
return _sampler.m_texture.SampleLevel(_sampler.m_sampler, _coord, _level);
|
|
|
|
}
|
|
|
|
|
2014-02-23 14:21:23 -05:00
|
|
|
vec4 bgfxTexture2DProj(BgfxSampler2D _sampler, vec3 _coord)
|
|
|
|
{
|
|
|
|
vec2 coord = _coord.xy * rcp(_coord.z);
|
|
|
|
return _sampler.m_texture.Sample(_sampler.m_sampler, coord);
|
|
|
|
}
|
|
|
|
|
|
|
|
vec4 bgfxTexture2DProj(BgfxSampler2D _sampler, vec4 _coord)
|
|
|
|
{
|
|
|
|
vec2 coord = _coord.xy * rcp(_coord.w);
|
|
|
|
return _sampler.m_texture.Sample(_sampler.m_sampler, coord);
|
|
|
|
}
|
|
|
|
|
|
|
|
struct BgfxSampler2DShadow
|
|
|
|
{
|
|
|
|
SamplerComparisonState m_sampler;
|
|
|
|
Texture2D m_texture;
|
|
|
|
};
|
|
|
|
|
|
|
|
float bgfxShadow2D(BgfxSampler2DShadow _sampler, vec3 _coord)
|
|
|
|
{
|
2014-02-25 00:44:12 -05:00
|
|
|
return _sampler.m_texture.SampleCmp(_sampler.m_sampler, _coord.xy, _coord.z * 2.0 - 1.0);
|
2014-02-23 14:21:23 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
float bgfxShadow2DProj(BgfxSampler2DShadow _sampler, vec4 _coord)
|
|
|
|
{
|
|
|
|
vec3 coord = _coord.xyz * rcp(_coord.w);
|
2014-02-25 00:44:12 -05:00
|
|
|
return _sampler.m_texture.SampleCmp(_sampler.m_sampler, coord.xy, coord.z * 2.0 - 1.0);
|
2014-02-23 14:21:23 -05:00
|
|
|
}
|
|
|
|
|
2013-02-22 00:07:31 -05:00
|
|
|
struct BgfxSampler3D
|
|
|
|
{
|
|
|
|
SamplerState m_sampler;
|
|
|
|
Texture3D m_texture;
|
|
|
|
};
|
|
|
|
|
2015-03-17 20:27:04 -04:00
|
|
|
struct BgfxISampler3D
|
|
|
|
{
|
|
|
|
Texture3D<ivec4> m_texture;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct BgfxUSampler3D
|
|
|
|
{
|
|
|
|
Texture3D<uvec4> m_texture;
|
|
|
|
};
|
|
|
|
|
2013-02-22 00:07:31 -05:00
|
|
|
vec4 bgfxTexture3D(BgfxSampler3D _sampler, vec3 _coord)
|
|
|
|
{
|
|
|
|
return _sampler.m_texture.Sample(_sampler.m_sampler, _coord);
|
|
|
|
}
|
|
|
|
|
|
|
|
vec4 bgfxTexture3DLod(BgfxSampler3D _sampler, vec3 _coord, float _level)
|
|
|
|
{
|
|
|
|
return _sampler.m_texture.SampleLevel(_sampler.m_sampler, _coord, _level);
|
|
|
|
}
|
|
|
|
|
2015-03-17 20:27:04 -04:00
|
|
|
ivec4 bgfxTexture3D(BgfxISampler3D _sampler, vec3 _coord)
|
|
|
|
{
|
|
|
|
ivec3 size;
|
|
|
|
_sampler.m_texture.GetDimensions(size.x, size.y, size.z);
|
|
|
|
return _sampler.m_texture.Load(ivec4(_coord * size, 0) );
|
|
|
|
}
|
|
|
|
|
|
|
|
uvec4 bgfxTexture3D(BgfxUSampler3D _sampler, vec3 _coord)
|
|
|
|
{
|
|
|
|
uvec3 size;
|
|
|
|
_sampler.m_texture.GetDimensions(size.x, size.y, size.z);
|
|
|
|
return _sampler.m_texture.Load(uvec4(_coord * size, 0) );
|
|
|
|
}
|
|
|
|
|
2013-02-22 00:07:31 -05:00
|
|
|
struct BgfxSamplerCube
|
|
|
|
{
|
|
|
|
SamplerState m_sampler;
|
|
|
|
TextureCube m_texture;
|
|
|
|
};
|
|
|
|
|
|
|
|
vec4 bgfxTextureCube(BgfxSamplerCube _sampler, vec3 _coord)
|
|
|
|
{
|
|
|
|
return _sampler.m_texture.Sample(_sampler.m_sampler, _coord);
|
|
|
|
}
|
|
|
|
|
|
|
|
vec4 bgfxTextureCubeLod(BgfxSamplerCube _sampler, vec3 _coord, float _level)
|
|
|
|
{
|
|
|
|
return _sampler.m_texture.SampleLevel(_sampler.m_sampler, _coord, _level);
|
|
|
|
}
|
|
|
|
|
|
|
|
# define SAMPLER2D(_name, _reg) \
|
|
|
|
uniform SamplerState _name ## Sampler : register(s[_reg]); \
|
|
|
|
uniform Texture2D _name ## Texture : register(t[_reg]); \
|
|
|
|
static BgfxSampler2D _name = { _name ## Sampler, _name ## Texture }
|
|
|
|
# define sampler2D BgfxSampler2D
|
|
|
|
# define texture2D(_sampler, _coord) bgfxTexture2D(_sampler, _coord)
|
|
|
|
# define texture2DLod(_sampler, _coord, _level) bgfxTexture2DLod(_sampler, _coord, _level)
|
2014-02-23 14:21:23 -05:00
|
|
|
# define texture2DProj(_sampler, _coord) bgfxTexture2DProj(_sampler, _coord)
|
|
|
|
|
|
|
|
# define SAMPLER2DSHADOW(_name, _reg) \
|
|
|
|
uniform SamplerComparisonState _name ## Sampler : register(s[_reg]); \
|
|
|
|
uniform Texture2D _name ## Texture : register(t[_reg]); \
|
|
|
|
static BgfxSampler2DShadow _name = { _name ## Sampler, _name ## Texture }
|
|
|
|
# define sampler2DShadow BgfxSampler2DShadow
|
|
|
|
# define shadow2D(_sampler, _coord) bgfxShadow2D(_sampler, _coord)
|
|
|
|
# define shadow2DProj(_sampler, _coord) bgfxShadow2DProj(_sampler, _coord)
|
2013-02-22 00:07:31 -05:00
|
|
|
|
|
|
|
# define SAMPLER3D(_name, _reg) \
|
|
|
|
uniform SamplerState _name ## Sampler : register(s[_reg]); \
|
|
|
|
uniform Texture3D _name ## Texture : register(t[_reg]); \
|
|
|
|
static BgfxSampler3D _name = { _name ## Sampler, _name ## Texture }
|
2015-03-17 20:27:04 -04:00
|
|
|
# define ISAMPLER3D(_name, _reg) \
|
|
|
|
uniform Texture3D<ivec4> _name ## Texture : register(t[_reg]); \
|
|
|
|
static BgfxISampler3D _name = { _name ## Texture }
|
|
|
|
# define USAMPLER3D(_name, _reg) \
|
|
|
|
uniform Texture3D<uvec4> _name ## Texture : register(t[_reg]); \
|
|
|
|
static BgfxUSampler3D _name = { _name ## Texture }
|
2013-02-22 00:07:31 -05:00
|
|
|
# define sampler3D BgfxSampler3D
|
|
|
|
# define texture3D(_sampler, _coord) bgfxTexture3D(_sampler, _coord)
|
|
|
|
# define texture3DLod(_sampler, _coord, _level) bgfxTexture3DLod(_sampler, _coord, _level)
|
|
|
|
|
|
|
|
# define SAMPLERCUBE(_name, _reg) \
|
|
|
|
uniform SamplerState _name ## Sampler : register(s[_reg]); \
|
|
|
|
uniform TextureCube _name ## Texture : register(t[_reg]); \
|
|
|
|
static BgfxSamplerCube _name = { _name ## Sampler, _name ## Texture }
|
|
|
|
# define samplerCube BgfxSamplerCube
|
|
|
|
# define textureCube(_sampler, _coord) bgfxTextureCube(_sampler, _coord)
|
|
|
|
# define textureCubeLod(_sampler, _coord, _level) bgfxTextureCubeLod(_sampler, _coord, _level)
|
|
|
|
# else
|
2014-02-23 14:21:23 -05:00
|
|
|
|
|
|
|
# define sampler2DShadow sampler2D
|
|
|
|
|
|
|
|
vec4 bgfxTexture2DProj(sampler2D _sampler, vec3 _coord)
|
|
|
|
{
|
|
|
|
return tex2Dproj(_sampler, vec4(_coord.xy, 0.0, _coord.z) );
|
|
|
|
}
|
|
|
|
|
|
|
|
vec4 bgfxTexture2DProj(sampler2D _sampler, vec4 _coord)
|
|
|
|
{
|
|
|
|
return tex2Dproj(_sampler, _coord);
|
|
|
|
}
|
|
|
|
|
|
|
|
float bgfxShadow2D(sampler2DShadow _sampler, vec3 _coord)
|
|
|
|
{
|
2014-02-25 00:44:12 -05:00
|
|
|
#if 0
|
2014-02-23 14:21:23 -05:00
|
|
|
float occluder = tex2D(_sampler, _coord.xy).x;
|
2014-02-25 00:44:12 -05:00
|
|
|
return step(_coord.z * 2.0 - 1.0, occluder);
|
|
|
|
#else
|
|
|
|
return tex2Dproj(_sampler, vec4(_coord.xy, _coord.z * 2.0 - 1.0, 1.0) ).x;
|
|
|
|
#endif // 0
|
2014-02-23 14:21:23 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
float bgfxShadow2DProj(sampler2DShadow _sampler, vec4 _coord)
|
|
|
|
{
|
2014-02-25 00:44:12 -05:00
|
|
|
#if 0
|
2014-02-23 14:21:23 -05:00
|
|
|
vec3 coord = _coord.xyz * rcp(_coord.w);
|
|
|
|
float occluder = tex2D(_sampler, coord.xy).x;
|
2014-02-25 00:44:12 -05:00
|
|
|
return step(coord.z * 2.0 - 1.0, occluder);
|
|
|
|
#else
|
|
|
|
return tex2Dproj(_sampler, _coord).x;
|
|
|
|
#endif // 0
|
2014-02-23 14:21:23 -05:00
|
|
|
}
|
|
|
|
|
2013-02-22 00:07:31 -05:00
|
|
|
# define SAMPLER2D(_name, _reg) uniform sampler2D _name : register(s ## _reg)
|
|
|
|
# define texture2D(_sampler, _coord) tex2D(_sampler, _coord)
|
2014-02-23 14:21:23 -05:00
|
|
|
# define texture2DProj(_sampler, _coord) bgfxTexture2DProj(_sampler, _coord)
|
|
|
|
|
|
|
|
# define SAMPLER2DSHADOW(_name, _reg) uniform sampler2DShadow _name : register(s ## _reg)
|
|
|
|
# define shadow2D(_sampler, _coord) bgfxShadow2D(_sampler, _coord)
|
|
|
|
# define shadow2DProj(_sampler, _coord) bgfxShadow2DProj(_sampler, _coord)
|
|
|
|
|
2013-02-22 00:07:31 -05:00
|
|
|
# define SAMPLER3D(_name, _reg) uniform sampler3D _name : register(s ## _reg)
|
|
|
|
# define texture3D(_sampler, _coord) tex3D(_sampler, _coord)
|
2014-02-23 14:21:23 -05:00
|
|
|
|
2013-02-22 00:07:31 -05:00
|
|
|
# define SAMPLERCUBE(_name, _reg) uniform samplerCUBE _name : register(s[_reg])
|
|
|
|
# define textureCube(_sampler, _coord) texCUBE(_sampler, _coord)
|
2015-04-15 22:54:19 -04:00
|
|
|
|
|
|
|
# if BGFX_SHADER_LANGUAGE_HLSL == 2
|
|
|
|
# define texture2DLod(_sampler, _coord, _level) tex2D(_sampler, (_coord).xy)
|
|
|
|
# define texture3DLod(_sampler, _coord, _level) tex3D(_sampler, (_coord).xyz)
|
|
|
|
# define textureCubeLod(_sampler, _coord, _level) texCUBE(_sampler, (_coord).xyz)
|
|
|
|
# else
|
|
|
|
# define texture2DLod(_sampler, _coord, _level) tex2Dlod(_sampler, vec4( (_coord).xy, 0.0, _level) )
|
|
|
|
# define texture3DLod(_sampler, _coord, _level) tex3Dlod(_sampler, vec4( (_coord).xyz, _level) )
|
|
|
|
# define textureCubeLod(_sampler, _coord, _level) texCUBElod(_sampler, vec4( (_coord).xyz, _level) )
|
2015-04-17 00:53:26 -04:00
|
|
|
# endif // BGFX_SHADER_LANGUAGE_HLSL == 2
|
2015-04-15 22:54:19 -04:00
|
|
|
|
2015-04-17 00:53:26 -04:00
|
|
|
# endif // BGFX_SHADER_LANGUAGE_HLSL > 3
|
2013-02-22 00:07:31 -05:00
|
|
|
|
2014-07-28 23:15:01 -04:00
|
|
|
vec2 vec2_splat(float _x) { return vec2(_x, _x); }
|
|
|
|
vec3 vec3_splat(float _x) { return vec3(_x, _x, _x); }
|
|
|
|
vec4 vec4_splat(float _x) { return vec4(_x, _x, _x, _x); }
|
|
|
|
|
2015-02-23 20:25:06 -05:00
|
|
|
uvec2 uvec2_splat(uint _x) { return uvec2(_x, _x); }
|
|
|
|
uvec3 uvec3_splat(uint _x) { return uvec3(_x, _x, _x); }
|
|
|
|
uvec4 uvec4_splat(uint _x) { return uvec4(_x, _x, _x, _x); }
|
|
|
|
|
2013-02-22 00:07:31 -05:00
|
|
|
vec3 instMul(vec3 _vec, mat3 _mtx) { return mul(_mtx, _vec); }
|
|
|
|
vec3 instMul(mat3 _mtx, vec3 _vec) { return mul(_vec, _mtx); }
|
|
|
|
vec4 instMul(vec4 _vec, mat4 _mtx) { return mul(_mtx, _vec); }
|
|
|
|
vec4 instMul(mat4 _mtx, vec4 _vec) { return mul(_vec, _mtx); }
|
|
|
|
|
|
|
|
bvec2 lessThan(vec2 _a, vec2 _b) { return _a < _b; }
|
|
|
|
bvec3 lessThan(vec3 _a, vec3 _b) { return _a < _b; }
|
|
|
|
bvec4 lessThan(vec4 _a, vec4 _b) { return _a < _b; }
|
|
|
|
|
|
|
|
bvec2 lessThanEqual(vec2 _a, vec2 _b) { return _a <= _b; }
|
2013-04-05 23:40:50 -04:00
|
|
|
bvec3 lessThanEqual(vec3 _a, vec3 _b) { return _a <= _b; }
|
|
|
|
bvec4 lessThanEqual(vec4 _a, vec4 _b) { return _a <= _b; }
|
2013-02-22 00:07:31 -05:00
|
|
|
|
|
|
|
bvec2 greaterThan(vec2 _a, vec2 _b) { return _a > _b; }
|
|
|
|
bvec3 greaterThan(vec3 _a, vec3 _b) { return _a > _b; }
|
|
|
|
bvec4 greaterThan(vec4 _a, vec4 _b) { return _a > _b; }
|
|
|
|
|
|
|
|
bvec2 greaterThanEqual(vec2 _a, vec2 _b) { return _a >= _b; }
|
|
|
|
bvec3 greaterThanEqual(vec3 _a, vec3 _b) { return _a >= _b; }
|
|
|
|
bvec4 greaterThanEqual(vec4 _a, vec4 _b) { return _a >= _b; }
|
|
|
|
|
|
|
|
bvec2 notEqual(vec2 _a, vec2 _b) { return _a != _b; }
|
|
|
|
bvec3 notEqual(vec3 _a, vec3 _b) { return _a != _b; }
|
|
|
|
bvec4 notEqual(vec4 _a, vec4 _b) { return _a != _b; }
|
|
|
|
|
|
|
|
bvec2 equal(vec2 _a, vec2 _b) { return _a == _b; }
|
|
|
|
bvec3 equal(vec3 _a, vec3 _b) { return _a == _b; }
|
|
|
|
bvec4 equal(vec4 _a, vec4 _b) { return _a == _b; }
|
|
|
|
|
2013-04-02 01:52:06 -04:00
|
|
|
float mix(float _a, float _b, float _t) { return lerp(_a, _b, _t); }
|
2014-02-23 14:21:23 -05:00
|
|
|
vec2 mix(vec2 _a, vec2 _b, vec2 _t) { return lerp(_a, _b, _t); }
|
|
|
|
vec3 mix(vec3 _a, vec3 _b, vec3 _t) { return lerp(_a, _b, _t); }
|
|
|
|
vec4 mix(vec4 _a, vec4 _b, vec4 _t) { return lerp(_a, _b, _t); }
|
2013-02-22 00:07:31 -05:00
|
|
|
|
2013-04-02 01:52:06 -04:00
|
|
|
float mod(float _a, float _b) { return _a - _b * floor(_a / _b); }
|
2014-02-23 14:21:23 -05:00
|
|
|
vec2 mod(vec2 _a, vec2 _b) { return _a - _b * floor(_a / _b); }
|
|
|
|
vec3 mod(vec3 _a, vec3 _b) { return _a - _b * floor(_a / _b); }
|
|
|
|
vec4 mod(vec4 _a, vec4 _b) { return _a - _b * floor(_a / _b); }
|
2013-04-02 01:52:06 -04:00
|
|
|
|
2013-02-22 00:07:31 -05:00
|
|
|
#elif BGFX_SHADER_LANGUAGE_GLSL
|
|
|
|
# define atan2(_x, _y) atan(_x, _y)
|
|
|
|
# define mul(_a, _b) ( (_a) * (_b) )
|
|
|
|
# define saturate(_x) clamp(_x, 0.0, 1.0)
|
|
|
|
# define SAMPLER2D(_name, _reg) uniform sampler2D _name
|
|
|
|
# define SAMPLER3D(_name, _reg) uniform sampler3D _name
|
|
|
|
# define SAMPLERCUBE(_name, _reg) uniform samplerCube _name
|
2014-02-23 14:21:23 -05:00
|
|
|
# define SAMPLER2DSHADOW(_name, _reg) uniform sampler2DShadow _name
|
2013-02-22 00:07:31 -05:00
|
|
|
# define vec2_splat(_x) vec2(_x)
|
|
|
|
# define vec3_splat(_x) vec3(_x)
|
|
|
|
# define vec4_splat(_x) vec4(_x)
|
2015-02-23 20:25:06 -05:00
|
|
|
# define uvec2_splat(_x) uvec2(_x)
|
|
|
|
# define uvec3_splat(_x) uvec3(_x)
|
|
|
|
# define uvec4_splat(_x) uvec4(_x)
|
2013-02-22 00:07:31 -05:00
|
|
|
|
2015-03-17 20:27:04 -04:00
|
|
|
# if BGFX_SHADER_LANGUAGE_GLSL >= 130
|
|
|
|
# define ISAMPLER3D(_name, _reg) uniform isampler3D _name
|
|
|
|
# define USAMPLER3D(_name, _reg) uniform usampler3D _name
|
|
|
|
ivec4 texture3D(isampler3D _sampler, vec3 _coord) { return texture(_sampler, _coord); }
|
|
|
|
uvec4 texture3D(usampler3D _sampler, vec3 _coord) { return texture(_sampler, _coord); }
|
|
|
|
# endif // BGFX_SHADER_LANGUAGE_GLSL >= 130
|
|
|
|
|
2013-02-22 00:07:31 -05:00
|
|
|
vec3 instMul(vec3 _vec, mat3 _mtx) { return mul(_vec, _mtx); }
|
|
|
|
vec3 instMul(mat3 _mtx, vec3 _vec) { return mul(_mtx, _vec); }
|
|
|
|
vec4 instMul(vec4 _vec, mat4 _mtx) { return mul(_vec, _mtx); }
|
|
|
|
vec4 instMul(mat4 _mtx, vec4 _vec) { return mul(_mtx, _vec); }
|
2013-04-05 23:40:50 -04:00
|
|
|
|
|
|
|
float rcp(float _a) { return 1.0/_a; }
|
2014-02-23 14:21:23 -05:00
|
|
|
vec2 rcp(vec2 _a) { return vec2(1.0)/_a; }
|
|
|
|
vec3 rcp(vec3 _a) { return vec3(1.0)/_a; }
|
|
|
|
vec4 rcp(vec4 _a) { return vec4(1.0)/_a; }
|
2013-02-22 00:07:31 -05:00
|
|
|
#endif // BGFX_SHADER_LANGUAGE_HLSL
|
|
|
|
|
2014-02-23 14:21:23 -05:00
|
|
|
uniform vec4 u_viewRect;
|
|
|
|
uniform vec4 u_viewTexel;
|
|
|
|
uniform mat4 u_view;
|
2014-05-10 23:51:44 -04:00
|
|
|
uniform mat4 u_invView;
|
|
|
|
uniform mat4 u_proj;
|
|
|
|
uniform mat4 u_invProj;
|
2014-02-23 14:21:23 -05:00
|
|
|
uniform mat4 u_viewProj;
|
2014-05-10 23:51:44 -04:00
|
|
|
uniform mat4 u_invViewProj;
|
2014-02-23 14:21:23 -05:00
|
|
|
uniform mat4 u_model[BGFX_CONFIG_MAX_BONES];
|
|
|
|
uniform mat4 u_modelView;
|
|
|
|
uniform mat4 u_modelViewProj;
|
2013-04-02 01:52:06 -04:00
|
|
|
uniform float u_alphaRef;
|
|
|
|
|
2013-02-22 00:07:31 -05:00
|
|
|
#endif // __cplusplus
|
|
|
|
|
2014-04-29 22:52:10 -04:00
|
|
|
#endif // BGFX_SHADER_H_HEADER_GUARD
|