ng2-3d-editor
Version:
Angular 2 3D Editor/viewer
282 lines (280 loc) • 47.2 kB
JavaScript
"use strict";
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __metadata = (this && this.__metadata) || function (k, v) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
};
var core_1 = require("@angular/core");
var editorControls_1 = require("../controllers/editorControls");
var THREE = require('three');
var FBXLoaderService = require('../jsservice/fbxLoader2.service.js');
var TransformControls = require('three-transformcontrols');
var ObjLoaderService = require('../jsservice/objLoader.service');
var MtlLoaderService = require('../jsservice/mtlLoader.service');
var Viewer3DComponent = (function () {
function Viewer3DComponent() {
this.enableTransformController = true;
this.inGenerate = false;
this.mouseX = 0;
this.mouseY = 0;
this.center = new THREE.Vector3();
this.loading = true;
}
Viewer3DComponent.prototype.ngOnChanges = function (changes) {
if (this.scene && changes.urlFile.currentValue !== changes.urlFile.previousValue.toString()) {
this.loading = true;
this.clearScene();
this.lights();
this.grid();
this.axisHelper();
this.load();
this.animate();
}
};
Viewer3DComponent.prototype.ngOnInit = function () {
var _this = this;
console.log(ObjLoaderService);
console.log(MtlLoaderService);
console.log(FBXLoaderService);
console.log(TransformControls);
this.container = document.getElementById('viewer-3d');
this.camera = new THREE.PerspectiveCamera(45, window.innerWidth / window.innerHeight, 1, 2000);
this.camera.position.z = 250;
this.scene = new THREE.Scene();
this.lights();
this.grid();
this.axisHelper();
this.load();
this.renderer = new THREE.WebGLRenderer();
this.renderer.setPixelRatio(window.devicePixelRatio);
this.renderer.setSize(window.innerWidth, window.innerHeight);
if (this.clearColor) {
this.renderer.setClearColor(this.clearColor);
}
this.container.appendChild(this.renderer.domElement);
this.animate();
if (this.enableTransformController) {
this.transformControl = new TransformControls(this.camera, this.renderer.domElement);
this.transformControl.addEventListener('change', this.render.bind(this));
}
this.controllers = new editorControls_1.EditorControls(this.container, this.camera);
window.addEventListener('resize', this.onWindowResize.bind(this), false);
window.addEventListener('keydown', function (event) {
switch (event.keyCode) {
case 81:
_this.transformControl.setSpace(_this.transformControl.space === 'local' ? 'world' : 'local');
break;
case 17:
_this.transformControl.setTranslationSnap(100);
_this.transformControl.setRotationSnap(THREE.Math.degToRad(15));
break;
case 87:
_this.transformControl.setMode('translate');
break;
case 69:
_this.transformControl.setMode('rotate');
break;
case 82:
_this.transformControl.setMode('scale');
break;
case 187:
case 107:
_this.transformControl.setSize(_this.transformControl.size + 0.1);
break;
case 189:
case 109:
_this.transformControl.setSize(Math.max(_this.transformControl.size - 0.1, 0.1));
break;
default:
break;
}
});
window.addEventListener('keyup', function (event) {
switch (event.keyCode) {
case 17:
_this.transformControl.setTranslationSnap(null);
_this.transformControl.setRotationSnap(null);
break;
default:
break;
}
});
};
Viewer3DComponent.prototype.load = function () {
if (!this.extension) {
this.extension = this.getFileExtension(this.urlFile);
}
if (this.extension === 'obj') {
this.loadObjFormatFile();
}
else if (this.extension === 'fbx') {
this.loadFbxFormatFile();
}
};
Viewer3DComponent.prototype.lights = function () {
var ambient = new THREE.AmbientLight(0x444444);
var directionalLight = new THREE.DirectionalLight(0xffffff, 1);
directionalLight.position.set(1, 1, 1).normalize();
var helper = new THREE.DirectionalLightHelper(directionalLight, 5);
this.scene.add(ambient);
this.scene.add(helper);
this.scene.add(directionalLight);
};
Viewer3DComponent.prototype.axisHelper = function () {
var axisHelper = new THREE.AxisHelper(5);
this.scene.add(axisHelper);
};
Viewer3DComponent.prototype.grid = function () {
var lineMaterial = new THREE.LineBasicMaterial({ color: 0x303030 }), geometry = new THREE.Geometry(), floor = -75, step = 25;
for (var i = 0; i <= 40; i++) {
geometry.vertices.push(new THREE.Vector3(-500, floor, i * step - 500));
geometry.vertices.push(new THREE.Vector3(500, floor, i * step - 500));
geometry.vertices.push(new THREE.Vector3(i * step - 500, floor, -500));
geometry.vertices.push(new THREE.Vector3(i * step - 500, floor, 500));
}
var line = new THREE.LineSegments(geometry, lineMaterial);
this.scene.add(line);
};
Viewer3DComponent.prototype.loadObjFormatFile = function () {
var _this = this;
var mtlLoader = new THREE.MTLLoader();
this.setDetailLoad('MATERIALS');
mtlLoader.load(this.urlFile.replace('.obj', '.mtl'), function (materials) {
_this.loadObj(materials);
}, function (progress) {
console.log('progress material loader' + JSON.stringify(progress));
}, function (error) {
console.log('error material loader');
_this.loadObj(null);
});
};
Viewer3DComponent.prototype.loadFbxFormatFile = function () {
var _this = this;
this.setDetailLoad('FBX OBJECTS');
var manager = new THREE.LoadingManager();
manager.onProgress = function (item, loaded, total) {
console.log(item, loaded, total);
};
var loader = new THREE.FBXLoader(manager);
loader.load(this.urlFile, function (object) {
_this.loading = false;
object.mixer = new THREE.AnimationMixer(object);
var action = object.mixer.clipAction(object.animations[0]);
action.play();
_this.scene.add(object);
if (_this.enableTransformController) {
_this.transformControl.attach(object);
_this.scene.add(_this.transformControl);
}
}, function (progress) {
console.log('progress fbx loader' + JSON.stringify(progress));
}, function (error) {
_this.setDetailLoad('ERROR loafing FBX file');
console.log('error' + error);
});
};
Viewer3DComponent.prototype.loadObj = function (materials) {
var _this = this;
var objLoader = new THREE.OBJLoader();
if (materials) {
materials.preload();
objLoader.setMaterials(materials);
}
this.setDetailLoad('OBJ OBJECTS');
objLoader.load(this.urlFile, function (object) {
_this.loading = false;
_this.scene.add(object);
if (_this.enableTransformController) {
_this.transformControl.attach(object);
_this.scene.add(_this.transformControl);
}
_this.cameraPositioning();
}, function (progress) {
console.log('progress obj loader' + JSON.stringify(progress));
}, function (error) {
_this.setDetailLoad('ERROR loafing OBJ file' + error);
console.log('error' + error);
});
};
Viewer3DComponent.prototype.cameraPositioning = function () {
if (this.initialPositionCamera) {
this.camera.position.set(this.initialPositionCamera.x, this.initialPositionCamera.y, this.initialPositionCamera.z);
}
if (this.initialRotationCamera) {
this.camera.rotation.set(this.initialRotationCamera.x, this.initialRotationCamera.y, this.initialRotationCamera.z);
}
this.camera.lookAt(this.center);
};
Viewer3DComponent.prototype.setDetailLoad = function (detail) {
this.detailLoading = detail;
};
;
Viewer3DComponent.prototype.animate = function () {
requestAnimationFrame(this.animate.bind(this));
this.render();
};
Viewer3DComponent.prototype.onWindowResize = function () {
this.windowHalfX = this.container.offsetWidth / 2;
this.windowHalfY = this.container.offsetHeight / 2;
this.camera.aspect = this.container.offsetWidth / this.container.offsetHeight;
this.camera.updateProjectionMatrix();
this.renderer.setSize(this.container.offsetWidth, this.container.offsetHeight);
};
Viewer3DComponent.prototype.render = function () {
if (this.transformControl) {
this.transformControl.update();
}
this.renderer.render(this.scene, this.camera);
};
Viewer3DComponent.prototype.isLoading = function () {
return this.loading;
};
Viewer3DComponent.prototype.getFileExtension = function (fileName) {
return fileName.split('.').pop().toLowerCase();
};
Viewer3DComponent.prototype.clearScene = function () {
var _this = this;
this.extension = undefined;
this.scene.children.forEach(function (object) {
_this.scene.remove(object);
});
};
return Viewer3DComponent;
}());
__decorate([
core_1.Input(),
__metadata("design:type", String)
], Viewer3DComponent.prototype, "urlFile", void 0);
__decorate([
core_1.Input(),
__metadata("design:type", String)
], Viewer3DComponent.prototype, "extension", void 0);
__decorate([
core_1.Input(),
__metadata("design:type", String)
], Viewer3DComponent.prototype, "clearColor", void 0);
__decorate([
core_1.Input(),
__metadata("design:type", Object)
], Viewer3DComponent.prototype, "initialPositionCamera", void 0);
__decorate([
core_1.Input(),
__metadata("design:type", Object)
], Viewer3DComponent.prototype, "initialRotationCamera", void 0);
__decorate([
core_1.Input(),
__metadata("design:type", Object)
], Viewer3DComponent.prototype, "enableTransformController", void 0);
Viewer3DComponent = __decorate([
core_1.Component({
selector: 'threed-viewer',
template: " <div class=\"loader-container\" *ngIf=\"isLoading()\" > <div class=\"loader\"> <h1>LOADING {{detailLoading}}</h1> <span></span> <span></span> <span></span> </div> </div> <div class=\"viewer-3d-content\"> <div class=\"viewer-3d-row\"> <div class=\"viewer-3d-cell\"> <div id=\"viewer-3d\" class=\"viewer-3d\"> </div> </div> </div> </div>",
styles: [" .viewer-3d-content { font-family: Monospace; background-color: #000; color: #fff; margin: 0px; overflow: hidden; } .viewer-3d-row { display: -webkit-box; display: -moz-box; display: -ms-flexbox; display: -webkit-flex; display: flex; -webkit-box-orient: horizontal; -moz-box-orient: horizontal; box-orient: horizontal; flex-direction: row; -webkit-box-pack: center; -moz-box-pack: center; box-pack: center; justify-content: center; -webkit-box-align: center; -moz-box-align: center; box-align: center; align-items: center; } .viewer-3d-cell { -webkit-box-flex: 1; -moz-box-flex: 1; box-flex: 1; -webkit-flex: 1 1 auto; flex: 1 1 auto; padding: 10px; margin: 10px; text-align: center; } .viewer-3d { height: 80vh; max-width: 100%; } .loader-container{ width: 200px; height: 200px; top: 0; bottom: 0; margin: auto; position: absolute; left: 0; right: 0; } .loader{ background:#333; } h1{ font-family: 'Actor', sans-serif; color:#FFF; font-size:16px; letter-spacing:1px; font-weight:200; text-align:center; } .loader span{ width:16px; height:16px; border-radius:50%; display:inline-block; position:absolute; left:50%; margin-left:-10px; -webkit-animation:3s infinite linear; -moz-animation:3s infinite linear; -o-animation:3s infinite linear; } .loader span:nth-child(2){ background:#E84C3D; -webkit-animation:kiri 1.2s infinite linear; -moz-animation:kiri 1.2s infinite linear; -o-animation:kiri 1.2s infinite linear; } .loader span:nth-child(3){ background:#F1C40F; z-index:100; } .loader span:nth-child(4){ background:#2FCC71; -webkit-animation:kanan 1.2s infinite linear; -moz-animation:kanan 1.2s infinite linear; -o-animation:kanan 1.2s infinite linear; } @-webkit-keyframes kanan { 0% {-webkit-transform:translateX(20px); } 50%{-webkit-transform:translateX(-20px); } 100%{-webkit-transform:translateX(20px); z-index:200; } } @-moz-keyframes kanan { 0% {-moz-transform:translateX(20px); } 50%{-moz-transform:translateX(-20px); } 100%{-moz-transform:translateX(20px); z-index:200; } } @-o-keyframes kanan { 0% {-o-transform:translateX(20px); } 50%{-o-transform:translateX(-20px); } 100%{-o-transform:translateX(20px); z-index:200; } } @-webkit-keyframes kiri { 0% {-webkit-transform:translateX(-20px); z-index:200; } 50%{-webkit-transform:translateX(20px); } 100%{-webkit-transform:translateX(-20px); } } @-moz-keyframes kiri { 0% {-moz-transform:translateX(-20px); z-index:200; } 50%{-moz-transform:translateX(20px); } 100%{-moz-transform:translateX(-20px); } } @-o-keyframes kiri { 0% {-o-transform:translateX(-20px); z-index:200; } 50%{-o-transform:translateX(20px); } 100%{-o-transform:translateX(-20px); } }"]
})
], Viewer3DComponent);
exports.Viewer3DComponent = Viewer3DComponent;
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["components/viewer3D.component.ts"],"names":[],"mappings":"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","file":"components/viewer3D.component.js","sourcesContent":["import { Component, Input } from '@angular/core';\nimport { EditorControls } from '../controllers/editorControls';\n\nlet THREE = require('three');\nlet FBXLoaderService = require('../jsservice/fbxLoader2.service.js');\nlet TransformControls = require('three-transformcontrols');\nlet ObjLoaderService = require('../jsservice/objLoader.service');\nlet MtlLoaderService = require('../jsservice/mtlLoader.service');\n\n@Component({\n    selector: 'threed-viewer',\n    template: \" <div class=\\\"loader-container\\\"  *ngIf=\\\"isLoading()\\\" >     <div class=\\\"loader\\\">         <h1>LOADING {{detailLoading}}</h1>         <span></span>         <span></span>         <span></span>     </div> </div>  <div class=\\\"viewer-3d-content\\\">     <div class=\\\"viewer-3d-row\\\">         <div class=\\\"viewer-3d-cell\\\">             <div id=\\\"viewer-3d\\\" class=\\\"viewer-3d\\\">             </div>         </div>     </div> </div>\",\n    styles: [\" .viewer-3d-content {     font-family: Monospace;     background-color: #000;     color: #fff;     margin: 0px;     overflow: hidden; }  .viewer-3d-row {     display: -webkit-box;     display: -moz-box;     display: -ms-flexbox;     display: -webkit-flex;     display: flex;      -webkit-box-orient: horizontal;     -moz-box-orient: horizontal;     box-orient: horizontal;     flex-direction: row;      -webkit-box-pack: center;     -moz-box-pack: center;     box-pack: center;     justify-content: center;      -webkit-box-align: center;     -moz-box-align: center;     box-align: center;     align-items: center; }  .viewer-3d-cell {     -webkit-box-flex: 1;     -moz-box-flex: 1;     box-flex: 1;     -webkit-flex: 1 1 auto;     flex: 1 1 auto;      padding: 10px;     margin: 10px;      text-align: center; }  .viewer-3d {     height: 80vh;     max-width: 100%; }  .loader-container{     width: 200px;     height: 200px;     top: 0;     bottom: 0;     margin: auto;     position: absolute;     left: 0;     right: 0; }  .loader{     background:#333;  }  h1{     font-family: 'Actor', sans-serif;     color:#FFF;     font-size:16px;     letter-spacing:1px;     font-weight:200;     text-align:center; } .loader span{     width:16px;     height:16px;     border-radius:50%;     display:inline-block;     position:absolute;     left:50%;     margin-left:-10px;     -webkit-animation:3s infinite linear;     -moz-animation:3s infinite linear;     -o-animation:3s infinite linear;  }   .loader span:nth-child(2){     background:#E84C3D;     -webkit-animation:kiri 1.2s infinite linear;     -moz-animation:kiri 1.2s infinite linear;     -o-animation:kiri 1.2s infinite linear;  } .loader span:nth-child(3){     background:#F1C40F;     z-index:100; } .loader span:nth-child(4){     background:#2FCC71;     -webkit-animation:kanan 1.2s infinite linear;     -moz-animation:kanan 1.2s infinite linear;     -o-animation:kanan 1.2s infinite linear; }   @-webkit-keyframes kanan {     0% {-webkit-transform:translateX(20px);     }      50%{-webkit-transform:translateX(-20px);     }      100%{-webkit-transform:translateX(20px);         z-index:200;     } } @-moz-keyframes kanan {     0% {-moz-transform:translateX(20px);     }      50%{-moz-transform:translateX(-20px);     }      100%{-moz-transform:translateX(20px);         z-index:200;     } } @-o-keyframes kanan {     0% {-o-transform:translateX(20px);     }      50%{-o-transform:translateX(-20px);     }      100%{-o-transform:translateX(20px);         z-index:200;     } }     @-webkit-keyframes kiri {     0% {-webkit-transform:translateX(-20px);         z-index:200;     }     50%{-webkit-transform:translateX(20px);     }     100%{-webkit-transform:translateX(-20px);     } }  @-moz-keyframes kiri {     0% {-moz-transform:translateX(-20px);         z-index:200;     }     50%{-moz-transform:translateX(20px);     }     100%{-moz-transform:translateX(-20px);     } } @-o-keyframes kiri {     0% {-o-transform:translateX(-20px);         z-index:200;     }     50%{-o-transform:translateX(20px);     }     100%{-o-transform:translateX(-20px);     } }\"]\n})\nexport class Viewer3DComponent {\n\n    @Input()\n    urlFile: string;\n\n    @Input()\n    extension: string;\n\n    @Input()\n    clearColor: string;\n\n    @Input()\n    initialPositionCamera: any;\n\n    @Input()\n    initialRotationCamera: any;\n\n    @Input()\n    enableTransformController: any = true;\n\n    inGenerate: boolean = false;\n\n    container: any;\n    camera: any;\n    scene: any;\n    renderer: any;\n    mouseX: number = 0;\n    mouseY: number = 0;\n    windowHalfY: any;\n    windowHalfX: any;\n    controllers: EditorControls;\n    transformControl: any;\n    center: any = new THREE.Vector3();\n\n    loading: boolean = true;\n    detailLoading: string;\n\n    ngOnChanges(changes) {\n        if (this.scene && changes.urlFile.currentValue !== changes.urlFile.previousValue.toString()) {\n            this.loading = true;\n            this.clearScene();\n            this.lights();\n            this.grid();\n            this.axisHelper();\n            this.load();\n            this.animate();\n        }\n    }\n\n    ngOnInit() {\n        console.log(ObjLoaderService);\n        console.log(MtlLoaderService);\n        console.log(FBXLoaderService);\n        console.log(TransformControls);\n        this.container = document.getElementById('viewer-3d');\n\n        this.camera = new THREE.PerspectiveCamera(45, window.innerWidth / window.innerHeight, 1, 2000);\n        this.camera.position.z = 250;\n        // scene\n        this.scene = new THREE.Scene();\n\n        this.lights();\n        this.grid();\n        this.axisHelper();\n        this.load();\n\n        this.renderer = new THREE.WebGLRenderer();\n        this.renderer.setPixelRatio(window.devicePixelRatio);\n        this.renderer.setSize(window.innerWidth, window.innerHeight);\n\n        if (this.clearColor) {\n            this.renderer.setClearColor(this.clearColor);\n        }\n\n        this.container.appendChild(this.renderer.domElement);\n\n        this.animate();\n\n        if (this.enableTransformController) {\n            this.transformControl = new TransformControls(this.camera, this.renderer.domElement);\n            this.transformControl.addEventListener('change', this.render.bind(this));\n        }\n\n        this.controllers = new EditorControls(this.container, this.camera);\n\n        window.addEventListener('resize', this.onWindowResize.bind(this), false);\n\n        window.addEventListener('keydown', (event) => {\n            switch (event.keyCode) {\n                case 81: // Q\n                    this.transformControl.setSpace(this.transformControl.space === 'local' ? 'world' : 'local');\n                    break;\n                case 17: // Ctrl\n                    this.transformControl.setTranslationSnap(100);\n                    this.transformControl.setRotationSnap(THREE.Math.degToRad(15));\n                    break;\n                case 87: // W\n                    this.transformControl.setMode('translate');\n                    break;\n                case 69: // E\n                    this.transformControl.setMode('rotate');\n                    break;\n                case 82: // R\n                    this.transformControl.setMode('scale');\n                    break;\n                case 187:\n                case 107: // +, =, num+\n                    this.transformControl.setSize(this.transformControl.size + 0.1);\n                    break;\n                case 189:\n                case 109: // -, _, num-\n                    this.transformControl.setSize(Math.max(this.transformControl.size - 0.1, 0.1));\n                    break;\n                default:\n                    break;\n            }\n        });\n\n        window.addEventListener('keyup', (event) => {\n            switch (event.keyCode) {\n                case 17: // Ctrl\n                    this.transformControl.setTranslationSnap(null);\n                    this.transformControl.setRotationSnap(null);\n                    break;\n                default:\n                    break;\n            }\n        });\n    }\n\n    load() {\n        if (!this.extension) {\n            this.extension = this.getFileExtension(this.urlFile);\n        }\n\n        if (this.extension === 'obj') {\n            this.loadObjFormatFile();\n        } else if (this.extension === 'fbx') {\n            this.loadFbxFormatFile();\n        }\n    }\n\n    lights() {\n        let ambient = new THREE.AmbientLight(0x444444);\n\n        let directionalLight = new THREE.DirectionalLight(0xffffff, 1);\n        directionalLight.position.set(1, 1, 1).normalize();\n\n        let helper = new THREE.DirectionalLightHelper(directionalLight, 5);\n\n        this.scene.add(ambient);\n        this.scene.add(helper);\n        this.scene.add(directionalLight);\n    }\n\n    axisHelper() {\n        let axisHelper = new THREE.AxisHelper(5);\n        this.scene.add(axisHelper);\n    }\n\n    grid() {\n        let lineMaterial = new THREE.LineBasicMaterial({color: 0x303030}),\n            geometry = new THREE.Geometry(),\n            floor = -75, step = 25;\n        for (let i = 0; i <= 40; i++) {\n            geometry.vertices.push(new THREE.Vector3(-500, floor, i * step - 500));\n            geometry.vertices.push(new THREE.Vector3(500, floor, i * step - 500));\n            geometry.vertices.push(new THREE.Vector3(i * step - 500, floor, -500));\n            geometry.vertices.push(new THREE.Vector3(i * step - 500, floor, 500));\n        }\n        let line = new THREE.LineSegments(geometry, lineMaterial);\n        this.scene.add(line);\n    }\n\n    loadObjFormatFile() {\n        let mtlLoader = new THREE.MTLLoader();\n\n        this.setDetailLoad('MATERIALS');\n\n        mtlLoader.load(this.urlFile.replace('.obj', '.mtl'), (materials) => {\n            this.loadObj(materials);\n        }, (progress) => {\n            console.log('progress material loader' + JSON.stringify(progress));\n        }, (error) => {\n            console.log('error material loader');\n            this.loadObj(null);\n        });\n    }\n\n    loadFbxFormatFile() {\n        this.setDetailLoad('FBX OBJECTS');\n\n        let manager = new THREE.LoadingManager();\n        manager.onProgress = function (item, loaded, total) {\n            console.log(item, loaded, total);\n        };\n\n        let loader = new THREE.FBXLoader(manager);\n        loader.load(this.urlFile, (object) => {\n            this.loading = false;\n\n            object.mixer = new THREE.AnimationMixer(object);\n            let action = object.mixer.clipAction(object.animations[0]);\n            action.play();\n            this.scene.add(object);\n\n            if (this.enableTransformController) {\n                this.transformControl.attach(object);\n                this.scene.add(this.transformControl);\n            }\n\n        }, (progress) => {\n            console.log('progress fbx loader' + JSON.stringify(progress));\n        }, (error) => {\n            this.setDetailLoad('ERROR loafing FBX file');\n            console.log('error' + error);\n        });\n    }\n\n    loadObj(materials: any) {\n        let objLoader = new THREE.OBJLoader();\n\n        if (materials) {\n            materials.preload();\n            objLoader.setMaterials(materials);\n        }\n\n        this.setDetailLoad('OBJ OBJECTS');\n\n        objLoader.load(this.urlFile, (object) => {\n            this.loading = false;\n            this.scene.add(object);\n\n            if (this.enableTransformController) {\n                this.transformControl.attach(object);\n                this.scene.add(this.transformControl);\n            }\n\n            this.cameraPositioning();\n\n        }, (progress) => {\n            console.log('progress obj loader' + JSON.stringify(progress));\n        }, (error) => {\n            this.setDetailLoad('ERROR loafing OBJ file' + error);\n            console.log('error' + error);\n        });\n    }\n\n    cameraPositioning() {\n        if (this.initialPositionCamera) {\n            this.camera.position.set(this.initialPositionCamera.x, this.initialPositionCamera.y, this.initialPositionCamera.z);\n        }\n\n        if (this.initialRotationCamera) {\n            this.camera.rotation.set(this.initialRotationCamera.x, this.initialRotationCamera.y, this.initialRotationCamera.z);\n        }\n\n        this.camera.lookAt(this.center);\n    }\n\n    private setDetailLoad(detail) {\n        this.detailLoading = detail;\n    };\n\n    animate() {\n        requestAnimationFrame(this.animate.bind(this));\n        this.render();\n    }\n\n    onWindowResize() {\n        this.windowHalfX = this.container.offsetWidth / 2;\n        this.windowHalfY = this.container.offsetHeight / 2;\n        this.camera.aspect = this.container.offsetWidth / this.container.offsetHeight;\n        this.camera.updateProjectionMatrix();\n        this.renderer.setSize(this.container.offsetWidth, this.container.offsetHeight);\n    }\n\n    render() {\n        if (this.transformControl) {\n            this.transformControl.update();\n        }\n        this.renderer.render(this.scene, this.camera);\n    }\n\n    isLoading() {\n        return this.loading;\n    }\n\n    getFileExtension(fileName: string) {\n        return fileName.split('.').pop().toLowerCase();\n    }\n\n    clearScene() {\n        this.extension = undefined;\n        this.scene.children.forEach((object) => {\n            this.scene.remove(object);\n        });\n    }\n}\n"]}