2016-12-01 21:02:00 +01:00
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
|
|
function runDemo(canvasId) {
|
|
|
|
|
var canvas = document.getElementById(canvasId);
|
|
|
|
|
var engine = new BABYLON.Engine(canvas, true);
|
2016-12-01 22:31:33 +01:00
|
|
|
|
|
2016-12-01 21:06:23 +01:00
|
|
|
|
// Cr<43>ation de la sc<73>ne
|
2016-12-01 21:02:00 +01:00
|
|
|
|
var scene = new BABYLON.Scene(engine);
|
2016-12-02 00:37:38 +01:00
|
|
|
|
var loader = new BABYLON.AssetsManager(scene);//Obj loader
|
|
|
|
|
BABYLON.OBJFileLoader.OPTIMIZE_WITH_UV = true;
|
2016-12-01 21:02:00 +01:00
|
|
|
|
scene.gravity = new BABYLON.Vector3(0, -9.81, 0);
|
|
|
|
|
scene.collisionsEnabled = true;
|
2016-12-01 22:31:33 +01:00
|
|
|
|
|
2016-12-01 21:06:23 +01:00
|
|
|
|
// Ajout d'une cam<61>ra et de son contr<74>leur
|
2016-12-01 21:02:00 +01:00
|
|
|
|
var camera = new BABYLON.FreeCamera("MainCamera", new BABYLON.Vector3(0, 2.5, 5), scene);
|
|
|
|
|
camera.applyGravity = true;
|
|
|
|
|
camera.checkCollisions = true;
|
2016-12-01 22:31:33 +01:00
|
|
|
|
|
2016-12-01 21:02:00 +01:00
|
|
|
|
camera.speed = 0.5;
|
|
|
|
|
camera.angularSensibility = 1000;
|
2016-12-01 22:31:33 +01:00
|
|
|
|
|
2016-12-01 21:02:00 +01:00
|
|
|
|
camera.keysUp = [90]; // Touche Z
|
|
|
|
|
camera.keysDown = [83]; // Touche S
|
|
|
|
|
camera.keysLeft = [81]; // Touche Q
|
|
|
|
|
camera.keysRight = [68]; // Touche D;
|
|
|
|
|
scene.activeCamera.attachControl(canvas);
|
2016-12-01 21:06:23 +01:00
|
|
|
|
|
2016-12-02 00:06:24 +01:00
|
|
|
|
if(camera.position.x>2){
|
|
|
|
|
camera.position.x=2;
|
|
|
|
|
}else if(camera.position.x<-2){
|
|
|
|
|
camera.position.x=-2;
|
|
|
|
|
}
|
|
|
|
|
|
2016-12-01 21:06:23 +01:00
|
|
|
|
// Ajout d'une lumi<6D>re
|
2016-12-01 21:02:00 +01:00
|
|
|
|
var light = new BABYLON.PointLight("DirLight", new BABYLON.Vector3(0, 10, 0), scene);
|
|
|
|
|
light.diffuse = new BABYLON.Color3(1, 1, 1);
|
|
|
|
|
light.specular = new BABYLON.Color3(0.6, 0.6, 0.6);
|
|
|
|
|
light.intensity = 1.5;
|
2016-12-01 22:31:33 +01:00
|
|
|
|
|
2016-12-01 21:02:00 +01:00
|
|
|
|
// On ajoute une skybox
|
|
|
|
|
createSkybox(scene);
|
2016-12-01 22:31:33 +01:00
|
|
|
|
|
2016-12-01 21:06:23 +01:00
|
|
|
|
// Enfin la sc<73>ne de d<>mo
|
2016-12-01 21:02:00 +01:00
|
|
|
|
createDemoScene(scene);
|
2016-12-01 22:31:33 +01:00
|
|
|
|
|
2016-12-02 00:06:24 +01:00
|
|
|
|
// Creer l obj
|
2016-12-02 00:37:38 +01:00
|
|
|
|
createObj(loader,scene);
|
|
|
|
|
|
|
|
|
|
loader.onFinish = function() {
|
|
|
|
|
engine.runRenderLoop(function () {
|
|
|
|
|
scene.render();
|
|
|
|
|
});
|
|
|
|
|
};
|
2016-12-02 00:06:24 +01:00
|
|
|
|
|
2016-12-02 00:37:38 +01:00
|
|
|
|
loader.load();
|
|
|
|
|
return scene;
|
2016-12-01 21:02:00 +01:00
|
|
|
|
}
|
|
|
|
|
|
2016-12-02 00:37:38 +01:00
|
|
|
|
function createObj(loader,scene){
|
|
|
|
|
var batman = loader.addMeshTask("bunny", "", "assets/", "bunny.obj");
|
|
|
|
|
batman.onSuccess = function(t){
|
|
|
|
|
t.loadedMeshes.forEach(function(m) {
|
|
|
|
|
m.position.x = 10;
|
|
|
|
|
m.scale = 100;
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
}
|
2016-12-02 00:06:24 +01:00
|
|
|
|
|
2016-12-01 21:02:00 +01:00
|
|
|
|
function createSkybox(scene) {
|
2016-12-01 21:06:23 +01:00
|
|
|
|
// Cr<43>ation d'une material
|
2016-12-01 21:02:00 +01:00
|
|
|
|
var sMaterial = new BABYLON.StandardMaterial("skyboxMaterial", scene);
|
|
|
|
|
sMaterial.backFaceCulling = false;
|
|
|
|
|
sMaterial.reflectionTexture = new BABYLON.CubeTexture("images/skybox/skybox", scene);
|
|
|
|
|
sMaterial.reflectionTexture.coordinatesMode = BABYLON.Texture.SKYBOX_MODE;
|
2016-12-01 22:31:33 +01:00
|
|
|
|
|
2016-12-01 21:06:23 +01:00
|
|
|
|
// Cr<43>ation d'un cube avec la material adapt<70>e
|
2016-12-01 21:02:00 +01:00
|
|
|
|
var skybox = BABYLON.Mesh.CreateBox("skybox", 250, scene);
|
|
|
|
|
skybox.material = sMaterial;
|
|
|
|
|
}
|
|
|
|
|
|
2016-12-02 00:06:24 +01:00
|
|
|
|
|
|
|
|
|
|
2016-12-01 21:02:00 +01:00
|
|
|
|
function createDemoScene(scene) {
|
2016-12-01 21:06:23 +01:00
|
|
|
|
// Cr<43>ation d'un sol
|
2016-12-02 00:06:24 +01:00
|
|
|
|
var ground = BABYLON.Mesh.CreatePlane("ground", 50, scene);
|
|
|
|
|
ground.rotation.x = Math.PI / 2;
|
|
|
|
|
ground.material = new BABYLON.StandardMaterial("gMaterial", scene);
|
|
|
|
|
ground.material.diffuseTexture = new BABYLON.Texture("images/ground.png", scene);
|
|
|
|
|
ground.checkCollisions = true;
|
|
|
|
|
|
|
|
|
|
var mur1 = BABYLON.Mesh.CreatePlane("mur1", 50, scene);
|
|
|
|
|
mur1.rotation.y = Math.PI / 2;
|
|
|
|
|
mur1.position.y = 20;
|
|
|
|
|
mur1.position.x = 25;
|
|
|
|
|
mur1.visibility = 0;
|
|
|
|
|
mur1.checkCollisions = true;
|
|
|
|
|
|
|
|
|
|
var mur2 = BABYLON.Mesh.CreatePlane("mur2", 50, scene);
|
|
|
|
|
mur2.rotation.y = -(Math.PI / 2);
|
|
|
|
|
mur2.position.y = 20;
|
|
|
|
|
mur2.position.x = -25;
|
|
|
|
|
mur2.visibility = 0;
|
|
|
|
|
mur2.checkCollisions = true;
|
|
|
|
|
|
|
|
|
|
var mur3 = BABYLON.Mesh.CreatePlane("mur3", 50, scene);
|
|
|
|
|
mur3.rotation.z = Math.PI / 2;
|
|
|
|
|
mur3.position.z = 25;
|
|
|
|
|
mur3.visibility = 0;
|
|
|
|
|
mur3.checkCollisions = true;
|
|
|
|
|
|
|
|
|
|
var mur4 = BABYLON.Mesh.CreatePlane("mur4", 50, scene);
|
|
|
|
|
mur4.rotation.x = Math.PI;
|
|
|
|
|
mur4.position.z = -25;
|
|
|
|
|
mur4.visibility = 0;
|
|
|
|
|
mur4.checkCollisions = true;
|
2016-12-01 22:31:33 +01:00
|
|
|
|
|
2016-12-01 21:02:00 +01:00
|
|
|
|
// Et quelques cubes...
|
|
|
|
|
var boxMaterial = new BABYLON.StandardMaterial("bMaterial", scene);
|
|
|
|
|
boxMaterial.diffuseTexture = new BABYLON.Texture("images/box.png", scene);
|
2016-12-01 22:31:33 +01:00
|
|
|
|
|
2016-12-01 21:02:00 +01:00
|
|
|
|
var positions = [
|
|
|
|
|
{ x: -15, z: 15 },
|
|
|
|
|
{ x: -15, z: -15 },
|
|
|
|
|
{ x: 15, z: 15 },
|
|
|
|
|
{ x: 15, z: -15 }
|
|
|
|
|
];
|
2016-12-01 22:31:33 +01:00
|
|
|
|
|
2016-12-01 21:02:00 +01:00
|
|
|
|
var cubeSize = 2.5;
|
2016-12-01 22:31:33 +01:00
|
|
|
|
|
2016-12-01 21:02:00 +01:00
|
|
|
|
for (var i = 0; i < 4; i++) {
|
|
|
|
|
var box = BABYLON.Mesh.CreateBox("box1", cubeSize, scene);
|
|
|
|
|
box.position = new BABYLON.Vector3(positions[i].x, cubeSize / 2, positions[i].z);
|
|
|
|
|
box.material = boxMaterial;
|
|
|
|
|
box.checkCollisions = true;
|
|
|
|
|
}
|
2016-12-01 22:31:33 +01:00
|
|
|
|
}
|