Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
fktz008
three.js
提交
ccf6d803
T
three.js
项目概览
fktz008
/
three.js
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
three.js
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
ccf6d803
编写于
12月 21, 2011
作者:
A
alteredq
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fixed shadow darkness for non-soft shadow code path.
上级
47523c5f
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
3 addition
and
3 deletion
+3
-3
build/Three.js
build/Three.js
+1
-1
build/custom/ThreeWebGL.js
build/custom/ThreeWebGL.js
+1
-1
src/renderers/WebGLShaders.js
src/renderers/WebGLShaders.js
+1
-1
未找到文件。
build/Three.js
浏览文件 @
ccf6d803
...
...
@@ -205,7 +205,7 @@ lights_phong_fragment:"vec3 normal = normalize( vNormal );\nvec3 viewPosition =
color_pars_fragment
:
"
#ifdef USE_COLOR
\n
varying vec3 vColor;
\n
#endif
"
,
color_fragment
:
"
#ifdef USE_COLOR
\n
gl_FragColor = gl_FragColor * vec4( vColor, opacity );
\n
#endif
"
,
color_pars_vertex
:
"
#ifdef USE_COLOR
\n
varying vec3 vColor;
\n
#endif
"
,
color_vertex
:
"
#ifdef USE_COLOR
\n
#ifdef GAMMA_INPUT
\n
vColor = color * color;
\n
#else
\n
vColor = color;
\n
#endif
\n
#endif
"
,
skinning_pars_vertex
:
"
#ifdef USE_SKINNING
\n
uniform mat4 boneGlobalMatrices[ MAX_BONES ];
\n
#endif
"
,
skinning_vertex
:
"
#ifdef USE_SKINNING
\n
gl_Position = ( boneGlobalMatrices[ int( skinIndex.x ) ] * skinVertexA ) * skinWeight.x;
\n
gl_Position += ( boneGlobalMatrices[ int( skinIndex.y ) ] * skinVertexB ) * skinWeight.y;
\n
gl_Position = projectionMatrix * viewMatrix * objectMatrix * gl_Position;
\n
#endif
"
,
morphtarget_pars_vertex
:
"
#ifdef USE_MORPHTARGETS
\n
uniform float morphTargetInfluences[ 8 ];
\n
#endif
"
,
morphtarget_vertex
:
"
#ifdef USE_MORPHTARGETS
\n
vec3 morphed = vec3( 0.0, 0.0, 0.0 );
\n
morphed += ( morphTarget0 - position ) * morphTargetInfluences[ 0 ];
\n
morphed += ( morphTarget1 - position ) * morphTargetInfluences[ 1 ];
\n
morphed += ( morphTarget2 - position ) * morphTargetInfluences[ 2 ];
\n
morphed += ( morphTarget3 - position ) * morphTargetInfluences[ 3 ];
\n
morphed += ( morphTarget4 - position ) * morphTargetInfluences[ 4 ];
\n
morphed += ( morphTarget5 - position ) * morphTargetInfluences[ 5 ];
\n
morphed += ( morphTarget6 - position ) * morphTargetInfluences[ 6 ];
\n
morphed += ( morphTarget7 - position ) * morphTargetInfluences[ 7 ];
\n
morphed += position;
\n
gl_Position = projectionMatrix * modelViewMatrix * vec4( morphed, 1.0 );
\n
#endif
"
,
default_vertex
:
"
#ifndef USE_MORPHTARGETS
\n
#ifndef USE_SKINNING
\n
gl_Position = projectionMatrix * mvPosition;
\n
#endif
\n
#endif
"
,
shadowmap_pars_fragment
:
"
#ifdef USE_SHADOWMAP
\n
uniform sampler2D shadowMap[ MAX_SHADOWS ];
\n
uniform float shadowDarkness;
\n
uniform float shadowBias;
\n
varying vec4 vShadowCoord[ MAX_SHADOWS ];
\n
float unpackDepth( const in vec4 rgba_depth ) {
\n
const vec4 bit_shift = vec4( 1.0 / ( 256.0 * 256.0 * 256.0 ), 1.0 / ( 256.0 * 256.0 ), 1.0 / 256.0, 1.0 );
\n
float depth = dot( rgba_depth, bit_shift );
\n
return depth;
\n
}
\n
#endif
"
,
shadowmap_fragment
:
"
#ifdef USE_SHADOWMAP
\n
#ifdef SHADOWMAP_SOFT
\n
const float xPixelOffset = 1.0 / SHADOWMAP_WIDTH;
\n
const float yPixelOffset = 1.0 / SHADOWMAP_HEIGHT;
\n
#endif
\n
vec3 shadowColor = vec3( 1.0 );
\n
for( int i = 0; i < MAX_SHADOWS; i ++ ) {
\n
vec3 shadowCoord = vShadowCoord[ i ].xyz / vShadowCoord[ i ].w;
\n
shadowCoord.z += shadowBias;
\n
if ( shadowCoord.x >= 0.0 && shadowCoord.x <= 1.0 && shadowCoord.y >= 0.0 && shadowCoord.y <= 1.0 ) {
\n
#ifdef SHADOWMAP_SOFT
\n
float shadow = 0.0;
\n
for ( float y = -1.25; y <= 1.25; y += 1.25 )
\n
for ( float x = -1.25; x <= 1.25; x += 1.25 ) {
\n
vec4 rgbaDepth = texture2D( shadowMap[ i ], vec2( x * xPixelOffset, y * yPixelOffset ) + shadowCoord.xy );
\n
float fDepth = unpackDepth( rgbaDepth );
\n
if ( fDepth < shadowCoord.z )
\n
shadow += 1.0;
\n
}
\n
shadow /= 9.0;
\n
shadowColor = shadowColor * vec3( ( 1.0 - shadowDarkness * shadow ) );
\n
#else
\n
vec4 rgbaDepth = texture2D( shadowMap[ i ], shadowCoord.xy );
\n
float fDepth = unpackDepth( rgbaDepth );
\n
if ( fDepth < shadowCoord.z )
\n
shadowColor = shadowColor * vec3( shadowDarkness );
\n
#endif
\n
}
\n
}
\n
#ifdef GAMMA_OUTPUT
\n
shadowColor *= shadowColor;
\n
#endif
\n
gl_FragColor.xyz = gl_FragColor.xyz * shadowColor;
\n
#endif
"
,
shadowmap_fragment
:
"
#ifdef USE_SHADOWMAP
\n
#ifdef SHADOWMAP_SOFT
\n
const float xPixelOffset = 1.0 / SHADOWMAP_WIDTH;
\n
const float yPixelOffset = 1.0 / SHADOWMAP_HEIGHT;
\n
#endif
\n
vec3 shadowColor = vec3( 1.0 );
\n
for( int i = 0; i < MAX_SHADOWS; i ++ ) {
\n
vec3 shadowCoord = vShadowCoord[ i ].xyz / vShadowCoord[ i ].w;
\n
shadowCoord.z += shadowBias;
\n
if ( shadowCoord.x >= 0.0 && shadowCoord.x <= 1.0 && shadowCoord.y >= 0.0 && shadowCoord.y <= 1.0 ) {
\n
#ifdef SHADOWMAP_SOFT
\n
float shadow = 0.0;
\n
for ( float y = -1.25; y <= 1.25; y += 1.25 )
\n
for ( float x = -1.25; x <= 1.25; x += 1.25 ) {
\n
vec4 rgbaDepth = texture2D( shadowMap[ i ], vec2( x * xPixelOffset, y * yPixelOffset ) + shadowCoord.xy );
\n
float fDepth = unpackDepth( rgbaDepth );
\n
if ( fDepth < shadowCoord.z )
\n
shadow += 1.0;
\n
}
\n
shadow /= 9.0;
\n
shadowColor = shadowColor * vec3( ( 1.0 - shadowDarkness * shadow ) );
\n
#else
\n
vec4 rgbaDepth = texture2D( shadowMap[ i ], shadowCoord.xy );
\n
float fDepth = unpackDepth( rgbaDepth );
\n
if ( fDepth < shadowCoord.z )
\n
shadowColor = shadowColor * vec3(
1.0 -
shadowDarkness );
\n
#endif
\n
}
\n
}
\n
#ifdef GAMMA_OUTPUT
\n
shadowColor *= shadowColor;
\n
#endif
\n
gl_FragColor.xyz = gl_FragColor.xyz * shadowColor;
\n
#endif
"
,
shadowmap_pars_vertex
:
"
#ifdef USE_SHADOWMAP
\n
varying vec4 vShadowCoord[ MAX_SHADOWS ];
\n
uniform mat4 shadowMatrix[ MAX_SHADOWS ];
\n
#endif
"
,
shadowmap_vertex
:
"
#ifdef USE_SHADOWMAP
\n
for( int i = 0; i < MAX_SHADOWS; i ++ ) {
\n
vShadowCoord[ i ] = shadowMatrix[ i ] * objectMatrix * vec4( position, 1.0 );
\n
}
\n
#endif
"
,
alphatest_fragment
:
"
#ifdef ALPHATEST
\n
if ( gl_FragColor.a < ALPHATEST ) discard;
\n
#endif
"
,
linear_to_gamma_fragment
:
"
#ifdef GAMMA_OUTPUT
\n
gl_FragColor.xyz = sqrt( gl_FragColor.xyz );
\n
#endif
"
};
THREE
.
UniformsUtils
=
{
merge
:
function
(
a
){
var
b
,
c
,
d
,
e
=
{};
for
(
b
=
0
;
b
<
a
.
length
;
b
++
)
for
(
c
in
d
=
this
.
clone
(
a
[
b
]),
d
)
e
[
c
]
=
d
[
c
];
return
e
},
clone
:
function
(
a
){
var
b
,
c
,
d
,
e
=
{};
for
(
b
in
a
)
for
(
c
in
e
[
b
]
=
{},
a
[
b
])
d
=
a
[
b
][
c
],
e
[
b
][
c
]
=
d
instanceof
THREE
.
Color
||
d
instanceof
THREE
.
Vector2
||
d
instanceof
THREE
.
Vector3
||
d
instanceof
THREE
.
Vector4
||
d
instanceof
THREE
.
Matrix4
||
d
instanceof
THREE
.
Texture
?
d
.
clone
():
d
instanceof
Array
?
d
.
slice
():
d
;
return
e
}};
THREE
.
UniformsLib
=
{
common
:{
diffuse
:{
type
:
"
c
"
,
value
:
new
THREE
.
Color
(
15658734
)},
opacity
:{
type
:
"
f
"
,
value
:
1
},
map
:{
type
:
"
t
"
,
value
:
0
,
texture
:
null
},
offsetRepeat
:{
type
:
"
v4
"
,
value
:
new
THREE
.
Vector4
(
0
,
0
,
1
,
1
)},
lightMap
:{
type
:
"
t
"
,
value
:
2
,
texture
:
null
},
envMap
:{
type
:
"
t
"
,
value
:
1
,
texture
:
null
},
flipEnvMap
:{
type
:
"
f
"
,
value
:
-
1
},
useRefract
:{
type
:
"
i
"
,
value
:
0
},
reflectivity
:{
type
:
"
f
"
,
value
:
1
},
refractionRatio
:{
type
:
"
f
"
,
value
:
0.98
},
combine
:{
type
:
"
i
"
,
value
:
0
},
morphTargetInfluences
:{
type
:
"
f
"
,
value
:
0
}},
fog
:{
fogDensity
:{
type
:
"
f
"
,
...
...
build/custom/ThreeWebGL.js
浏览文件 @
ccf6d803
...
...
@@ -158,7 +158,7 @@ lights_phong_fragment:"vec3 normal = normalize( vNormal );\nvec3 viewPosition =
color_pars_fragment
:
"
#ifdef USE_COLOR
\n
varying vec3 vColor;
\n
#endif
"
,
color_fragment
:
"
#ifdef USE_COLOR
\n
gl_FragColor = gl_FragColor * vec4( vColor, opacity );
\n
#endif
"
,
color_pars_vertex
:
"
#ifdef USE_COLOR
\n
varying vec3 vColor;
\n
#endif
"
,
color_vertex
:
"
#ifdef USE_COLOR
\n
#ifdef GAMMA_INPUT
\n
vColor = color * color;
\n
#else
\n
vColor = color;
\n
#endif
\n
#endif
"
,
skinning_pars_vertex
:
"
#ifdef USE_SKINNING
\n
uniform mat4 boneGlobalMatrices[ MAX_BONES ];
\n
#endif
"
,
skinning_vertex
:
"
#ifdef USE_SKINNING
\n
gl_Position = ( boneGlobalMatrices[ int( skinIndex.x ) ] * skinVertexA ) * skinWeight.x;
\n
gl_Position += ( boneGlobalMatrices[ int( skinIndex.y ) ] * skinVertexB ) * skinWeight.y;
\n
gl_Position = projectionMatrix * viewMatrix * objectMatrix * gl_Position;
\n
#endif
"
,
morphtarget_pars_vertex
:
"
#ifdef USE_MORPHTARGETS
\n
uniform float morphTargetInfluences[ 8 ];
\n
#endif
"
,
morphtarget_vertex
:
"
#ifdef USE_MORPHTARGETS
\n
vec3 morphed = vec3( 0.0, 0.0, 0.0 );
\n
morphed += ( morphTarget0 - position ) * morphTargetInfluences[ 0 ];
\n
morphed += ( morphTarget1 - position ) * morphTargetInfluences[ 1 ];
\n
morphed += ( morphTarget2 - position ) * morphTargetInfluences[ 2 ];
\n
morphed += ( morphTarget3 - position ) * morphTargetInfluences[ 3 ];
\n
morphed += ( morphTarget4 - position ) * morphTargetInfluences[ 4 ];
\n
morphed += ( morphTarget5 - position ) * morphTargetInfluences[ 5 ];
\n
morphed += ( morphTarget6 - position ) * morphTargetInfluences[ 6 ];
\n
morphed += ( morphTarget7 - position ) * morphTargetInfluences[ 7 ];
\n
morphed += position;
\n
gl_Position = projectionMatrix * modelViewMatrix * vec4( morphed, 1.0 );
\n
#endif
"
,
default_vertex
:
"
#ifndef USE_MORPHTARGETS
\n
#ifndef USE_SKINNING
\n
gl_Position = projectionMatrix * mvPosition;
\n
#endif
\n
#endif
"
,
shadowmap_pars_fragment
:
"
#ifdef USE_SHADOWMAP
\n
uniform sampler2D shadowMap[ MAX_SHADOWS ];
\n
uniform float shadowDarkness;
\n
uniform float shadowBias;
\n
varying vec4 vShadowCoord[ MAX_SHADOWS ];
\n
float unpackDepth( const in vec4 rgba_depth ) {
\n
const vec4 bit_shift = vec4( 1.0 / ( 256.0 * 256.0 * 256.0 ), 1.0 / ( 256.0 * 256.0 ), 1.0 / 256.0, 1.0 );
\n
float depth = dot( rgba_depth, bit_shift );
\n
return depth;
\n
}
\n
#endif
"
,
shadowmap_fragment
:
"
#ifdef USE_SHADOWMAP
\n
#ifdef SHADOWMAP_SOFT
\n
const float xPixelOffset = 1.0 / SHADOWMAP_WIDTH;
\n
const float yPixelOffset = 1.0 / SHADOWMAP_HEIGHT;
\n
#endif
\n
vec3 shadowColor = vec3( 1.0 );
\n
for( int i = 0; i < MAX_SHADOWS; i ++ ) {
\n
vec3 shadowCoord = vShadowCoord[ i ].xyz / vShadowCoord[ i ].w;
\n
shadowCoord.z += shadowBias;
\n
if ( shadowCoord.x >= 0.0 && shadowCoord.x <= 1.0 && shadowCoord.y >= 0.0 && shadowCoord.y <= 1.0 ) {
\n
#ifdef SHADOWMAP_SOFT
\n
float shadow = 0.0;
\n
for ( float y = -1.25; y <= 1.25; y += 1.25 )
\n
for ( float x = -1.25; x <= 1.25; x += 1.25 ) {
\n
vec4 rgbaDepth = texture2D( shadowMap[ i ], vec2( x * xPixelOffset, y * yPixelOffset ) + shadowCoord.xy );
\n
float fDepth = unpackDepth( rgbaDepth );
\n
if ( fDepth < shadowCoord.z )
\n
shadow += 1.0;
\n
}
\n
shadow /= 9.0;
\n
shadowColor = shadowColor * vec3( ( 1.0 - shadowDarkness * shadow ) );
\n
#else
\n
vec4 rgbaDepth = texture2D( shadowMap[ i ], shadowCoord.xy );
\n
float fDepth = unpackDepth( rgbaDepth );
\n
if ( fDepth < shadowCoord.z )
\n
shadowColor = shadowColor * vec3( shadowDarkness );
\n
#endif
\n
}
\n
}
\n
#ifdef GAMMA_OUTPUT
\n
shadowColor *= shadowColor;
\n
#endif
\n
gl_FragColor.xyz = gl_FragColor.xyz * shadowColor;
\n
#endif
"
,
shadowmap_fragment
:
"
#ifdef USE_SHADOWMAP
\n
#ifdef SHADOWMAP_SOFT
\n
const float xPixelOffset = 1.0 / SHADOWMAP_WIDTH;
\n
const float yPixelOffset = 1.0 / SHADOWMAP_HEIGHT;
\n
#endif
\n
vec3 shadowColor = vec3( 1.0 );
\n
for( int i = 0; i < MAX_SHADOWS; i ++ ) {
\n
vec3 shadowCoord = vShadowCoord[ i ].xyz / vShadowCoord[ i ].w;
\n
shadowCoord.z += shadowBias;
\n
if ( shadowCoord.x >= 0.0 && shadowCoord.x <= 1.0 && shadowCoord.y >= 0.0 && shadowCoord.y <= 1.0 ) {
\n
#ifdef SHADOWMAP_SOFT
\n
float shadow = 0.0;
\n
for ( float y = -1.25; y <= 1.25; y += 1.25 )
\n
for ( float x = -1.25; x <= 1.25; x += 1.25 ) {
\n
vec4 rgbaDepth = texture2D( shadowMap[ i ], vec2( x * xPixelOffset, y * yPixelOffset ) + shadowCoord.xy );
\n
float fDepth = unpackDepth( rgbaDepth );
\n
if ( fDepth < shadowCoord.z )
\n
shadow += 1.0;
\n
}
\n
shadow /= 9.0;
\n
shadowColor = shadowColor * vec3( ( 1.0 - shadowDarkness * shadow ) );
\n
#else
\n
vec4 rgbaDepth = texture2D( shadowMap[ i ], shadowCoord.xy );
\n
float fDepth = unpackDepth( rgbaDepth );
\n
if ( fDepth < shadowCoord.z )
\n
shadowColor = shadowColor * vec3(
1.0 -
shadowDarkness );
\n
#endif
\n
}
\n
}
\n
#ifdef GAMMA_OUTPUT
\n
shadowColor *= shadowColor;
\n
#endif
\n
gl_FragColor.xyz = gl_FragColor.xyz * shadowColor;
\n
#endif
"
,
shadowmap_pars_vertex
:
"
#ifdef USE_SHADOWMAP
\n
varying vec4 vShadowCoord[ MAX_SHADOWS ];
\n
uniform mat4 shadowMatrix[ MAX_SHADOWS ];
\n
#endif
"
,
shadowmap_vertex
:
"
#ifdef USE_SHADOWMAP
\n
for( int i = 0; i < MAX_SHADOWS; i ++ ) {
\n
vShadowCoord[ i ] = shadowMatrix[ i ] * objectMatrix * vec4( position, 1.0 );
\n
}
\n
#endif
"
,
alphatest_fragment
:
"
#ifdef ALPHATEST
\n
if ( gl_FragColor.a < ALPHATEST ) discard;
\n
#endif
"
,
linear_to_gamma_fragment
:
"
#ifdef GAMMA_OUTPUT
\n
gl_FragColor.xyz = sqrt( gl_FragColor.xyz );
\n
#endif
"
};
THREE
.
UniformsUtils
=
{
merge
:
function
(
a
){
var
b
,
d
,
c
,
f
=
{};
for
(
b
=
0
;
b
<
a
.
length
;
b
++
)
for
(
d
in
c
=
this
.
clone
(
a
[
b
]),
c
)
f
[
d
]
=
c
[
d
];
return
f
},
clone
:
function
(
a
){
var
b
,
d
,
c
,
f
=
{};
for
(
b
in
a
)
for
(
d
in
f
[
b
]
=
{},
a
[
b
])
c
=
a
[
b
][
d
],
f
[
b
][
d
]
=
c
instanceof
THREE
.
Color
||
c
instanceof
THREE
.
Vector2
||
c
instanceof
THREE
.
Vector3
||
c
instanceof
THREE
.
Vector4
||
c
instanceof
THREE
.
Matrix4
||
c
instanceof
THREE
.
Texture
?
c
.
clone
():
c
instanceof
Array
?
c
.
slice
():
c
;
return
f
}};
THREE
.
UniformsLib
=
{
common
:{
diffuse
:{
type
:
"
c
"
,
value
:
new
THREE
.
Color
(
15658734
)},
opacity
:{
type
:
"
f
"
,
value
:
1
},
map
:{
type
:
"
t
"
,
value
:
0
,
texture
:
null
},
offsetRepeat
:{
type
:
"
v4
"
,
value
:
new
THREE
.
Vector4
(
0
,
0
,
1
,
1
)},
lightMap
:{
type
:
"
t
"
,
value
:
2
,
texture
:
null
},
envMap
:{
type
:
"
t
"
,
value
:
1
,
texture
:
null
},
flipEnvMap
:{
type
:
"
f
"
,
value
:
-
1
},
useRefract
:{
type
:
"
i
"
,
value
:
0
},
reflectivity
:{
type
:
"
f
"
,
value
:
1
},
refractionRatio
:{
type
:
"
f
"
,
value
:
0.98
},
combine
:{
type
:
"
i
"
,
value
:
0
},
morphTargetInfluences
:{
type
:
"
f
"
,
value
:
0
}},
fog
:{
fogDensity
:{
type
:
"
f
"
,
...
...
src/renderers/WebGLShaders.js
浏览文件 @
ccf6d803
...
...
@@ -812,7 +812,7 @@ THREE.ShaderChunk = {
// spot with multiple shadows is darker
"
shadowColor = shadowColor * vec3( shadowDarkness );
"
,
"
shadowColor = shadowColor * vec3(
1.0 -
shadowDarkness );
"
,
// spot with multiple shadows has the same color as single shadow spot
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录