2016-07-31 18:32:03 +01:00
|
|
|
/**
|
2019-09-30 23:28:17 +01:00
|
|
|
* The Matter.js development demo and testing tool.
|
|
|
|
*
|
|
|
|
* This demo uses MatterTools, you can see the wiki for a simple example instead:
|
|
|
|
* https://github.com/liabru/matter-js/wiki/Getting-started
|
2016-07-31 18:32:03 +01:00
|
|
|
*
|
|
|
|
* NOTE: For the actual example code, refer to the source files in `/examples/`.
|
|
|
|
*
|
|
|
|
* @class Demo
|
|
|
|
*/
|
|
|
|
|
|
|
|
(function() {
|
2019-09-15 18:36:26 +01:00
|
|
|
var examples = [
|
|
|
|
{ name: 'Air Friction', id: 'airFriction' },
|
|
|
|
{ name: 'Avalanche', id: 'avalanche' },
|
|
|
|
{ name: 'Ball Pool', id: 'ballPool' },
|
|
|
|
{ name: 'Bridge', id: 'bridge' },
|
|
|
|
{ name: 'Broadphase', id: 'broadphase' },
|
|
|
|
{ name: 'Car', id: 'car' },
|
|
|
|
{ name: 'Catapult', id: 'catapult' },
|
|
|
|
{ name: 'Chains', id: 'chains' },
|
|
|
|
{ name: 'Circle Stack', id: 'circleStack' },
|
|
|
|
{ name: 'Cloth', id: 'cloth' },
|
|
|
|
{ name: 'Collision Filtering', id: 'collisionFiltering' },
|
|
|
|
{ name: 'Composite Manipulation', id: 'compositeManipulation' },
|
|
|
|
{ name: 'Compound Bodies', id: 'compound' },
|
|
|
|
{ name: 'Compound Stack', id: 'compoundStack' },
|
|
|
|
{ name: 'Concave', id: 'concave' },
|
|
|
|
{ name: 'Constraints', id: 'constraints' },
|
|
|
|
{ name: 'Double Pendulum', id: 'doublePendulum' },
|
|
|
|
{ name: 'Events', id: 'events' },
|
|
|
|
{ name: 'Friction', id: 'friction' },
|
|
|
|
{ name: 'Reverse Gravity', id: 'gravity' },
|
|
|
|
{ name: 'Gyroscope', id: 'gyro' },
|
|
|
|
{ name: 'Manipulation', id: 'manipulation' },
|
|
|
|
{ name: 'Mixed Shapes', id: 'mixed' },
|
|
|
|
{ name: 'Newton\'s Cradle', id: 'newtonsCradle' },
|
|
|
|
{ name: 'Ragdoll', id: 'ragdoll' },
|
|
|
|
{ name: 'Pyramid', id: 'pyramid' },
|
|
|
|
{ name: 'Raycasting', id: 'raycasting' },
|
|
|
|
{ name: 'Restitution', id: 'restitution' },
|
|
|
|
{ name: 'Rounded Corners (Chamfering)', id: 'rounded' },
|
|
|
|
{ name: 'Sensors', id: 'sensors' },
|
|
|
|
{ name: 'Sleeping', id: 'sleeping' },
|
|
|
|
{ name: 'Slingshot', id: 'slingshot' },
|
|
|
|
{ name: 'Soft Body', id: 'softBody' },
|
|
|
|
{ name: 'Sprites', id: 'sprites' },
|
|
|
|
{ name: 'Stack', id: 'stack' },
|
|
|
|
{ name: 'Static Friction', id: 'staticFriction' },
|
|
|
|
{ name: 'Stress', id: 'stress' },
|
|
|
|
{ name: 'Stress 2', id: 'stress2' },
|
|
|
|
{ name: 'Concave SVG Paths', id: 'svg' },
|
|
|
|
{ name: 'Terrain', id: 'terrain' },
|
|
|
|
{ name: 'Time Scaling', id: 'timescale' },
|
|
|
|
{ name: 'Views', id: 'views' },
|
|
|
|
{ name: 'Wrecking Ball', id: 'wreckingBall' }
|
|
|
|
];
|
|
|
|
|
2016-11-21 00:41:57 +00:00
|
|
|
var sourceLinkRoot = 'https://github.com/liabru/matter-js/blob/master/examples';
|
|
|
|
|
2019-09-15 18:36:26 +01:00
|
|
|
for (var i = 0; i < examples.length; i += 1) {
|
|
|
|
var example = examples[i];
|
|
|
|
example.sourceLink = sourceLinkRoot + '/' + example.id + '.js';
|
|
|
|
example.init = window.Example[example.id];
|
|
|
|
|
|
|
|
if (!example.init) {
|
|
|
|
console.warn('Example not loaded:', example.id);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-09-30 23:28:17 +01:00
|
|
|
if (window.location.search.indexOf('compare') >= 0) {
|
|
|
|
var compareScript = document.createElement('script');
|
|
|
|
compareScript.src = '../js/Compare.js';
|
|
|
|
window.MatterDemo = { examples: examples };
|
|
|
|
document.body.append(compareScript);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2016-11-21 00:41:57 +00:00
|
|
|
var demo = MatterTools.Demo.create({
|
|
|
|
toolbar: {
|
|
|
|
title: 'matter-js',
|
|
|
|
url: 'https://github.com/liabru/matter-js',
|
|
|
|
reset: true,
|
|
|
|
source: true,
|
|
|
|
inspector: true,
|
|
|
|
tools: true,
|
|
|
|
fullscreen: true,
|
|
|
|
exampleSelect: true
|
|
|
|
},
|
|
|
|
tools: {
|
|
|
|
inspector: true,
|
|
|
|
gui: true
|
|
|
|
},
|
|
|
|
inline: false,
|
2017-01-26 23:42:07 +00:00
|
|
|
preventZoom: true,
|
2016-11-21 00:41:57 +00:00
|
|
|
resetOnOrientation: true,
|
2017-07-08 13:28:19 +01:00
|
|
|
routing: true,
|
|
|
|
startExample: 'mixed',
|
2019-09-15 18:36:26 +01:00
|
|
|
examples: examples
|
2016-11-21 00:41:57 +00:00
|
|
|
});
|
2016-07-31 18:32:03 +01:00
|
|
|
|
2020-11-24 23:26:20 +00:00
|
|
|
window.MatterDemo = demo;
|
|
|
|
|
2016-11-21 00:41:57 +00:00
|
|
|
document.body.appendChild(demo.dom.root);
|
2016-07-31 18:32:03 +01:00
|
|
|
|
2016-11-21 00:41:57 +00:00
|
|
|
MatterTools.Demo.start(demo);
|
2017-08-11 11:21:19 +02:00
|
|
|
})();
|