Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Ablesons
three.js
提交
bec5849d
T
three.js
项目概览
Ablesons
/
three.js
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
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,发现更多精彩内容 >>
提交
bec5849d
编写于
11月 13, 2012
作者:
M
Mr.doob
浏览文件
操作
浏览文件
下载
差异文件
Merge remote-tracking branch 'alteredq/dev' into dev
上级
4667cc6f
3689f6b3
变更
19
隐藏空白更改
内联
并排
Showing
19 changed file
with
778 addition
and
368 deletion
+778
-368
build/three.js
build/three.js
+75
-20
build/three.min.js
build/three.min.js
+237
-237
editor/index.html
editor/index.html
+13
-16
editor/js/ui/Menubar.Add.js
editor/js/ui/Menubar.Add.js
+137
-7
editor/js/ui/Menubar.Edit.js
editor/js/ui/Menubar.Edit.js
+18
-3
editor/js/ui/Menubar.File.js
editor/js/ui/Menubar.File.js
+38
-7
editor/js/ui/Menubar.Help.js
editor/js/ui/Menubar.Help.js
+17
-2
editor/js/ui/Sidebar.Scene.js
editor/js/ui/Sidebar.Scene.js
+0
-6
editor/js/ui/Sidebar.js
editor/js/ui/Sidebar.js
+1
-0
editor/js/ui/Viewport.js
editor/js/ui/Viewport.js
+166
-49
examples/js/ShaderSkin.js
examples/js/ShaderSkin.js
+1
-1
src/core/Projector.js
src/core/Projector.js
+4
-2
src/core/Ray.js
src/core/Ray.js
+2
-1
src/extras/ShaderUtils.js
src/extras/ShaderUtils.js
+5
-5
src/extras/renderers/plugins/DepthPassPlugin.js
src/extras/renderers/plugins/DepthPassPlugin.js
+18
-2
src/extras/renderers/plugins/ShadowMapPlugin.js
src/extras/renderers/plugins/ShadowMapPlugin.js
+18
-2
src/materials/MeshFaceMaterial.js
src/materials/MeshFaceMaterial.js
+5
-1
src/renderers/WebGLRenderer.js
src/renderers/WebGLRenderer.js
+21
-5
src/renderers/WebGLShaders.js
src/renderers/WebGLShaders.js
+2
-2
未找到文件。
build/three.js
浏览文件 @
bec5849d
...
...
@@ -2965,8 +2965,9 @@ THREE.Frustum.__v1 = new THREE.Vector3();
var geometry = object.geometry;
var vertices = geometry.vertices;
var geometryMaterials = object.geometry.materials;
var isFaceMaterial = object.material instanceof THREE.MeshFaceMaterial;
var geometryMaterials = ( isFaceMaterial && object.material.materials.length > 0 ) ? object.material.materials : object.geometry.materials;
var side = object.material.side;
var a, b, c, d;
...
...
@@ -3983,7 +3984,7 @@ THREE.Projector = function() {
_renderData = projectGraph( scene, sortObjects );
for ( o = 0, ol = _renderData.objects.length; o < ol; o++ ) {
for ( o = 0, ol = _renderData.objects.length; o < ol; o
++ ) {
object = _renderData.objects[ o ].object;
...
...
@@ -3994,7 +3995,7 @@ THREE.Projector = function() {
if ( object instanceof THREE.Mesh ) {
geometry = object.geometry;
geometryMaterials = object.geometry.materials;
vertices = geometry.vertices;
faces = geometry.faces;
faceVertexUvs = geometry.faceVertexUvs;
...
...
@@ -4003,6 +4004,8 @@ THREE.Projector = function() {
_normalMatrix.transpose();
isFaceMaterial = object.material instanceof THREE.MeshFaceMaterial;
geometryMaterials = ( isFaceMaterial && object.material.materials.length > 0 ) ? object.material.materials : object.geometry.materials;
side = object.material.side;
for ( v = 0, vl = vertices.length; v < vl; v ++ ) {
...
...
@@ -11051,7 +11054,11 @@ THREE.MeshNormalMaterial.prototype.clone = function () {
* @author mrdoob / http://mrdoob.com/
*/
THREE.MeshFaceMaterial = function () {};
THREE.MeshFaceMaterial = function ( materials ) {
this.materials = materials instanceof Array ? materials : [];
};
THREE.MeshFaceMaterial.prototype.clone = function () {
...
...
@@ -15619,7 +15626,7 @@ THREE.ShaderLib = {
"void main() {",
"vec4 mvPosition = modelViewMatrix * vec4( position, 1.0 );",
"vNormal = normal
Matrix * normal
;",
"vNormal = normal
ize( normalMatrix * normal )
;",
"gl_Position = projectionMatrix * mvPosition;",
...
...
@@ -15893,7 +15900,7 @@ THREE.ShaderLib = {
THREE.ShaderChunk[ "skinnormal_vertex" ],
THREE.ShaderChunk[ "defaultnormal_vertex" ],
"vNormal =
transformedNormal
;",
"vNormal =
normalize( transformedNormal )
;",
THREE.ShaderChunk[ "morphtarget_vertex" ],
THREE.ShaderChunk[ "skinning_vertex" ],
...
...
@@ -17037,13 +17044,21 @@ THREE.WebGLRenderer = function ( parameters ) {
function getBufferMaterial( object, geometryGroup ) {
if ( object.material
&& ! ( object.material instanceof THREE.MeshFaceMaterial )
) {
if ( object.material
instanceof THREE.MeshFaceMaterial
) {
return object.material;
if ( object.material.materials.length > 0 ) {
return object.material.materials[ geometryGroup.materialIndex ];
} else {
return object.geometry.materials[ geometryGroup.materialIndex ];
}
} else
if ( geometryGroup.materialIndex >= 0 )
{
} else {
return object.
geometry.materials[ geometryGroup.materialIndex ]
;
return object.
material
;
}
...
...
@@ -20307,7 +20322,15 @@ THREE.WebGLRenderer = function ( parameters ) {
if ( materialIndex >= 0 ) {
material = object.geometry.materials[ materialIndex ];
if ( meshMaterial.materials.length > 0 ) {
material = meshMaterial.materials[ materialIndex ];
} else {
material = object.geometry.materials[ materialIndex ];
}
if ( material.transparent ) {
...
...
@@ -25731,19 +25754,19 @@ THREE.ShaderUtils = {
"#ifdef USE_SKINNING",
"vNormal = normal
Matrix * skinnedNormal.xyz
;",
"vNormal = normal
ize( normalMatrix * skinnedNormal.xyz )
;",
"vec4 skinnedTangent = skinMatrix * vec4( tangent.xyz, 0.0 );",
"vTangent = normal
Matrix * skinnedTangent.xyz
;",
"vTangent = normal
ize( normalMatrix * skinnedTangent.xyz )
;",
"#else",
"vNormal = normal
Matrix * normal
;",
"vTangent = normal
Matrix * tangent.xyz
;",
"vNormal = normal
ize( normalMatrix * normal )
;",
"vTangent = normal
ize( normalMatrix * tangent.xyz )
;",
"#endif",
"vBinormal =
cross( vNormal, vTangent ) * tangent.w
;",
"vBinormal =
normalize( cross( vNormal, vTangent ) * tangent.w )
;",
"vUv = uv * uRepeat + uOffset;",
...
...
@@ -35154,9 +35177,25 @@ THREE.ShadowMapPlugin = function ( ) {
function getObjectMaterial( object ) {
return object.material instanceof THREE.MeshFaceMaterial ? object.geometry.materials[ 0 ] : object.material;
if ( object.material instanceof THREE.MeshFaceMaterial ) {
}
if ( object.material.materials.length > 0 ) {
return object.material.materials[ 0 ];
} else {
return object.geometry.materials[ 0 ];
}
} else {
return object.material;
}
};
};
...
...
@@ -35670,9 +35709,25 @@ THREE.DepthPassPlugin = function ( ) {
function getObjectMaterial( object ) {
return object.material instanceof THREE.MeshFaceMaterial ? object.geometry.materials[ 0 ] : object.material;
if ( object.material instanceof THREE.MeshFaceMaterial ) {
}
if ( object.material.materials.length > 0 ) {
return object.material.materials[ 0 ];
} else {
return object.geometry.materials[ 0 ];
}
} else {
return object.material;
}
};
};
...
...
build/three.min.js
浏览文件 @
bec5849d
因为 它太大了无法显示 source diff 。你可以改为
查看blob
。
editor/index.html
浏览文件 @
bec5849d
...
...
@@ -66,7 +66,7 @@
// notifications
scene
Creat
ed
:
new
SIGNALS
.
Signal
(),
scene
Add
ed
:
new
SIGNALS
.
Signal
(),
sceneChanged
:
new
SIGNALS
.
Signal
(),
objectAdded
:
new
SIGNALS
.
Signal
(),
objectSelected
:
new
SIGNALS
.
Signal
(),
...
...
@@ -139,7 +139,7 @@
geometry
.
sourceType
=
"
ctm
"
;
geometry
.
sourceFile
=
file
.
name
;
var
mesh
=
new
THREE
.
Mesh
(
geometry
,
createDummyMaterial
(
geometry
)
);
var
mesh
=
new
THREE
.
Mesh
(
geometry
,
createDummyMaterial
()
);
mesh
.
name
=
filename
;
signals
.
objectAdded
.
dispatch
(
mesh
);
...
...
@@ -228,7 +228,7 @@
geometry
.
sourceType
=
"
ascii
"
;
geometry
.
sourceFile
=
file
.
name
;
var
mesh
=
new
THREE
.
Mesh
(
geometry
,
createDummyMaterial
(
geometry
)
);
var
mesh
=
new
THREE
.
Mesh
(
geometry
,
createDummyMaterial
()
);
mesh
.
name
=
filename
;
signals
.
objectAdded
.
dispatch
(
mesh
);
...
...
@@ -244,7 +244,7 @@
if
(
resetScene
)
{
signals
.
resetScene
.
dispatch
(
result
.
scene
,
result
.
currentCamera
,
result
.
bgColor
);
signals
.
sceneAdded
.
dispatch
(
result
.
scene
,
result
.
currentCamera
,
result
.
bgColor
);
}
else
{
...
...
@@ -291,7 +291,7 @@
geometry
.
sourceType
=
"
stl
"
;
geometry
.
sourceFile
=
file
.
name
;
var
mesh
=
new
THREE
.
Mesh
(
geometry
,
createDummyMaterial
(
geometry
)
);
var
mesh
=
new
THREE
.
Mesh
(
geometry
,
createDummyMaterial
()
);
mesh
.
name
=
filename
;
signals
.
objectAdded
.
dispatch
(
mesh
);
...
...
@@ -335,7 +335,7 @@
geometry
.
sourceType
=
"
vtk
"
;
geometry
.
sourceFile
=
file
.
name
;
var
mesh
=
new
THREE
.
Mesh
(
geometry
,
createDummyMaterial
(
geometry
)
);
var
mesh
=
new
THREE
.
Mesh
(
geometry
,
createDummyMaterial
()
);
mesh
.
name
=
filename
;
signals
.
objectAdded
.
dispatch
(
mesh
);
...
...
@@ -350,16 +350,11 @@
}
var
geometry
=
new
THREE
.
SphereGeometry
(
75
,
25
,
15
);
// create default scene
var
material
=
new
THREE
.
MeshPhongMaterial
();
material
.
color
.
setHSV
(
Math
.
random
(),
Math
.
random
(),
1
);
signals
.
resetScene
.
dispatch
();
var
mesh
=
new
THREE
.
Mesh
(
geometry
,
material
);
mesh
.
name
=
"
Sphere
"
;
signals
.
objectAdded
.
dispatch
(
mesh
);
signals
.
objectSelected
.
dispatch
(
mesh
);
//
var
onWindowResize
=
function
(
event
)
{
...
...
@@ -367,12 +362,14 @@
};
var
createDummyMaterial
=
function
(
geometry
)
{
var
createDummyMaterial
=
function
()
{
return
new
THREE
.
Mesh
Lambert
Material
();
return
new
THREE
.
Mesh
Phong
Material
();
};
//
onWindowResize
();
window
.
addEventListener
(
'
resize
'
,
onWindowResize
,
false
);
...
...
editor/js/ui/Menubar.Add.js
浏览文件 @
bec5849d
...
...
@@ -19,25 +19,155 @@ Menubar.Add = function ( signals ) {
var
options
=
new
UI
.
Panel
();
options
.
setWidth
(
'
140px
'
);
options
.
setBackgroundColor
(
'
#ddd
'
);
options
.
setPadding
(
'
10px
'
);
options
.
setPadding
(
'
0px
'
);
options
.
setBorderTop
(
'
solid 1px #ccc
'
);
options
.
setStyle
(
'
box-shadow
'
,
[
'
0 3px 6px rgba(0,0,0,0.1), 3px 3px 6px rgba(0,0,0,0.2)
'
]
);
options
.
setDisplay
(
'
none
'
);
container
.
add
(
options
);
// add sphere
var
option
=
new
UI
.
Panel
();
option
.
setTextContent
(
'
Sphere
'
).
setColor
(
'
#666
'
);
option
.
onClick
(
function
()
{
alert
(
'
Sphere
'
)
}
);
option
.
setTextContent
(
'
Sphere
'
).
setColor
(
'
#666
'
).
setPadding
(
'
6px 12px
'
);
option
.
onClick
(
function
()
{
var
radius
=
75
;
var
widthSegments
=
32
;
var
heightSegments
=
16
;
var
geometry
=
new
THREE
.
SphereGeometry
(
radius
,
widthSegments
,
heightSegments
);
var
mesh
=
new
THREE
.
Mesh
(
geometry
,
createDummyMaterial
(
geometry
)
);
mesh
.
name
=
'
Sphere
'
+
mesh
.
id
;
signals
.
objectAdded
.
dispatch
(
mesh
);
}
);
options
.
add
(
option
);
addHoverStyle
(
option
);
// add cube
var
option
=
new
UI
.
Panel
();
option
.
setTextContent
(
'
Cube
'
).
setColor
(
'
#666
'
);
option
.
onClick
(
function
()
{
alert
(
'
Cube
'
)
}
);
option
.
setTextContent
(
'
Cube
'
).
setColor
(
'
#666
'
).
setPadding
(
'
6px 12px
'
);
option
.
onClick
(
function
()
{
var
width
=
100
;
var
height
=
100
;
var
depth
=
100
;
var
widthSegments
=
1
;
var
heightSegments
=
1
;
var
depthSegments
=
1
;
var
geometry
=
new
THREE
.
CubeGeometry
(
width
,
height
,
depth
,
widthSegments
,
heightSegments
,
depthSegments
);
var
mesh
=
new
THREE
.
Mesh
(
geometry
,
createDummyMaterial
(
geometry
)
);
mesh
.
name
=
'
Cube
'
+
mesh
.
id
;
signals
.
objectAdded
.
dispatch
(
mesh
);
}
);
options
.
add
(
option
);
addHoverStyle
(
option
);
// add plane
var
option
=
new
UI
.
Panel
();
option
.
setTextContent
(
'
Plane
'
).
setColor
(
'
#666
'
);
option
.
onClick
(
function
()
{
alert
(
'
Plane
'
)
}
);
option
.
setTextContent
(
'
Plane
'
).
setColor
(
'
#666
'
).
setPadding
(
'
6px 12px
'
);
option
.
onClick
(
function
()
{
var
width
=
200
;
var
height
=
200
;
var
widthSegments
=
1
;
var
heightSegments
=
1
;
var
geometry
=
new
THREE
.
PlaneGeometry
(
width
,
height
,
widthSegments
,
heightSegments
);
var
mesh
=
new
THREE
.
Mesh
(
geometry
,
createDummyMaterial
(
geometry
)
);
mesh
.
name
=
'
Plane
'
+
mesh
.
id
;
mesh
.
rotation
.
x
=
-
Math
.
PI
/
2
;
signals
.
objectAdded
.
dispatch
(
mesh
);
}
);
options
.
add
(
option
);
addHoverStyle
(
option
);
// divider
var
option
=
new
UI
.
Panel
();
option
.
setBackgroundColor
(
'
#ccc
'
).
setPadding
(
'
1px 12px
'
);
options
.
add
(
option
);
// add directional light
var
option
=
new
UI
.
Panel
();
option
.
setTextContent
(
'
Directional light
'
).
setColor
(
'
#666
'
).
setPadding
(
'
6px 12px
'
);
option
.
onClick
(
function
()
{
var
color
=
0xffffff
;
var
intensity
=
1
;
var
light
=
new
THREE
.
DirectionalLight
(
color
,
intensity
);
light
.
name
=
'
Light
'
+
light
.
id
;
light
.
target
.
name
=
'
Light
'
+
light
.
id
+
'
target
'
;
light
.
target
.
properties
.
targetInverse
=
light
;
light
.
position
.
set
(
1
,
1
,
1
).
multiplyScalar
(
200
);
signals
.
objectAdded
.
dispatch
(
light
);
}
);
options
.
add
(
option
);
addHoverStyle
(
option
);
// add point light
var
option
=
new
UI
.
Panel
();
option
.
setTextContent
(
'
Point light
'
).
setColor
(
'
#666
'
).
setPadding
(
'
6px 12px
'
);
option
.
onClick
(
function
()
{
var
color
=
0xffffff
;
var
intensity
=
1
;
var
distance
=
0
;
var
light
=
new
THREE
.
PointLight
(
color
,
intensity
,
distance
);
light
.
name
=
'
Light
'
+
light
.
id
;
signals
.
objectAdded
.
dispatch
(
light
);
}
);
options
.
add
(
option
);
addHoverStyle
(
option
);
// add spot light
// add hemisphere light
// add ambient light
//
function
addHoverStyle
(
element
)
{
element
.
onMouseOver
(
function
()
{
element
.
setBackgroundColor
(
'
#356
'
).
setColor
(
'
#eee
'
);
}
);
element
.
onMouseOut
(
function
()
{
element
.
setBackgroundColor
(
'
transparent
'
).
setColor
(
'
#666
'
)
}
);
}
function
createDummyMaterial
()
{
return
new
THREE
.
MeshPhongMaterial
();
};
return
container
;
}
editor/js/ui/Menubar.Edit.js
浏览文件 @
bec5849d
...
...
@@ -19,15 +19,30 @@ Menubar.Edit = function ( signals ) {
var
options
=
new
UI
.
Panel
();
options
.
setWidth
(
'
140px
'
);
options
.
setBackgroundColor
(
'
#ddd
'
);
options
.
setPadding
(
'
10px
'
);
options
.
setPadding
(
'
0px
'
);
options
.
setBorderTop
(
'
solid 1px #ccc
'
);
options
.
setStyle
(
'
box-shadow
'
,
[
'
0 3px 6px rgba(0,0,0,0.1), 3px 3px 6px rgba(0,0,0,0.2)
'
]
);
options
.
setDisplay
(
'
none
'
);
container
.
add
(
options
);
// delete
var
option
=
new
UI
.
Panel
();
option
.
setTextContent
(
'
Delete
'
).
setColor
(
'
#666
'
);
option
.
onClick
(
function
()
{
alert
(
'
Delete
'
)
}
);
option
.
setTextContent
(
'
Delete
'
).
setColor
(
'
#666
'
)
.
setPadding
(
'
6px 12px
'
)
;
option
.
onClick
(
function
()
{
signals
.
removeSelectedObject
.
dispatch
();
}
);
options
.
add
(
option
);
addHoverStyle
(
option
);
//
function
addHoverStyle
(
element
)
{
element
.
onMouseOver
(
function
()
{
element
.
setBackgroundColor
(
'
#356
'
).
setColor
(
'
#eee
'
);
}
);
element
.
onMouseOut
(
function
()
{
element
.
setBackgroundColor
(
'
transparent
'
).
setColor
(
'
#666
'
)
}
);
}
return
container
;
}
editor/js/ui/Menubar.File.js
浏览文件 @
bec5849d
...
...
@@ -19,35 +19,66 @@ Menubar.File = function ( signals ) {
var
options
=
new
UI
.
Panel
();
options
.
setWidth
(
'
140px
'
);
options
.
setBackgroundColor
(
'
#ddd
'
);
options
.
setPadding
(
'
10px
'
);
options
.
setPadding
(
'
0px
'
);
options
.
setBorderTop
(
'
solid 1px #ccc
'
);
options
.
setStyle
(
'
box-shadow
'
,
[
'
0 3px 6px rgba(0,0,0,0.1), 3px 3px 6px rgba(0,0,0,0.2)
'
]
);
options
.
setDisplay
(
'
none
'
);
container
.
add
(
options
);
// open
var
option
=
new
UI
.
Panel
();
option
.
setTextContent
(
'
Open
'
).
setColor
(
'
#666
'
);
option
.
setTextContent
(
'
Open
'
).
setColor
(
'
#666
'
)
.
setPadding
(
'
6px 12px
'
)
;
option
.
onClick
(
function
()
{
alert
(
'
Open
'
)
}
);
options
.
add
(
option
);
addHoverStyle
(
option
);
// reset scene
var
option
=
new
UI
.
Panel
();
option
.
setTextContent
(
'
Reset
'
).
setColor
(
'
#666
'
);
option
.
onClick
(
function
()
{
alert
(
'
Reset
'
)
}
);
option
.
setTextContent
(
'
Reset
'
).
setColor
(
'
#666
'
)
.
setPadding
(
'
6px 12px
'
)
;
option
.
onClick
(
function
()
{
signals
.
resetScene
.
dispatch
();
}
);
options
.
add
(
option
);
addHoverStyle
(
option
);
// export geometry
var
option
=
new
UI
.
Panel
();
option
.
setTextContent
(
'
Export Geometry
'
).
setColor
(
'
#666
'
);
option
.
setTextContent
(
'
Export Geometry
'
).
setColor
(
'
#666
'
)
.
setPadding
(
'
6px 12px
'
)
;
option
.
onClick
(
function
()
{
signals
.
exportGeometry
.
dispatch
();
}
);
options
.
add
(
option
);
addHoverStyle
(
option
);
// export scene
var
option
=
new
UI
.
Panel
();
option
.
setTextContent
(
'
Export Scene
'
).
setColor
(
'
#666
'
);
option
.
setTextContent
(
'
Export Scene
'
).
setColor
(
'
#666
'
)
.
setPadding
(
'
6px 12px
'
)
;
option
.
onClick
(
function
()
{
signals
.
exportScene
.
dispatch
();
}
);
options
.
add
(
option
);
addHoverStyle
(
option
);
// export OBJ
var
option
=
new
UI
.
Panel
();
option
.
setTextContent
(
'
Export OBJ
'
).
setColor
(
'
#666
'
);
option
.
setTextContent
(
'
Export OBJ
'
).
setColor
(
'
#666
'
)
.
setPadding
(
'
6px 12px
'
)
;
option
.
onClick
(
function
()
{
alert
(
'
Export OBJ
'
)
}
);
options
.
add
(
option
);
addHoverStyle
(
option
);
//
function
addHoverStyle
(
element
)
{
element
.
onMouseOver
(
function
()
{
element
.
setBackgroundColor
(
'
#356
'
).
setColor
(
'
#eee
'
);
}
);
element
.
onMouseOut
(
function
()
{
element
.
setBackgroundColor
(
'
transparent
'
).
setColor
(
'
#666
'
)
}
);
}
return
container
;
}
editor/js/ui/Menubar.Help.js
浏览文件 @
bec5849d
...
...
@@ -19,15 +19,30 @@ Menubar.Help = function ( signals ) {
var
options
=
new
UI
.
Panel
();
options
.
setWidth
(
'
140px
'
);
options
.
setBackgroundColor
(
'
#ddd
'
);
options
.
setPadding
(
'
10px
'
);
options
.
setPadding
(
'
0px
'
);
options
.
setBorderTop
(
'
solid 1px #ccc
'
);
options
.
setStyle
(
'
box-shadow
'
,
[
'
0 3px 7px rgba(0,0,0,0.05), 3px 3px 7px rgba(0,0,0,0.1)
'
]
);
options
.
setDisplay
(
'
none
'
);
container
.
add
(
options
);
// about
var
option
=
new
UI
.
Panel
();
option
.
setTextContent
(
'
About
'
).
setColor
(
'
#666
'
);
option
.
setTextContent
(
'
About
'
).
setColor
(
'
#666
'
)
.
setPadding
(
'
6px 12px
'
)
;
option
.
onClick
(
function
()
{
alert
(
'
About
'
)
}
);
options
.
add
(
option
);
addHoverStyle
(
option
);
//
function
addHoverStyle
(
element
)
{
element
.
onMouseOver
(
function
()
{
element
.
setBackgroundColor
(
'
#356
'
).
setColor
(
'
#eee
'
);
}
);
element
.
onMouseOut
(
function
()
{
element
.
setBackgroundColor
(
'
transparent
'
).
setColor
(
'
#666
'
)
}
);
}
return
container
;
}
editor/js/ui/Sidebar.Scene.js
浏览文件 @
bec5849d
...
...
@@ -224,12 +224,6 @@ Sidebar.Scene = function ( signals ) {
// events
signals
.
sceneCreated
.
add
(
function
(
object
)
{
scene
=
object
;
}
);
signals
.
sceneChanged
.
add
(
function
(
object
)
{
scene
=
object
;
...
...
editor/js/ui/Sidebar.js
浏览文件 @
bec5849d
...
...
@@ -3,6 +3,7 @@ var Sidebar = function ( signals ) {
var
container
=
new
UI
.
Panel
(
'
absolute
'
);
container
.
setWidth
(
'
300px
'
).
setHeight
(
'
100%
'
);
container
.
setBackgroundColor
(
'
#eee
'
);
container
.
setBorderLeft
(
'
solid 1px #ccc
'
);
container
.
setOverflow
(
'
auto
'
);
container
.
add
(
new
Sidebar
.
Scene
(
signals
)
);
...
...
editor/js/ui/Viewport.js
浏览文件 @
bec5849d
...
...
@@ -2,6 +2,7 @@ var Viewport = function ( signals ) {
var
container
=
new
UI
.
Panel
(
'
absolute
'
);
container
.
setBackgroundColor
(
'
#aaa
'
);
container
.
setBorderTop
(
'
solid 1px #ccc
'
);
// settings
...
...
@@ -47,30 +48,10 @@ var Viewport = function ( signals ) {
selectionAxis
.
visible
=
false
;
sceneHelpers
.
add
(
selectionAxis
);
//
//
default dummy scene and camera
var
scene
=
new
THREE
.
Scene
();
var
camera
=
new
THREE
.
PerspectiveCamera
(
50
,
1
,
1
,
5000
);
camera
.
position
.
set
(
500
,
250
,
500
);
camera
.
lookAt
(
scene
.
position
);
scene
.
add
(
camera
);
var
light1
=
new
THREE
.
DirectionalLight
(
0xffffff
,
0.8
);
light1
.
position
.
set
(
1
,
0.5
,
0
).
multiplyScalar
(
400
);
var
light2
=
new
THREE
.
SpotLight
(
0xffffff
,
1.5
,
500
,
Math
.
PI
*
0.025
);
light2
.
position
.
set
(
-
1
,
0.5
,
1
).
multiplyScalar
(
300
);
light1
.
target
.
properties
.
targetInverse
=
light1
;
light2
.
target
.
properties
.
targetInverse
=
light2
;
var
light3
=
new
THREE
.
PointLight
(
0xffaa00
,
0.75
);
light3
.
position
.
set
(
-
250
,
200
,
-
200
);
//var light4 = new THREE.AmbientLight( 0x111111 );
var
light4
=
new
THREE
.
HemisphereLight
(
0x00aaff
,
0xff0000
,
0.75
);
light4
.
position
.
y
=
250
;
var
camera
=
new
THREE
.
Camera
();
// fog
...
...
@@ -80,24 +61,6 @@ var Viewport = function ( signals ) {
var
oldFogFar
=
5000
;
var
oldFogDensity
=
0.00025
;
// default objects names
camera
.
name
=
"
Camera
"
;
light1
.
name
=
"
Light 1
"
;
light1
.
target
.
name
=
"
Light 1 Target
"
;
light2
.
name
=
"
Light 2
"
;
light2
.
target
.
name
=
"
Light 2 Target
"
;
light3
.
name
=
"
Light 3
"
;
light4
.
name
=
"
Light 4
"
;
// active objects
camera
.
properties
.
active
=
true
;
// object picking
var
intersectionPlane
=
new
THREE
.
Mesh
(
new
THREE
.
PlaneGeometry
(
10000
,
10000
,
8
,
8
)
);
...
...
@@ -390,6 +353,13 @@ var Viewport = function ( signals ) {
object
.
traverse
(
handleAddition
);
scene
.
add
(
object
);
if
(
object
instanceof
THREE
.
Light
&&
!
(
object
instanceof
THREE
.
AmbientLight
)
)
{
updateMaterials
(
scene
);
}
render
();
signals
.
sceneChanged
.
dispatch
(
scene
);
...
...
@@ -431,16 +401,28 @@ var Viewport = function ( signals ) {
}
// remove from picking list
// remove
proxies
from picking list
var
toRemove
=
{};
selected
.
traverse
(
function
(
child
)
{
var
proxyObject
=
selected
.
properties
.
pickingProxy
?
selected
.
properties
.
pickingProxy
:
selected
;
proxyObject
.
traverse
(
function
(
child
)
{
toRemove
[
child
.
id
]
=
true
;
}
);
// remove eventual pure Object3D target proxies from picking list
if
(
selected
.
target
&&
!
selected
.
target
.
geometry
)
{
toRemove
[
selected
.
target
.
properties
.
pickingProxy
.
id
]
=
true
;
}
//
var
newObjects
=
[];
for
(
var
i
=
0
;
i
<
objects
.
length
;
i
++
)
{
...
...
@@ -457,17 +439,61 @@ var Viewport = function ( signals ) {
objects
=
newObjects
;
//
//
clean selection highlight
selectionBox
.
visible
=
false
;
selectionAxis
.
visible
=
false
;
// remove selected object from the scene
scene
.
traverse
(
function
(
node
)
{
node
.
remove
(
selected
);
}
);
// remove eventual pure Object3D targets from the scene
if
(
selected
.
target
&&
!
selected
.
target
.
geometry
)
{
scene
.
traverse
(
function
(
node
)
{
node
.
remove
(
selected
.
target
);
}
);
}
// remove eventual helpers for the object from helpers scene
var
helpersToRemove
=
[];
if
(
selected
.
properties
.
helper
)
{
helpersToRemove
.
push
(
selected
.
properties
.
helper
);
if
(
selected
.
properties
.
helper
.
targetLine
)
helpersToRemove
.
push
(
selected
.
properties
.
helper
.
targetLine
);
if
(
selected
.
target
&&
!
selected
.
target
.
geometry
)
helpersToRemove
.
push
(
selected
.
properties
.
helper
.
targetSphere
);
}
sceneHelpers
.
traverse
(
function
(
node
)
{
for
(
var
i
=
0
;
i
<
helpersToRemove
.
length
;
i
++
)
{
node
.
remove
(
helpersToRemove
[
i
]
);
}
}
);
if
(
selected
instanceof
THREE
.
Light
&&
!
(
selected
instanceof
THREE
.
AmbientLight
)
)
{
updateMaterials
(
scene
);
}
render
();
signals
.
sceneChanged
.
dispatch
(
scene
);
...
...
@@ -647,6 +673,13 @@ var Viewport = function ( signals ) {
signals
.
exportGeometry
.
add
(
function
()
{
if
(
!
selected
.
geometry
)
{
console
.
warn
(
"
Selected object doesn't have any geometry
"
);
return
;
}
var
output
=
new
THREE
.
GeometryExporter
().
parse
(
selected
.
geometry
);
var
blob
=
new
Blob
(
[
output
],
{
type
:
'
text/plain
'
}
);
...
...
@@ -679,7 +712,21 @@ var Viewport = function ( signals ) {
}
);
signals
.
resetScene
.
add
(
function
(
newScene
,
newCamera
,
newClearColor
)
{
signals
.
resetScene
.
add
(
function
()
{
var
defaultScene
=
createDefaultScene
();
var
defaultCamera
=
createDefaultCamera
();
var
defaultBgColor
=
new
THREE
.
Color
(
0xaaaaaa
);
defaultCamera
.
lookAt
(
defaultScene
.
position
);
defaultScene
.
add
(
defaultCamera
);
signals
.
sceneAdded
.
dispatch
(
defaultScene
,
defaultCamera
,
defaultBgColor
);
signals
.
objectSelected
.
dispatch
(
defaultScene
.
properties
.
defaultSelection
);
}
);
signals
.
sceneAdded
.
add
(
function
(
newScene
,
newCamera
,
newClearColor
)
{
scene
=
newScene
;
...
...
@@ -787,11 +834,6 @@ var Viewport = function ( signals ) {
signals
.
sceneChanged
.
dispatch
(
scene
);
signals
.
objectAdded
.
dispatch
(
light1
);
signals
.
objectAdded
.
dispatch
(
light2
);
signals
.
objectAdded
.
dispatch
(
light3
);
signals
.
objectAdded
.
dispatch
(
light4
);
//
function
updateMaterials
(
root
)
{
...
...
@@ -832,6 +874,81 @@ var Viewport = function ( signals ) {
}
function
createDefaultScene
()
{
// create scene
var
scene
=
new
THREE
.
Scene
();
// create lights
var
light1
=
new
THREE
.
DirectionalLight
(
0xffffff
,
0.8
);
light1
.
position
.
set
(
1
,
0.5
,
0
).
multiplyScalar
(
400
);
var
light2
=
new
THREE
.
SpotLight
(
0xffffff
,
1.5
,
500
,
Math
.
PI
*
0.025
);
light2
.
position
.
set
(
-
1
,
0.5
,
1
).
multiplyScalar
(
300
);
var
light3
=
new
THREE
.
PointLight
(
0xffaa00
,
0.75
);
light3
.
position
.
set
(
-
250
,
200
,
-
200
);
//var light4 = new THREE.AmbientLight( 0x111111 );
var
light4
=
new
THREE
.
HemisphereLight
(
0x00aaff
,
0xff0000
,
0.75
);
light4
.
position
.
y
=
250
;
light1
.
target
.
properties
.
targetInverse
=
light1
;
light2
.
target
.
properties
.
targetInverse
=
light2
;
// create objects
var
geometry
=
new
THREE
.
SphereGeometry
(
75
,
25
,
15
);
var
material
=
new
THREE
.
MeshPhongMaterial
();
material
.
color
.
setHSV
(
Math
.
random
(),
Math
.
random
(),
1
);
var
mesh
=
new
THREE
.
Mesh
(
geometry
,
material
);
// set default names
light1
.
name
=
"
Light 1
"
;
light1
.
target
.
name
=
"
Light 1 Target
"
;
light2
.
name
=
"
Light 2
"
;
light2
.
target
.
name
=
"
Light 2 Target
"
;
light3
.
name
=
"
Light 3
"
;
light4
.
name
=
"
Light 4
"
;
mesh
.
name
=
"
Sphere
"
;
// set default selection
scene
.
properties
.
defaultSelection
=
mesh
;
// add to scene
scene
.
add
(
light1
);
scene
.
add
(
light2
);
scene
.
add
(
light3
);
scene
.
add
(
light4
);
scene
.
add
(
mesh
);
return
scene
;
}
function
createDefaultCamera
()
{
var
camera
=
new
THREE
.
PerspectiveCamera
(
50
,
1
,
1
,
5000
);
camera
.
position
.
set
(
500
,
250
,
500
);
camera
.
name
=
"
Camera
"
;
camera
.
properties
.
active
=
true
;
return
camera
;
}
function
animate
()
{
requestAnimationFrame
(
animate
);
...
...
examples/js/ShaderSkin.js
浏览文件 @
bec5849d
...
...
@@ -323,7 +323,7 @@ THREE.ShaderSkin = {
"
vViewPosition = -mvPosition.xyz;
"
,
"
vNormal = normal
Matrix * normal
;
"
,
"
vNormal = normal
ize( normalMatrix * normal )
;
"
,
"
vUv = uv * offsetRepeat.zw + offsetRepeat.xy;
"
,
...
...
src/core/Projector.js
浏览文件 @
bec5849d
...
...
@@ -196,7 +196,7 @@ THREE.Projector = function() {
_renderData
=
projectGraph
(
scene
,
sortObjects
);
for
(
o
=
0
,
ol
=
_renderData
.
objects
.
length
;
o
<
ol
;
o
++
)
{
for
(
o
=
0
,
ol
=
_renderData
.
objects
.
length
;
o
<
ol
;
o
++
)
{
object
=
_renderData
.
objects
[
o
].
object
;
...
...
@@ -207,7 +207,7 @@ THREE.Projector = function() {
if
(
object
instanceof
THREE
.
Mesh
)
{
geometry
=
object
.
geometry
;
geometryMaterials
=
object
.
geometry
.
materials
;
vertices
=
geometry
.
vertices
;
faces
=
geometry
.
faces
;
faceVertexUvs
=
geometry
.
faceVertexUvs
;
...
...
@@ -216,6 +216,8 @@ THREE.Projector = function() {
_normalMatrix
.
transpose
();
isFaceMaterial
=
object
.
material
instanceof
THREE
.
MeshFaceMaterial
;
geometryMaterials
=
(
isFaceMaterial
&&
object
.
material
.
materials
.
length
>
0
)
?
object
.
material
.
materials
:
object
.
geometry
.
materials
;
side
=
object
.
material
.
side
;
for
(
v
=
0
,
vl
=
vertices
.
length
;
v
<
vl
;
v
++
)
{
...
...
src/core/Ray.js
浏览文件 @
bec5849d
...
...
@@ -109,8 +109,9 @@
var
geometry
=
object
.
geometry
;
var
vertices
=
geometry
.
vertices
;
var
geometryMaterials
=
object
.
geometry
.
materials
;
var
isFaceMaterial
=
object
.
material
instanceof
THREE
.
MeshFaceMaterial
;
var
geometryMaterials
=
(
isFaceMaterial
&&
object
.
material
.
materials
.
length
>
0
)
?
object
.
material
.
materials
:
object
.
geometry
.
materials
;
var
side
=
object
.
material
.
side
;
var
a
,
b
,
c
,
d
;
...
...
src/extras/ShaderUtils.js
浏览文件 @
bec5849d
...
...
@@ -635,19 +635,19 @@ THREE.ShaderUtils = {
"
#ifdef USE_SKINNING
"
,
"
vNormal = normal
Matrix * skinnedNormal.xyz
;
"
,
"
vNormal = normal
ize( normalMatrix * skinnedNormal.xyz )
;
"
,
"
vec4 skinnedTangent = skinMatrix * vec4( tangent.xyz, 0.0 );
"
,
"
vTangent = normal
Matrix * skinnedTangent.xyz
;
"
,
"
vTangent = normal
ize( normalMatrix * skinnedTangent.xyz )
;
"
,
"
#else
"
,
"
vNormal = normal
Matrix * normal
;
"
,
"
vTangent = normal
Matrix * tangent.xyz
;
"
,
"
vNormal = normal
ize( normalMatrix * normal )
;
"
,
"
vTangent = normal
ize( normalMatrix * tangent.xyz )
;
"
,
"
#endif
"
,
"
vBinormal =
cross( vNormal, vTangent ) * tangent.w
;
"
,
"
vBinormal =
normalize( cross( vNormal, vTangent ) * tangent.w )
;
"
,
"
vUv = uv * uRepeat + uOffset;
"
,
...
...
src/extras/renderers/plugins/DepthPassPlugin.js
浏览文件 @
bec5849d
...
...
@@ -196,9 +196,25 @@ THREE.DepthPassPlugin = function ( ) {
function
getObjectMaterial
(
object
)
{
return
object
.
material
instanceof
THREE
.
MeshFaceMaterial
?
object
.
geometry
.
materials
[
0
]
:
object
.
material
;
if
(
object
.
material
instanceof
THREE
.
MeshFaceMaterial
)
{
}
if
(
object
.
material
.
materials
.
length
>
0
)
{
return
object
.
material
.
materials
[
0
];
}
else
{
return
object
.
geometry
.
materials
[
0
];
}
}
else
{
return
object
.
material
;
}
};
};
src/extras/renderers/plugins/ShadowMapPlugin.js
浏览文件 @
bec5849d
...
...
@@ -480,9 +480,25 @@ THREE.ShadowMapPlugin = function ( ) {
function
getObjectMaterial
(
object
)
{
return
object
.
material
instanceof
THREE
.
MeshFaceMaterial
?
object
.
geometry
.
materials
[
0
]
:
object
.
material
;
if
(
object
.
material
instanceof
THREE
.
MeshFaceMaterial
)
{
}
if
(
object
.
material
.
materials
.
length
>
0
)
{
return
object
.
material
.
materials
[
0
];
}
else
{
return
object
.
geometry
.
materials
[
0
];
}
}
else
{
return
object
.
material
;
}
};
};
...
...
src/materials/MeshFaceMaterial.js
浏览文件 @
bec5849d
...
...
@@ -2,7 +2,11 @@
* @author mrdoob / http://mrdoob.com/
*/
THREE
.
MeshFaceMaterial
=
function
()
{};
THREE
.
MeshFaceMaterial
=
function
(
materials
)
{
this
.
materials
=
materials
instanceof
Array
?
materials
:
[];
};
THREE
.
MeshFaceMaterial
.
prototype
.
clone
=
function
()
{
...
...
src/renderers/WebGLRenderer.js
浏览文件 @
bec5849d
...
...
@@ -890,13 +890,21 @@ THREE.WebGLRenderer = function ( parameters ) {
function
getBufferMaterial
(
object
,
geometryGroup
)
{
if
(
object
.
material
&&
!
(
object
.
material
instanceof
THREE
.
MeshFaceMaterial
)
)
{
if
(
object
.
material
instanceof
THREE
.
MeshFaceMaterial
)
{
return
object
.
material
;
if
(
object
.
material
.
materials
.
length
>
0
)
{
return
object
.
material
.
materials
[
geometryGroup
.
materialIndex
];
}
else
{
}
else
if
(
geometryGroup
.
materialIndex
>=
0
)
{
return
object
.
geometry
.
materials
[
geometryGroup
.
materialIndex
];
return
object
.
geometry
.
materials
[
geometryGroup
.
materialIndex
];
}
}
else
{
return
object
.
material
;
}
...
...
@@ -4160,7 +4168,15 @@ THREE.WebGLRenderer = function ( parameters ) {
if
(
materialIndex
>=
0
)
{
material
=
object
.
geometry
.
materials
[
materialIndex
];
if
(
meshMaterial
.
materials
.
length
>
0
)
{
material
=
meshMaterial
.
materials
[
materialIndex
];
}
else
{
material
=
object
.
geometry
.
materials
[
materialIndex
];
}
if
(
material
.
transparent
)
{
...
...
src/renderers/WebGLShaders.js
浏览文件 @
bec5849d
...
...
@@ -1937,7 +1937,7 @@ THREE.ShaderLib = {
"
void main() {
"
,
"
vec4 mvPosition = modelViewMatrix * vec4( position, 1.0 );
"
,
"
vNormal = normal
Matrix * normal
;
"
,
"
vNormal = normal
ize( normalMatrix * normal )
;
"
,
"
gl_Position = projectionMatrix * mvPosition;
"
,
...
...
@@ -2211,7 +2211,7 @@ THREE.ShaderLib = {
THREE
.
ShaderChunk
[
"
skinnormal_vertex
"
],
THREE
.
ShaderChunk
[
"
defaultnormal_vertex
"
],
"
vNormal =
transformedNormal
;
"
,
"
vNormal =
normalize( transformedNormal )
;
"
,
THREE
.
ShaderChunk
[
"
morphtarget_vertex
"
],
THREE
.
ShaderChunk
[
"
skinning_vertex
"
],
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录