Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Ablesons
three.js
提交
dab80671
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,发现更多精彩内容 >>
提交
dab80671
编写于
11月 23, 2016
作者:
K
Kyle Larson
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Embedded phong material on sample FBX is being applied.
上级
0ad977c2
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
143 addition
and
6 deletion
+143
-6
examples/js/loaders/FBXLoader.js
examples/js/loaders/FBXLoader.js
+138
-5
examples/webgl_loader_fbx.html
examples/webgl_loader_fbx.html
+5
-1
未找到文件。
examples/js/loaders/FBXLoader.js
浏览文件 @
dab80671
...
...
@@ -121,6 +121,7 @@
scope
.
weights
=
(
new
Weights
()
).
parse
(
nodes
,
scope
.
hierarchy
);
scope
.
animations
=
(
new
Animation
()
).
parse
(
nodes
,
scope
.
hierarchy
);
scope
.
textures
=
(
new
Textures
()
).
parse
(
nodes
,
scope
.
hierarchy
);
scope
.
materials
=
(
new
Materials
()
).
parse
(
nodes
,
scope
.
hierarchy
);
console
.
timeEnd
(
'
FBXLoader: ObjectParser
'
);
console
.
time
(
'
FBXLoader: GeometryParser
'
);
...
...
@@ -252,14 +253,38 @@
}
var
material
;
if
(
texture
!==
undefined
)
{
var
mats
=
this
.
materials
.
getById
(
nodes
.
searchConnectionParent
(
geo
.
id
)
);
if
(
mats
!==
undefined
&&
mats
.
length
>
0
)
{
var
mat_data
=
mats
[
0
];
// TODO:
// Cannot find a list of possible ShadingModel values.
// If someone finds a list, please add additional cases
// and map to appropriate materials.
switch
(
mat_data
.
type
)
{
case
"
phong
"
:
material
=
new
THREE
.
MeshPhongMaterial
();
break
;
default
:
console
.
warn
(
"
No implementation given for material type
"
+
mat_data
.
type
+
"
in FBXLoader.js. Defaulting to basic material
"
)
material
=
new
THREE
.
MeshBasicMaterial
({
color
:
0x3300ff
});
break
;
}
if
(
texture
!==
undefined
)
{
mat_data
.
parameters
.
map
=
texture
;
}
material
.
setValues
(
mat_data
.
parameters
);
}
else
{
//No material found for this geometry, create default
if
(
texture
!==
undefined
)
{
material
=
new
THREE
.
MeshBasicMaterial
(
{
map
:
texture
}
);
material
=
new
THREE
.
MeshBasicMaterial
({
map
:
texture
}
);
}
else
{
}
else
{
material
=
new
THREE
.
MeshBasicMaterial
(
{
color
:
0x3300ff
}
);
material
=
new
THREE
.
MeshBasicMaterial
({
color
:
0x3300ff
}
);
}
}
geometry
=
new
THREE
.
Geometry
().
fromBufferGeometry
(
geometry
);
...
...
@@ -522,7 +547,7 @@
// TODO
THREE
.
FBXLoader
.
prototype
.
parseMaterial
=
function
(
node
)
{
};
...
...
@@ -2503,6 +2528,114 @@
};
function
Materials
()
{
this
.
materials
=
[];
this
.
perGeoMap
=
{};
}
Materials
.
prototype
.
add
=
function
(
mat
)
{
if
(
this
.
materials
===
undefined
)
{
this
.
materials
=
[];
}
this
.
materials
.
push
(
mat
);
for
(
var
i
=
0
;
i
<
mat
.
parentIds
.
length
;
++
i
)
{
if
(
this
.
perGeoMap
[
mat
.
parentIds
[
i
]
]
===
undefined
)
{
this
.
perGeoMap
[
mat
.
parentIds
[
i
]
]
=
[];
}
this
.
perGeoMap
[
mat
.
parentIds
[
i
]
].
push
(
this
.
materials
[
this
.
materials
.
length
-
1
]
);
}
};
Materials
.
prototype
.
parse
=
function
(
node
,
bones
)
{
var
rawNodes
=
node
.
Objects
.
subNodes
.
Material
;
for
(
var
n
in
rawNodes
)
{
var
mat
=
(
new
Material
()
).
parse
(
rawNodes
[
n
],
node
);
this
.
add
(
mat
);
}
return
this
;
};
Materials
.
prototype
.
getById
=
function
(
id
)
{
return
this
.
perGeoMap
[
id
];
};
function
Material
()
{
this
.
fileName
=
""
;
this
.
name
=
""
;
this
.
id
=
null
;
this
.
parentIds
=
[];
}
Material
.
prototype
.
parse
=
function
(
node
,
nodes
)
{
this
.
id
=
node
.
id
;
this
.
name
=
node
.
attrName
;
this
.
type
=
node
.
properties
.
ShadingModel
;
this
.
parameters
=
this
.
getParameters
(
node
.
properties
);
this
.
parentIds
=
this
.
searchParents
(
this
.
id
,
nodes
);
return
this
;
};
Material
.
prototype
.
getParameters
=
function
(
properties
)
{
var
parameters
=
{};
//TODO: Missing parameters:
// - Ambient
// - AmbientColor
// - (Diffuse?) Using DiffuseColor, which has same value, so I dunno.
// - (Emissive?) Same as above)
// - MultiLayer
// - ShininessExponent (Same vals as Shininess)
// - Specular (Same vals as SpecularColor)
// - TransparencyFactor (Maybe same as Opacity?).
parameters
.
color
=
new
THREE
.
Color
().
fromArray
(
toFloat
([
properties
.
DiffuseColor
.
value
.
x
,
properties
.
DiffuseColor
.
value
.
y
,
properties
.
DiffuseColor
.
value
.
z
]));
parameters
.
specular
=
new
THREE
.
Color
().
fromArray
(
toFloat
([
properties
.
SpecularColor
.
value
.
x
,
properties
.
SpecularColor
.
value
.
y
,
properties
.
SpecularColor
.
value
.
z
]));
parameters
.
shininess
=
properties
.
Shininess
.
value
;
parameters
.
emissive
=
new
THREE
.
Color
().
fromArray
(
toFloat
([
properties
.
EmissiveColor
.
value
.
x
,
properties
.
EmissiveColor
.
value
.
y
,
properties
.
EmissiveColor
.
value
.
z
]));
parameters
.
emissiveIntensity
=
properties
.
EmissiveFactor
.
value
;
parameters
.
reflectivity
=
properties
.
Reflectivity
.
value
;
parameters
.
opacity
=
properties
.
Opacity
.
value
;
if
(
parameters
.
opacity
<
1.0
)
{
parameters
.
transparent
=
true
;
}
return
parameters
;
};
Material
.
prototype
.
searchParents
=
function
(
id
,
nodes
)
{
var
p
=
nodes
.
searchConnectionParent
(
id
);
return
p
;
};
/* --------------------------------------------------------------------- */
/* --------------------------------------------------------------------- */
...
...
examples/webgl_loader_fbx.html
浏览文件 @
dab80671
...
...
@@ -44,7 +44,7 @@
if
(
!
Detector
.
webgl
)
Detector
.
addGetWebGLMessage
();
var
container
,
stats
,
controls
;
var
camera
,
scene
,
renderer
;
var
camera
,
scene
,
renderer
,
light
;
var
clock
=
new
THREE
.
Clock
();
...
...
@@ -138,6 +138,10 @@
window
.
addEventListener
(
'
resize
'
,
onWindowResize
,
false
);
light
=
new
THREE
.
DirectionalLight
(
0xffffff
,
1.0
);
light
.
position
.
set
(
0
,
1
,
0
);
scene
.
add
(
light
);
animate
();
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录