xrfragment/example/assets/utils.js

53 lines
1.8 KiB
JavaScript
Raw Normal View History

2023-04-21 17:36:03 +02:00
// contentLoaders = {".gltf" : () => .....} and so on
export function loadFile(contentLoaders, multiple){
return () => {
let input = document.createElement('input');
input.type = 'file';
input.multiple = multiple;
input.accept = Object.keys(contentLoaders).join(",");
input.onchange = () => {
let files = Array.from(input.files);
let file = files.slice ? files[0] : files
for( var i in contentLoaders ){
let r = new RegExp('\\'+i+'$')
if( file.name.match(r) ) return contentLoaders[i](file)
}
alert(file.name+" is not supported")
};
input.click();
}
}
2023-04-28 16:04:32 +02:00
2023-05-17 21:31:28 +02:00
export function setupConsole(el){
if( !el ) return setTimeout( () => setupConsole( $('.lil-gui') ),200 )
let $console = document.createElement('textarea')
2023-04-28 16:04:32 +02:00
$console.style.position = 'absolute'
$console.style.display = 'block'
2023-05-17 21:31:28 +02:00
$console.style.zIndex = 2000;
2023-04-28 16:04:32 +02:00
$console.style.background = "transparent !important"
$console.style.pointerEvents = 'none'
$console.style.top = '70px'
2023-05-17 21:31:28 +02:00
$console.style.padding = '10px'
$console.style.margin = '10px'
$console.style.background = '#000'
2023-04-28 16:04:32 +02:00
$console.style.left = $console.style.right = $console.style.bottom = 0;
2023-05-17 21:31:28 +02:00
$console.style.color = '#A6F';
$console.style.fontSize = '10px';
2023-04-28 16:04:32 +02:00
$console.style.fontFamily = 'Courier'
$console.style.border = '0'
$console.innerHTML = "XRFRAGMENT CONSOLE OUTPUT:\n"
2023-05-17 21:31:28 +02:00
el.appendChild($console)
2023-04-28 16:04:32 +02:00
console.log = ( (log) => function(){
let s = new Date().toISOString().substr(11).substr(0,8) + " " + ([...arguments]).join(" ").replace(/.*[0-9]: /,"")
log(s)
let lines = String($console.innerHTML + "\n"+s).split("\n")
while( lines.length > 200 ) lines.shift()
$console.innerHTML = lines.join("\n")
$console.scrollTop = $console.scrollHeight;
})(console.log.bind(console))
}