This is how I used the above script in the multi app example:
<!DOCTYPE html>
<html>
<head>
<title>PlayCanvas Multiple Applications</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, user-scalable=no, minimum-scale=1.0, maximum-scale=1.0">
<link rel="icon" type="image/png" href="../playcanvas-favicon.png" />
<script src="../../build/playcanvas.js"></script>
<script src="../../scripts/camera/fly-camera.js"></script>
<style>
#canvas-1 {
position: absolute;
width: 45%;
left: 0px;
margin: 0 0;
}
#canvas-2 {
position: absolute;
width: 45%;
right: 0px;
margin: 0 0;
}
</style>
</head>
<body>
<!-- The canvas element -->
<canvas id="canvas-1"></canvas>
<canvas id="canvas-2"></canvas>
<!-- The script -->
<script>
var canvas = document.getElementById("canvas-1");
// Create the app and start the update loop
var app1 = new pc.Application(canvas, {
mouse: new pc.Mouse(canvas),
touch: new pc.TouchDevice(canvas),
keyboard: new pc.Keyboard(document.body)
});
app1.start();
app1.setCanvasResolution(pc.RESOLUTION_AUTO);
// Add a script to the register
createFlyCameraScript(app1);
var entity, light, camera;
// Create an Entity with a box component
entity = new pc.Entity(app1);
entity.name = "Box 1";
entity.addComponent("model", {
type: "box"
});
app1.root.addChild(entity);
// Create an Entity with a camera component
var camera = new pc.Entity(app1);
camera.addComponent("camera", {
clearColor: new pc.Color(0.4, 0.45, 0.5)
});
camera.translate(0, 0, 4);
app1.root.addChild(camera);
// Add script to camera
camera.addComponent("script");
camera.script.create("flyCamera");
// Create an Entity with a omni light component
var light = new pc.Entity(app1);
light.addComponent("light", {
type: "omni",
color: new pc.Color(1, 1, 1),
range: 100
});
light.translate(5, 0, 15);
app1.root.addChild(light);
app1.on("update", function (dt) {
var entity = app1.root.findByName("Box 1");
if (entity) {
entity.rotate(0, 10 * dt, 0);
}
});
var canvas = document.getElementById("canvas-2");
// Create the app and start the update loop
var app2 = new pc.Application(canvas, {
mouse: new pc.Mouse(canvas),
touch: new pc.TouchDevice(canvas),
keyboard: new pc.Keyboard(document.body)
});
app2.start();
app2.setCanvasResolution(pc.RESOLUTION_AUTO);
// Add a script to the register
createFlyCameraScript(app2);
var entity, light, camera;
// Create an Entity with a box component
entity = new pc.Entity(app2);
entity.name = "Box 2";
entity.addComponent("model", {
type: "box"
});
app2.root.addChild(entity);
// Create an Entity with a camera component
var camera = new pc.Entity(app2);
camera.addComponent("camera", {
clearColor: new pc.Color(0.4, 0.45, 0.5)
});
camera.translate(0, 0, 4);
app2.root.addChild(camera);
// Add script to camera
camera.addComponent("script");
camera.script.create("flyCamera");
// Create an Entity with a omni light component
var light = new pc.Entity(app2);
light.addComponent("light", {
type: "omni",
color: new pc.Color(1, 1, 1),
range: 100
});
light.translate(5, 0, 15);
app2.root.addChild(light);
app2.on("update", function (dt) {
// var entity = app2.root.findByName("Box 2");
if (entity) {
entity.rotate(0, 10 * dt, 0);
}
});
window.addEventListener("resize", function () {
app1.resizeCanvas(canvas.width, canvas.height);
app2.resizeCanvas(canvas.width, canvas.height);
});
</script>
</body>
</html>