-
Notifications
You must be signed in to change notification settings - Fork 40
/
graphics.js
84 lines (72 loc) · 3.17 KB
/
graphics.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
import * as BABYLON from 'babylonjs';
/**
* GraphicsEngine class for running BabylonJS
* and rendering 3D rigged character on it
*/
export default class GraphicsEngine {
/**
* the class constructor
* @param {HTMLCanvasElement} _canvas
* @param {Joints} _joints
*/
constructor(_canvas, _joints){
this.canvas = _canvas;
this.engine = new BABYLON.Engine(this.canvas, true);
this.engine.displayLoadingUI();
this.engine.loadingUIText = "Bablyon 3D Loading ...";
this.joints = _joints;
this.initScene();
this.engine.hideLoadingUI();
}
/**
* Initialez the scene, creates the character
* and defines how should joints of the character be updated
*/
initScene(){
this.scene = new BABYLON.Scene(this.engine);
this.scene.clearColor = new BABYLON.Color3(0.5, 0.8, 0.5);
const camera = this.setCamera();
const sphere = BABYLON.MeshBuilder.CreateSphere('', { diameter: .0001 }, this.scene);
BABYLON.SceneLoader.ImportMesh("", `/${process.env.BPATH}/Scenes/Dude/`, "Dude.babylon", this.scene, (newMeshes, particleSystems, skeletons) => {
const mesh = newMeshes[0];
const skeleton = skeletons[0];
mesh.scaling = new BABYLON.Vector3(0.1, 0.1, 0.1);
mesh.position = new BABYLON.Vector3(0, 0, 0);
const head_bone = skeleton.bones[7];
const right_shoulder_bone = skeleton.bones[13];
const right_arm_bone = skeleton.bones[14];
const left_shoulder_bone = skeleton.bones[32];
const left_arm_bone = skeleton.bones[33];
const lookAtCtl = new BABYLON.BoneLookController(mesh, head_bone, sphere.position, { adjustYaw: Math.PI * .5, adjustRoll: Math.PI * .5 });
this.scene.registerBeforeRender(() => {
const { data } = this.joints;
sphere.position.x = 0 + data.head.x;
sphere.position.y = 6 + data.head.y;
sphere.position.z = 5;
lookAtCtl.update();
right_shoulder_bone.rotation = new BABYLON.Vector3(0, 1.5 * data.rightShoulder, 0);
right_arm_bone.rotation = new BABYLON.Vector3(0, data.rightElbow, 0);
left_shoulder_bone.rotation = new BABYLON.Vector3(0, -1.5 * data.leftShoulder, 0);
left_arm_bone.rotation = new BABYLON.Vector3(0, -data.leftElbow, 0);
});
});
};
/** BabylonJS render function that is called every frame */
render(){
const self = this;
this.engine.runRenderLoop(() => {
const self = this;
if(self.scene) self.scene.render();
});
}
/** Sets up 3d virtual cam for the scene */
setCamera(){
const camera = new BABYLON.ArcRotateCamera("camera", 0, 1, 20, BABYLON.Vector3.Zero(), this.scene);
camera.setTarget(new BABYLON.Vector3(0, 4, 0));
camera.setPosition(new BABYLON.Vector3(0, 5, 11))
camera.attachControl(this.canvas, true);
const light = new BABYLON.HemisphericLight("light1", new BABYLON.Vector3(0, 1, 0), this.scene);
light.intensity = 0.7;
return camera;
}
}