Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Ablesons
three.js
提交
71f53423
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,体验更适合开发者的 AI 搜索 >>
提交
71f53423
编写于
3月 01, 2020
作者:
M
Mr.doob
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Editor: Implemented DataTransferItemList support.
上级
10f3f03f
变更
4
显示空白变更内容
内联
并排
Showing
4 changed file
with
114 addition
and
18 deletion
+114
-18
editor/index.html
editor/index.html
+11
-1
editor/js/Loader.js
editor/js/Loader.js
+14
-17
editor/js/LoaderUtils.js
editor/js/LoaderUtils.js
+88
-0
editor/sw.js
editor/sw.js
+1
-0
未找到文件。
editor/index.html
浏览文件 @
71f53423
...
...
@@ -188,8 +188,18 @@
event
.
preventDefault
();
// DataTransferItemList supports folders
if
(
event
.
dataTransfer
.
items
)
{
editor
.
loader
.
loadItemList
(
event
.
dataTransfer
.
items
);
}
else
{
editor
.
loader
.
loadFiles
(
event
.
dataTransfer
.
files
);
}
},
false
);
function
onWindowResize
()
{
...
...
editor/js/Loader.js
浏览文件 @
71f53423
...
...
@@ -23,17 +23,29 @@ import { VRMLLoader } from '../../examples/jsm/loaders/VRMLLoader.js';
import
{
AddObjectCommand
}
from
'
./commands/AddObjectCommand.js
'
;
import
{
SetSceneCommand
}
from
'
./commands/SetSceneCommand.js
'
;
import
{
LoaderUtils
}
from
'
./LoaderUtils.js
'
;
var
Loader
=
function
(
editor
)
{
var
scope
=
this
;
this
.
texturePath
=
''
;
this
.
loadFiles
=
function
(
files
)
{
this
.
loadItemList
=
function
(
items
)
{
LoaderUtils
.
getFilesFromItemList
(
items
,
function
(
files
,
filesMap
)
{
scope
.
loadFiles
(
files
,
filesMap
);
}
);
};
this
.
loadFiles
=
function
(
files
,
filesMap
)
{
if
(
files
.
length
>
0
)
{
var
filesMap
=
createFile
Map
(
files
);
var
filesMap
=
filesMap
||
LoaderUtils
.
createFiles
Map
(
files
);
var
manager
=
new
THREE
.
LoadingManager
();
manager
.
setURLModifier
(
function
(
url
)
{
...
...
@@ -566,21 +578,6 @@ var Loader = function ( editor ) {
}
function
createFileMap
(
files
)
{
var
map
=
{};
for
(
var
i
=
0
;
i
<
files
.
length
;
i
++
)
{
var
file
=
files
[
i
];
map
[
file
.
name
]
=
file
;
}
return
map
;
}
function
handleZIP
(
contents
)
{
var
zip
=
new
JSZip
(
contents
);
...
...
editor/js/LoaderUtils.js
0 → 100644
浏览文件 @
71f53423
/**
* @author mrdoob / http://mrdoob.com/
*/
var
LoaderUtils
=
{
createFilesMap
:
function
(
files
)
{
var
map
=
{};
for
(
var
i
=
0
;
i
<
files
.
length
;
i
++
)
{
var
file
=
files
[
i
];
map
[
file
.
name
]
=
file
;
}
return
map
;
},
getFilesFromItemList
:
function
(
items
,
onDone
)
{
// TOFIX: setURLModifier() breaks when the file being loaded is not in root
var
itemsCount
=
0
;
var
itemsTotal
=
0
;
var
files
=
[];
var
filesMap
=
{};
function
onEntryHandled
()
{
itemsCount
++
;
if
(
itemsCount
===
itemsTotal
)
{
onDone
(
files
,
filesMap
);
}
}
function
handleEntry
(
entry
)
{
if
(
entry
.
isDirectory
)
{
var
reader
=
entry
.
createReader
();
reader
.
readEntries
(
function
(
entries
)
{
for
(
var
i
=
0
;
i
<
entries
.
length
;
i
++
)
{
handleEntry
(
entries
[
i
]
);
}
onEntryHandled
(
entry
);
}
);
}
else
if
(
entry
.
isFile
)
{
entry
.
file
(
function
(
file
)
{
files
.
push
(
file
);
filesMap
[
entry
.
fullPath
.
substr
(
1
)
]
=
file
;
onEntryHandled
();
}
);
}
itemsTotal
++
;
}
for
(
var
i
=
0
;
i
<
items
.
length
;
i
++
)
{
handleEntry
(
items
[
i
].
webkitGetAsEntry
()
);
}
}
};
export
{
LoaderUtils
};
editor/sw.js
浏览文件 @
71f53423
...
...
@@ -101,6 +101,7 @@ const assets = [
'
./js/Config.js
'
,
'
./js/History.js
'
,
'
./js/Loader.js
'
,
'
./js/LoaderUtils.js
'
,
'
./js/Menubar.js
'
,
'
./js/Menubar.File.js
'
,
'
./js/Menubar.Edit.js
'
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录