Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
车家大少爷
three.js
提交
891a374a
T
three.js
项目概览
车家大少爷
/
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,发现更多精彩内容 >>
提交
891a374a
编写于
3月 26, 2017
作者:
W
WestLangley
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Dispose of geometries properly; clean up
上级
df0a5a8c
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
26 addition
and
23 deletion
+26
-23
examples/webgl_geometry_extrude_splines.html
examples/webgl_geometry_extrude_splines.html
+26
-23
未找到文件。
examples/webgl_geometry_extrude_splines.html
浏览文件 @
891a374a
...
...
@@ -95,7 +95,7 @@
SampleClosedSpline
:
sampleClosedSpline
};
var
parent
,
tube
,
tubeMesh
;
var
parent
,
tube
Geometry
,
group
;
var
params
=
{
spline
:
'
GrannyKnot
'
,
...
...
@@ -108,42 +108,45 @@
cameraHelper
:
false
,
};
var
material
=
new
THREE
.
MeshLambertMaterial
(
{
color
:
0xff00ff
}
);
var
wireframeMaterial
=
new
THREE
.
MeshBasicMaterial
(
{
color
:
0x000000
,
opacity
:
0.3
,
wireframe
:
true
,
transparent
:
true
}
);
function
addTube
()
{
if
(
tubeMesh
!==
undefined
)
parent
.
remove
(
tubeMesh
);
if
(
group
!==
undefined
)
{
parent
.
remove
(
group
);
group
.
children
[
0
].
geometry
.
dispose
();
group
.
children
[
1
].
geometry
.
dispose
();
}
extrudePath
=
splines
[
params
.
spline
];
tube
=
new
THREE
.
TubeBufferGeometry
(
extrudePath
,
params
.
extrusionSegments
,
2
,
params
.
radiusSegments
,
params
.
closed
);
tubeGeometry
=
new
THREE
.
TubeBufferGeometry
(
extrudePath
,
params
.
extrusionSegments
,
2
,
params
.
radiusSegments
,
params
.
closed
);
addGeometry
(
tubeGeometry
);
addGeometry
(
tube
,
0xff00ff
);
setScale
();
}
function
setScale
()
{
tubeMesh
.
scale
.
set
(
params
.
scale
,
params
.
scale
,
params
.
scale
);
group
.
scale
.
set
(
params
.
scale
,
params
.
scale
,
params
.
scale
);
}
function
addGeometry
(
geometry
,
color
)
{
function
addGeometry
(
geometry
)
{
// 3D shape
tubeMesh
=
THREE
.
SceneUtils
.
createMultiMaterialObject
(
geometry
,
[
new
THREE
.
MeshLambertMaterial
(
{
color
:
color
}
),
new
THREE
.
MeshBasicMaterial
(
{
color
:
0x000000
,
opacity
:
0.3
,
wireframe
:
true
,
transparent
:
true
}
)
]
);
group
=
THREE
.
SceneUtils
.
createMultiMaterialObject
(
geometry
,
[
material
,
wireframeMaterial
]
);
parent
.
add
(
tubeMesh
);
parent
.
add
(
group
);
}
...
...
@@ -266,20 +269,20 @@
var
looptime
=
20
*
1000
;
var
t
=
(
time
%
looptime
)
/
looptime
;
var
pos
=
tube
.
parameters
.
path
.
getPointAt
(
t
);
var
pos
=
tube
Geometry
.
parameters
.
path
.
getPointAt
(
t
);
pos
.
multiplyScalar
(
params
.
scale
);
// interpolation
var
segments
=
tube
.
tangents
.
length
;
var
segments
=
tube
Geometry
.
tangents
.
length
;
var
pickt
=
t
*
segments
;
var
pick
=
Math
.
floor
(
pickt
);
var
pickNext
=
(
pick
+
1
)
%
segments
;
binormal
.
subVectors
(
tube
.
binormals
[
pickNext
],
tube
.
binormals
[
pick
]
);
binormal
.
multiplyScalar
(
pickt
-
pick
).
add
(
tube
.
binormals
[
pick
]
);
binormal
.
subVectors
(
tube
Geometry
.
binormals
[
pickNext
],
tubeGeometry
.
binormals
[
pick
]
);
binormal
.
multiplyScalar
(
pickt
-
pick
).
add
(
tube
Geometry
.
binormals
[
pick
]
);
var
dir
=
tube
.
parameters
.
path
.
getTangentAt
(
t
);
var
dir
=
tube
Geometry
.
parameters
.
path
.
getTangentAt
(
t
);
var
offset
=
15
;
normal
.
copy
(
binormal
).
cross
(
dir
);
...
...
@@ -293,7 +296,7 @@
// using arclength for stablization in look ahead
var
lookAt
=
tube
.
parameters
.
path
.
getPointAt
(
(
t
+
30
/
tube
.
parameters
.
path
.
getLength
()
)
%
1
).
multiplyScalar
(
params
.
scale
);
var
lookAt
=
tube
Geometry
.
parameters
.
path
.
getPointAt
(
(
t
+
30
/
tubeGeometry
.
parameters
.
path
.
getLength
()
)
%
1
).
multiplyScalar
(
params
.
scale
);
// camera orientation 2 - up orientation via normal
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录