mirror of
https://github.com/liabru/matter-js.git
synced 2025-01-14 16:28:42 -05:00
removed file functions from Matter.Gui and added file functions to Matter.Inspector
This commit is contained in:
parent
fa06a05a04
commit
d883671874
2 changed files with 79 additions and 68 deletions
|
@ -93,9 +93,7 @@ var Gui = {};
|
||||||
addBody: function() { _addBody(gui); },
|
addBody: function() { _addBody(gui); },
|
||||||
clear: function() { _clear(gui); },
|
clear: function() { _clear(gui); },
|
||||||
save: function() { _save(gui); },
|
save: function() { _save(gui); },
|
||||||
saveFile: function() { _saveFile(gui); },
|
load: function() { _load(gui); }
|
||||||
load: function() { _load(gui); },
|
|
||||||
loadFile: function() { _loadFile(gui); }
|
|
||||||
};
|
};
|
||||||
|
|
||||||
var metrics = datGui.addFolder('Metrics');
|
var metrics = datGui.addFolder('Metrics');
|
||||||
|
@ -130,8 +128,6 @@ var Gui = {};
|
||||||
var worldGui = datGui.addFolder('World');
|
var worldGui = datGui.addFolder('World');
|
||||||
worldGui.add(funcs, 'load');
|
worldGui.add(funcs, 'load');
|
||||||
worldGui.add(funcs, 'save');
|
worldGui.add(funcs, 'save');
|
||||||
worldGui.add(funcs, 'loadFile');
|
|
||||||
worldGui.add(funcs, 'saveFile');
|
|
||||||
worldGui.add(funcs, 'clear');
|
worldGui.add(funcs, 'clear');
|
||||||
worldGui.open();
|
worldGui.open();
|
||||||
|
|
||||||
|
@ -241,34 +237,6 @@ var Gui = {};
|
||||||
Events.trigger(gui, 'save');
|
Events.trigger(gui, 'save');
|
||||||
};
|
};
|
||||||
|
|
||||||
var _saveFile = function(gui) {
|
|
||||||
var engine = gui.engine;
|
|
||||||
|
|
||||||
if (gui.serializer) {
|
|
||||||
var json = gui.serializer.stringify(engine.world, function(key, value) {
|
|
||||||
// skip non-required values
|
|
||||||
if (key === 'path')
|
|
||||||
return undefined;
|
|
||||||
|
|
||||||
// limit precision of floats
|
|
||||||
if (!/^#/.exec(key) && typeof value === 'number') {
|
|
||||||
return parseFloat(value.toFixed(2));
|
|
||||||
}
|
|
||||||
return value;
|
|
||||||
});
|
|
||||||
|
|
||||||
var blob = new Blob([json], { type: 'application/json' }),
|
|
||||||
anchor = document.createElement('a');
|
|
||||||
|
|
||||||
anchor.download = "world.json";
|
|
||||||
anchor.href = (window.webkitURL || window.URL).createObjectURL(blob);
|
|
||||||
anchor.dataset.downloadurl = ['application/json', anchor.download, anchor.href].join(':');
|
|
||||||
anchor.click();
|
|
||||||
}
|
|
||||||
|
|
||||||
Events.trigger(gui, 'save');
|
|
||||||
};
|
|
||||||
|
|
||||||
var _load = function(gui) {
|
var _load = function(gui) {
|
||||||
var engine = gui.engine,
|
var engine = gui.engine,
|
||||||
loadedWorld;
|
loadedWorld;
|
||||||
|
@ -284,41 +252,6 @@ var Gui = {};
|
||||||
Events.trigger(gui, 'load');
|
Events.trigger(gui, 'load');
|
||||||
};
|
};
|
||||||
|
|
||||||
var _loadFile = function(gui) {
|
|
||||||
var engine = gui.engine;
|
|
||||||
|
|
||||||
var element = document.createElement('div');
|
|
||||||
element.innerHTML = '<input type="file">';
|
|
||||||
var fileInput = element.firstChild;
|
|
||||||
|
|
||||||
fileInput.addEventListener('change', function(e) {
|
|
||||||
var file = fileInput.files[0];
|
|
||||||
|
|
||||||
if (file.name.match(/\.(txt|json)$/)) {
|
|
||||||
var reader = new FileReader();
|
|
||||||
|
|
||||||
reader.onload = function(e) {
|
|
||||||
var loadedWorld;
|
|
||||||
|
|
||||||
if (gui.serializer)
|
|
||||||
loadedWorld = gui.serializer.parse(reader.result);
|
|
||||||
|
|
||||||
if (loadedWorld) {
|
|
||||||
Engine.merge(engine, { world: loadedWorld });
|
|
||||||
}
|
|
||||||
|
|
||||||
Events.trigger(gui, 'load');
|
|
||||||
}
|
|
||||||
|
|
||||||
reader.readAsText(file);
|
|
||||||
} else {
|
|
||||||
alert("File not supported, JSON text files only");
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
fileInput.click();
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
*
|
*
|
||||||
* Events Documentation
|
* Events Documentation
|
||||||
|
|
|
@ -36,6 +36,13 @@ var Inspector = {};
|
||||||
selected: []
|
selected: []
|
||||||
};
|
};
|
||||||
|
|
||||||
|
if (Resurrect) {
|
||||||
|
inspector.serializer = new Resurrect({ prefix: '$' });
|
||||||
|
inspector.serializer.parse = inspector.serializer.resurrect;
|
||||||
|
} else {
|
||||||
|
inspector.serializer = JSON;
|
||||||
|
}
|
||||||
|
|
||||||
_initControls(inspector);
|
_initControls(inspector);
|
||||||
_initEvents(inspector);
|
_initEvents(inspector);
|
||||||
|
|
||||||
|
@ -111,6 +118,14 @@ var Inspector = {};
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
controls.exportButton.click(function() {
|
||||||
|
_exportFile(inspector);
|
||||||
|
});
|
||||||
|
|
||||||
|
controls.importButton.click(function() {
|
||||||
|
_importFile(inspector);
|
||||||
|
});
|
||||||
|
|
||||||
Events.on(engine, 'tick', function() {
|
Events.on(engine, 'tick', function() {
|
||||||
if (engine.world.isModified) {
|
if (engine.world.isModified) {
|
||||||
var data = _generateCompositeTreeNode(engine.world);
|
var data = _generateCompositeTreeNode(engine.world);
|
||||||
|
@ -429,4 +444,67 @@ var Inspector = {};
|
||||||
return node;
|
return node;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
var _exportFile = function(inspector) {
|
||||||
|
var engine = inspector.engine;
|
||||||
|
|
||||||
|
if (inspector.serializer) {
|
||||||
|
var json = inspector.serializer.stringify(engine.world, function(key, value) {
|
||||||
|
// skip non-required values
|
||||||
|
if (key === 'path')
|
||||||
|
return undefined;
|
||||||
|
|
||||||
|
// limit precision of floats
|
||||||
|
if (!/^#/.exec(key) && typeof value === 'number') {
|
||||||
|
return parseFloat(value.toFixed(2));
|
||||||
|
}
|
||||||
|
return value;
|
||||||
|
});
|
||||||
|
|
||||||
|
var blob = new Blob([json], { type: 'application/json' }),
|
||||||
|
anchor = document.createElement('a');
|
||||||
|
|
||||||
|
anchor.download = "world.json";
|
||||||
|
anchor.href = (window.webkitURL || window.URL).createObjectURL(blob);
|
||||||
|
anchor.dataset.downloadurl = ['application/json', anchor.download, anchor.href].join(':');
|
||||||
|
anchor.click();
|
||||||
|
}
|
||||||
|
|
||||||
|
Events.trigger(inspector, 'save');
|
||||||
|
};
|
||||||
|
|
||||||
|
var _importFile = function(inspector) {
|
||||||
|
var engine = inspector.engine;
|
||||||
|
|
||||||
|
var element = document.createElement('div');
|
||||||
|
element.innerHTML = '<input type="file">';
|
||||||
|
var fileInput = element.firstChild;
|
||||||
|
|
||||||
|
fileInput.addEventListener('change', function(e) {
|
||||||
|
var file = fileInput.files[0];
|
||||||
|
|
||||||
|
if (file.name.match(/\.(txt|json)$/)) {
|
||||||
|
var reader = new FileReader();
|
||||||
|
|
||||||
|
reader.onload = function(e) {
|
||||||
|
var loadedWorld;
|
||||||
|
|
||||||
|
if (inspector.serializer)
|
||||||
|
loadedWorld = inspector.serializer.parse(reader.result);
|
||||||
|
|
||||||
|
if (loadedWorld) {
|
||||||
|
Engine.merge(engine, { world: loadedWorld });
|
||||||
|
}
|
||||||
|
|
||||||
|
Events.trigger(inspector, 'load');
|
||||||
|
}
|
||||||
|
|
||||||
|
reader.readAsText(file);
|
||||||
|
} else {
|
||||||
|
alert("File not supported, JSON text files only");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
fileInput.click();
|
||||||
|
};
|
||||||
|
|
||||||
})();
|
})();
|
Loading…
Reference in a new issue