Skip to content
Snippets Groups Projects
Commit 37648b41 authored by Alexander Rose's avatar Alexander Rose
Browse files

added uInteriorDarkening factor to renderer

parent fac183c2
No related branches found
No related tags found
No related merge requests found
...@@ -169,6 +169,7 @@ export const GlobalUniformSchema = { ...@@ -169,6 +169,7 @@ export const GlobalUniformSchema = {
uFogColor: UniformSpec('v3'), uFogColor: UniformSpec('v3'),
uPickingAlphaThreshold: UniformSpec('f'), uPickingAlphaThreshold: UniformSpec('f'),
uInteriorDarkening: UniformSpec('f'),
} }
export type GlobalUniformSchema = typeof GlobalUniformSchema export type GlobalUniformSchema = typeof GlobalUniformSchema
export type GlobalUniformValues = Values<GlobalUniformSchema> // { [k in keyof GlobalUniformSchema]: ValueCell<any> } export type GlobalUniformValues = Values<GlobalUniformSchema> // { [k in keyof GlobalUniformSchema]: ValueCell<any> }
......
...@@ -47,6 +47,7 @@ interface Renderer { ...@@ -47,6 +47,7 @@ interface Renderer {
export const RendererParams = { export const RendererParams = {
backgroundColor: PD.Color(Color(0x000000)), backgroundColor: PD.Color(Color(0x000000)),
pickingAlphaThreshold: PD.Numeric(0.5, { min: 0.0, max: 1.0, step: 0.01 }, { description: 'The minimum opacity value needed for an object to be pickable.' }), pickingAlphaThreshold: PD.Numeric(0.5, { min: 0.0, max: 1.0, step: 0.01 }, { description: 'The minimum opacity value needed for an object to be pickable.' }),
interiorDarkening: PD.Numeric(0.5, { min: 0.0, max: 1.0, step: 0.01 }),
lightIntensity: PD.Numeric(0.6, { min: 0.0, max: 1.0, step: 0.01 }), lightIntensity: PD.Numeric(0.6, { min: 0.0, max: 1.0, step: 0.01 }),
ambientIntensity: PD.Numeric(0.4, { min: 0.0, max: 1.0, step: 0.01 }), ambientIntensity: PD.Numeric(0.4, { min: 0.0, max: 1.0, step: 0.01 }),
...@@ -107,6 +108,7 @@ namespace Renderer { ...@@ -107,6 +108,7 @@ namespace Renderer {
uFogColor: ValueCell.create(bgColor), uFogColor: ValueCell.create(bgColor),
uPickingAlphaThreshold: ValueCell.create(p.pickingAlphaThreshold), uPickingAlphaThreshold: ValueCell.create(p.pickingAlphaThreshold),
uInteriorDarkening: ValueCell.create(p.interiorDarkening),
} }
const globalUniformList = Object.entries(globalUniforms) const globalUniformList = Object.entries(globalUniforms)
...@@ -232,6 +234,10 @@ namespace Renderer { ...@@ -232,6 +234,10 @@ namespace Renderer {
p.pickingAlphaThreshold = props.pickingAlphaThreshold p.pickingAlphaThreshold = props.pickingAlphaThreshold
ValueCell.update(globalUniforms.uPickingAlphaThreshold, p.pickingAlphaThreshold) ValueCell.update(globalUniforms.uPickingAlphaThreshold, p.pickingAlphaThreshold)
} }
if (props.interiorDarkening !== undefined && props.interiorDarkening !== p.interiorDarkening) {
p.interiorDarkening = props.interiorDarkening
ValueCell.update(globalUniforms.uInteriorDarkening, p.interiorDarkening)
}
if (props.backgroundColor !== undefined && props.backgroundColor !== p.backgroundColor) { if (props.backgroundColor !== undefined && props.backgroundColor !== p.backgroundColor) {
p.backgroundColor = props.backgroundColor p.backgroundColor = props.backgroundColor
Color.toVec3Normalized(bgColor, p.backgroundColor) Color.toVec3Normalized(bgColor, p.backgroundColor)
......
...@@ -13,6 +13,12 @@ export default ` ...@@ -13,6 +13,12 @@ export default `
#endif #endif
#endif #endif
#if defined(dColorType_uniform) || defined(dColorType_attribute) || defined(dColorType_instance) || defined(dColorType_group) || defined(dColorType_groupInstance)
if (gl_FrontFacing == false) {
material.rgb *= 1.0 - uInteriorDarkening;
}
#endif
// mix material with overpaint // mix material with overpaint
#if defined(dOverpaint) && (defined(dColorType_uniform) || defined(dColorType_attribute) || defined(dColorType_instance) || defined(dColorType_group) || defined(dColorType_groupInstance)) #if defined(dOverpaint) && (defined(dColorType_uniform) || defined(dColorType_attribute) || defined(dColorType_instance) || defined(dColorType_group) || defined(dColorType_groupInstance))
material.rgb = mix(material.rgb, vOverpaint.rgb, vOverpaint.a); material.rgb = mix(material.rgb, vOverpaint.rgb, vOverpaint.a);
......
...@@ -18,4 +18,6 @@ uniform vec3 uFogColor; ...@@ -18,4 +18,6 @@ uniform vec3 uFogColor;
uniform float uAlpha; uniform float uAlpha;
uniform float uPickingAlphaThreshold; uniform float uPickingAlphaThreshold;
uniform int uPickable; uniform int uPickable;
uniform float uInteriorDarkening;
` `
\ No newline at end of file
...@@ -14,10 +14,6 @@ precision highp int; ...@@ -14,10 +14,6 @@ precision highp int;
#include light_frag_params #include light_frag_params
uniform mat4 uProjection; uniform mat4 uProjection;
// uniform vec3 uInteriorColor;
// uniform float uInteriorDarkening;
vec3 uInteriorColor = vec3(0.5, 0.5, 0.5);
float uInteriorDarkening = 0.0;
uniform float uClipNear; uniform float uClipNear;
uniform float uIsOrtho; uniform float uIsOrtho;
...@@ -53,7 +49,7 @@ bool Impostor(out vec3 cameraPos, out vec3 cameraNormal){ ...@@ -53,7 +49,7 @@ bool Impostor(out vec3 cameraPos, out vec3 cameraNormal){
float B = dot(rayDirection, cameraSphereDir); float B = dot(rayDirection, cameraSphereDir);
float det = B * B + vRadiusSq - dot(cameraSphereDir, cameraSphereDir); float det = B * B + vRadiusSq - dot(cameraSphereDir, cameraSphereDir);
if(det < 0.0){ if (det < 0.0){
discard; discard;
return false; return false;
} }
...@@ -65,16 +61,16 @@ bool Impostor(out vec3 cameraPos, out vec3 cameraNormal){ ...@@ -65,16 +61,16 @@ bool Impostor(out vec3 cameraPos, out vec3 cameraNormal){
cameraPos = rayDirection * negT + rayOrigin; cameraPos = rayDirection * negT + rayOrigin;
#ifdef NEAR_CLIP #ifdef NEAR_CLIP
if(calcDepth(cameraPos) <= 0.0){ if (calcDepth(cameraPos) <= 0.0){
cameraPos = rayDirection * posT + rayOrigin; cameraPos = rayDirection * posT + rayOrigin;
interior = true; interior = true;
}else if(calcClip(cameraPos) > 0.0){ } else if(calcClip(cameraPos) > 0.0) {
cameraPos = rayDirection * posT + rayOrigin; cameraPos = rayDirection * posT + rayOrigin;
interior = true; interior = true;
flag2 = true; flag2 = true;
} }
#else #else
if(calcDepth(cameraPos) <= 0.0){ if (calcDepth(cameraPos) <= 0.0) {
cameraPos = rayDirection * posT + rayOrigin; cameraPos = rayDirection * posT + rayOrigin;
interior = true; interior = true;
} }
...@@ -90,24 +86,24 @@ void main(void){ ...@@ -90,24 +86,24 @@ void main(void){
bool flag = Impostor(cameraPos, cameraNormal); bool flag = Impostor(cameraPos, cameraNormal);
#ifdef NEAR_CLIP #ifdef NEAR_CLIP
if(calcClip(cameraPos) > 0.0) if (calcClip(cameraPos) > 0.0)
discard; discard;
#endif #endif
// FIXME not compatible with custom clipping plane // FIXME not compatible with custom clipping plane
// Set the depth based on the new cameraPos. // Set the depth based on the new cameraPos.
gl_FragDepthEXT = calcDepth(cameraPos); gl_FragDepthEXT = calcDepth(cameraPos);
if(!flag){ if (!flag) {
// clamp to near clipping plane and add a tiny value to // clamp to near clipping plane and add a tiny value to
// make spheres with a greater radius occlude smaller ones // make spheres with a greater radius occlude smaller ones
#ifdef NEAR_CLIP #ifdef NEAR_CLIP
if( flag2 ){ if (flag2) {
gl_FragDepthEXT = max(0.0, calcDepth(vec3(-(uClipNear - 0.5))) + (0.0000001 / vRadius)); gl_FragDepthEXT = max(0.0, calcDepth(vec3(-(uClipNear - 0.5))) + (0.0000001 / vRadius));
}else if(gl_FragDepthEXT >= 0.0){ } else if (gl_FragDepthEXT >= 0.0) {
gl_FragDepthEXT = 0.0 + (0.0000001 / vRadius); gl_FragDepthEXT = 0.0 + (0.0000001 / vRadius);
} }
#else #else
if(gl_FragDepthEXT >= 0.0){ if (gl_FragDepthEXT >= 0.0) {
gl_FragDepthEXT = 0.0 + (0.0000001 / vRadius); gl_FragDepthEXT = 0.0 + (0.0000001 / vRadius);
} }
#endif #endif
...@@ -132,11 +128,8 @@ void main(void){ ...@@ -132,11 +128,8 @@ void main(void){
vec3 vViewPosition = -cameraPos; vec3 vViewPosition = -cameraPos;
#include apply_light_color #include apply_light_color
if(interior){ if (interior) {
#ifdef USE_INTERIOR_COLOR gl_FragColor.rgb = material.rgb * (1.0 - uInteriorDarkening);
gl_FragColor.rgb = uInteriorColor;
#endif
gl_FragColor.rgb *= 1.0 - uInteriorDarkening;
} }
#include apply_marker_color #include apply_marker_color
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment