angular-stl-model-viewer
Advanced tools
Comparing version 2.0.0 to 3.0.0
@@ -1,1 +0,1 @@ | ||
{"__symbolic":"module","version":4,"metadata":{"MeshOptions":{"__symbolic":"interface"},"StlModelViewerComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":46,"character":1},"arguments":[{"changeDetection":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectionStrategy","line":47,"character":19},"member":"OnPush"},"selector":"stl-model-viewer","styles":["\n:host {\n width: 100%;\n height: 100%;\n display: block;\n}\n "],"template":""}]}],"members":{"stlModels":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":59,"character":3}}]}],"hasControls":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":60,"character":3}}]}],"camera":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":61,"character":3}}]}],"cameraTarget":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":62,"character":3}}]}],"light":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":63,"character":3}}]}],"material":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":64,"character":3}}]}],"scene":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":65,"character":3}}]}],"renderer":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":66,"character":3}}]}],"controls":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":67,"character":3}}]}],"meshOptions":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":68,"character":3}}]}],"rendered":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":70,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":79,"character":17},{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":80,"character":20},{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":81,"character":20}]}],"ngOnInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"init":[{"__symbolic":"method"}],"createMesh":[{"__symbolic":"method"}],"setSizes":[{"__symbolic":"method"}]}},"StlModelViewerModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":3,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"StlModelViewerComponent"}],"exports":[{"__symbolic":"reference","name":"StlModelViewerComponent"}],"imports":[]}]}],"members":{}}},"origins":{"MeshOptions":"./lib/angular-stl-model-viewer.component","StlModelViewerComponent":"./lib/angular-stl-model-viewer.component","StlModelViewerModule":"./lib/angular-stl-model-viewer.module"},"importAs":"angular-stl-model-viewer"} | ||
{"__symbolic":"module","version":4,"metadata":{"MeshOptions":{"__symbolic":"interface"},"StlModelViewerComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":46,"character":1},"arguments":[{"changeDetection":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectionStrategy","line":47,"character":19},"member":"OnPush"},"selector":"stl-model-viewer","styles":["\n:host {\n width: 100%\n height: 100%\n display: block\n}\n "],"template":""}]}],"members":{"stlModels":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":59,"character":3}}]}],"hasControls":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":60,"character":3}}]}],"camera":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":61,"character":3}}]}],"cameraTarget":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":62,"character":3}}]}],"light":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":63,"character":3}}]}],"material":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":64,"character":3}}]}],"scene":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":65,"character":3}}]}],"renderer":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":66,"character":3}}]}],"controls":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":67,"character":3}}]}],"meshOptions":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":68,"character":3}}]}],"rendered":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":70,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":79,"character":17},{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":80,"character":20},{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":81,"character":20}]}],"ngOnInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"createMesh":[{"__symbolic":"method"}],"setSizes":[{"__symbolic":"method"}],"init":[{"__symbolic":"method"}]}},"StlModelViewerModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":3,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"StlModelViewerComponent"}],"exports":[{"__symbolic":"reference","name":"StlModelViewerComponent"}],"imports":[]}]}],"members":{}}},"origins":{"MeshOptions":"./lib/angular-stl-model-viewer.component","StlModelViewerComponent":"./lib/angular-stl-model-viewer.component","StlModelViewerModule":"./lib/angular-stl-model-viewer.module"},"importAs":"angular-stl-model-viewer"} |
@@ -314,3 +314,3 @@ (function (global, factory) { | ||
}; | ||
function isWebGLAvailable() { | ||
var isWebGLAvailable = function () { | ||
try { | ||
@@ -323,3 +323,4 @@ var canvas = document.createElement('canvas'); | ||
} | ||
} | ||
}; | ||
var ɵ0 = isWebGLAvailable; | ||
var StlModelViewerComponent = /** @class */ (function () { | ||
@@ -400,5 +401,38 @@ function StlModelViewerComponent(cdr, eleRef, ngZone) { | ||
}); | ||
this.scene.dispose(); | ||
} | ||
}; | ||
StlModelViewerComponent.prototype.createMesh = function (path, meshOptions) { | ||
if (meshOptions === void 0) { meshOptions = {}; } | ||
return __awaiter(this, void 0, void 0, function () { | ||
var geometry, mesh, vectorOptions, options; | ||
return __generator(this, function (_a) { | ||
switch (_a.label) { | ||
case 0: return [4 /*yield*/, this.stlLoader.loadAsync(path)]; | ||
case 1: | ||
geometry = _a.sent(); | ||
mesh = new THREE.Mesh(geometry, this.material); | ||
vectorOptions = ['position', 'scale', 'up']; | ||
options = Object.assign({}, defaultMeshOptions, meshOptions); | ||
Object.getOwnPropertyNames(options).forEach(function (option) { | ||
if (vectorOptions.indexOf(option) > -1) { | ||
var vector = options[option]; | ||
var meshVectorOption = mesh[option]; | ||
meshVectorOption.set(vector.x, vector.y, vector.z); | ||
} | ||
else { | ||
mesh[option] = options[option]; | ||
} | ||
}); | ||
return [2 /*return*/, mesh]; | ||
} | ||
}); | ||
}); | ||
}; | ||
StlModelViewerComponent.prototype.setSizes = function () { | ||
var width = this.eleRef.nativeElement.offsetWidth; | ||
var height = this.eleRef.nativeElement.offsetHeight; | ||
this.camera.aspect = width / height; | ||
this.camera.updateProjectionMatrix(); | ||
this.renderer.setSize(width, height); | ||
}; | ||
StlModelViewerComponent.prototype.init = function () { | ||
@@ -441,36 +475,2 @@ return __awaiter(this, void 0, void 0, function () { | ||
}; | ||
StlModelViewerComponent.prototype.createMesh = function (path, meshOptions) { | ||
if (meshOptions === void 0) { meshOptions = {}; } | ||
return __awaiter(this, void 0, void 0, function () { | ||
var geometry, mesh, vectorOptions, options; | ||
return __generator(this, function (_a) { | ||
switch (_a.label) { | ||
case 0: return [4 /*yield*/, this.stlLoader.loadAsync(path)]; | ||
case 1: | ||
geometry = _a.sent(); | ||
mesh = new THREE.Mesh(geometry, this.material); | ||
vectorOptions = ['position', 'scale', 'up']; | ||
options = Object.assign({}, defaultMeshOptions, meshOptions); | ||
Object.getOwnPropertyNames(options).forEach(function (option) { | ||
if (vectorOptions.indexOf(option) > -1) { | ||
var vector = options[option]; | ||
var meshVectorOption = mesh[option]; | ||
meshVectorOption.set(vector.x, vector.y, vector.z); | ||
} | ||
else { | ||
mesh[option] = options[option]; | ||
} | ||
}); | ||
return [2 /*return*/, mesh]; | ||
} | ||
}); | ||
}); | ||
}; | ||
StlModelViewerComponent.prototype.setSizes = function () { | ||
var width = this.eleRef.nativeElement.offsetWidth; | ||
var height = this.eleRef.nativeElement.offsetHeight; | ||
this.camera.aspect = width / height; | ||
this.camera.updateProjectionMatrix(); | ||
this.renderer.setSize(width, height); | ||
}; | ||
return StlModelViewerComponent; | ||
@@ -483,3 +483,3 @@ }()); | ||
template: '', | ||
styles: ["\n:host {\n width: 100%;\n height: 100%;\n display: block;\n}\n "] | ||
styles: ["\n:host {\n width: 100%\n height: 100%\n display: block\n}\n "] | ||
},] } | ||
@@ -529,2 +529,3 @@ ]; | ||
exports.StlModelViewerModule = StlModelViewerModule; | ||
exports.ɵ0 = ɵ0; | ||
@@ -531,0 +532,0 @@ Object.defineProperty(exports, '__esModule', { value: true }); |
@@ -15,3 +15,3 @@ !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("three"),require("three/examples/jsm/loaders/STLLoader"),require("three/examples/jsm/controls/OrbitControls")):"function"==typeof define&&define.amd?define("angular-stl-model-viewer",["exports","@angular/core","three","three/examples/jsm/loaders/STLLoader","three/examples/jsm/controls/OrbitControls"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self)["angular-stl-model-viewer"]={},e.ng.core,e.THREE,e.STLLoader,e.OrbitControls)}(this,(function(e,t,n,r,i){"use strict"; | ||
PERFORMANCE OF THIS SOFTWARE. | ||
***************************************************************************** */function s(e,t,n,r){return new(n||(n=Promise))((function(i,s){function o(e){try{c(r.next(e))}catch(e){s(e)}}function a(e){try{c(r.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?i(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(o,a)}c((r=r.apply(e,t||[])).next())}))}function o(e,t){var n,r,i,s,o={label:0,sent:function(){if(1&i[0])throw i[1];return i[1]},trys:[],ops:[]};return s={next:a(0),throw:a(1),return:a(2)},"function"==typeof Symbol&&(s[Symbol.iterator]=function(){return this}),s;function a(s){return function(a){return function(s){if(n)throw new TypeError("Generator is already executing.");for(;o;)try{if(n=1,r&&(i=2&s[0]?r.return:s[0]?r.throw||((i=r.return)&&i.call(r),0):r.next)&&!(i=i.call(r,s[1])).done)return i;switch(r=0,i&&(s=[2&s[0],i.value]),s[0]){case 0:case 1:i=s;break;case 4:return o.label++,{value:s[1],done:!1};case 5:o.label++,r=s[1],s=[0];continue;case 7:s=o.ops.pop(),o.trys.pop();continue;default:if(!(i=o.trys,(i=i.length>0&&i[i.length-1])||6!==s[0]&&2!==s[0])){o=0;continue}if(3===s[0]&&(!i||s[1]>i[0]&&s[1]<i[3])){o.label=s[1];break}if(6===s[0]&&o.label<i[1]){o.label=i[1],i=s;break}if(i&&o.label<i[2]){o.label=i[2],o.ops.push(s);break}i[2]&&o.ops.pop(),o.trys.pop();continue}s=t.call(e,o)}catch(e){s=[6,e],r=0}finally{n=i=0}if(5&s[0])throw s[1];return{value:s[0]?s[1]:void 0,done:!0}}([s,a])}}}Object.create;Object.create;var a={castShadow:!0,position:new n.Vector3(0,0,0),receiveShadow:!0,scale:new n.Vector3(.03,.03,.03)};var c=function(){function e(e,i,s){var o=this;this.cdr=e,this.eleRef=i,this.ngZone=s,this.stlModels=[],this.hasControls=!0,this.camera=new n.PerspectiveCamera(35,window.innerWidth/window.innerHeight,1,15),this.cameraTarget=new n.Vector3(0,0,0),this.light=new n.PointLight(16777215),this.material=new n.MeshPhongMaterial({color:12895428,shininess:100,specular:1118481}),this.scene=new n.Scene,this.renderer=new n.WebGLRenderer({antialias:!0}),this.controls=null,this.meshOptions=[],this.rendered=new t.EventEmitter,this.hasWebGL=function(){try{var e=document.createElement("canvas");return!(!window.WebGLRenderingContext||!e.getContext("webgl")&&!e.getContext("experimental-webgl"))}catch(e){return!1}}(),this.meshGroup=new n.Object3D,this.isRendered=!1,this.showStlModel=!0,this.stlLoader=new r.STLLoader,this.render=function(){o.renderer.render(o.scene,o.camera)},this.onWindowResize=function(){o.setSizes(),o.render()},this.cdr.detach(),this.light.position.set(1,1,2),this.camera.position.set(3,3,3),this.scene.background=new n.Color(16777215),this.renderer.setPixelRatio(window.devicePixelRatio),this.renderer.shadowMap.enabled=!0}return e.prototype.ngOnInit=function(){var e=this;this.hasWebGL?this.ngZone.runOutsideAngular((function(){e.init()})):console.error("stl-model-viewer: Seems like your system does not support webgl.")},e.prototype.ngOnDestroy=function(){var e=this;window.removeEventListener("resize",this.onWindowResize,!1),this.meshGroup.remove(),this.renderer&&(this.renderer.renderLists.dispose(),this.renderer.dispose()),this.camera&&this.camera.remove(),this.light&&this.light.remove(),this.material&&this.material.dispose(),this.controls&&(this.controls.removeEventListener("change",this.render),this.controls.dispose()),this.scene&&(this.scene.children.forEach((function(t){e.scene.remove(t)})),this.scene.dispose())},e.prototype.init=function(){return s(this,void 0,void 0,(function(){var e,t=this;return o(this,(function(n){switch(n.label){case 0:return this.camera.add(this.light),this.scene.add(this.camera),this.hasControls&&!this.controls&&(this.controls=new i.OrbitControls(this.camera,this.renderer.domElement),this.controls.enableZoom=!0,this.controls.minDistance=1,this.controls.maxDistance=7,this.controls.addEventListener("change",this.render)),window.addEventListener("resize",this.onWindowResize,!1),e=this.stlModels.map((function(e,n){return t.createMesh(e,t.meshOptions[n])})),[4,Promise.all(e)];case 1:return n.sent().map((function(e){return t.meshGroup.add(e)})),this.scene.add(this.meshGroup),this.eleRef.nativeElement.appendChild(this.renderer.domElement),this.setSizes(),this.render(),this.ngZone.run((function(){t.isRendered=!0,t.rendered.emit(),t.cdr.detectChanges()})),[2]}}))}))},e.prototype.createMesh=function(e,t){return void 0===t&&(t={}),s(this,void 0,void 0,(function(){var r,i,s,c;return o(this,(function(o){switch(o.label){case 0:return[4,this.stlLoader.loadAsync(e)];case 1:return r=o.sent(),i=new n.Mesh(r,this.material),s=["position","scale","up"],c=Object.assign({},a,t),Object.getOwnPropertyNames(c).forEach((function(e){if(s.indexOf(e)>-1){var t=c[e];i[e].set(t.x,t.y,t.z)}else i[e]=c[e]})),[2,i]}}))}))},e.prototype.setSizes=function(){var e=this.eleRef.nativeElement.offsetWidth,t=this.eleRef.nativeElement.offsetHeight;this.camera.aspect=e/t,this.camera.updateProjectionMatrix(),this.renderer.setSize(e,t)},e}();c.decorators=[{type:t.Component,args:[{changeDetection:t.ChangeDetectionStrategy.OnPush,selector:"stl-model-viewer",template:"",styles:["\n:host {\n width: 100%;\n height: 100%;\n display: block;\n}\n "]}]}],c.ctorParameters=function(){return[{type:t.ChangeDetectorRef},{type:t.ElementRef},{type:t.NgZone}]},c.propDecorators={stlModels:[{type:t.Input}],hasControls:[{type:t.Input}],camera:[{type:t.Input}],cameraTarget:[{type:t.Input}],light:[{type:t.Input}],material:[{type:t.Input}],scene:[{type:t.Input}],renderer:[{type:t.Input}],controls:[{type:t.Input}],meshOptions:[{type:t.Input}],rendered:[{type:t.Output}]};var h=function(){};h.decorators=[{type:t.NgModule,args:[{declarations:[c],exports:[c],imports:[]}]}],e.StlModelViewerComponent=c,e.StlModelViewerModule=h,Object.defineProperty(e,"__esModule",{value:!0})})); | ||
***************************************************************************** */function s(e,t,n,r){return new(n||(n=Promise))((function(i,s){function o(e){try{c(r.next(e))}catch(e){s(e)}}function a(e){try{c(r.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?i(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(o,a)}c((r=r.apply(e,t||[])).next())}))}function o(e,t){var n,r,i,s,o={label:0,sent:function(){if(1&i[0])throw i[1];return i[1]},trys:[],ops:[]};return s={next:a(0),throw:a(1),return:a(2)},"function"==typeof Symbol&&(s[Symbol.iterator]=function(){return this}),s;function a(s){return function(a){return function(s){if(n)throw new TypeError("Generator is already executing.");for(;o;)try{if(n=1,r&&(i=2&s[0]?r.return:s[0]?r.throw||((i=r.return)&&i.call(r),0):r.next)&&!(i=i.call(r,s[1])).done)return i;switch(r=0,i&&(s=[2&s[0],i.value]),s[0]){case 0:case 1:i=s;break;case 4:return o.label++,{value:s[1],done:!1};case 5:o.label++,r=s[1],s=[0];continue;case 7:s=o.ops.pop(),o.trys.pop();continue;default:if(!(i=o.trys,(i=i.length>0&&i[i.length-1])||6!==s[0]&&2!==s[0])){o=0;continue}if(3===s[0]&&(!i||s[1]>i[0]&&s[1]<i[3])){o.label=s[1];break}if(6===s[0]&&o.label<i[1]){o.label=i[1],i=s;break}if(i&&o.label<i[2]){o.label=i[2],o.ops.push(s);break}i[2]&&o.ops.pop(),o.trys.pop();continue}s=t.call(e,o)}catch(e){s=[6,e],r=0}finally{n=i=0}if(5&s[0])throw s[1];return{value:s[0]?s[1]:void 0,done:!0}}([s,a])}}}Object.create;Object.create;var a={castShadow:!0,position:new n.Vector3(0,0,0),receiveShadow:!0,scale:new n.Vector3(.03,.03,.03)},c=function(){try{var e=document.createElement("canvas");return!(!window.WebGLRenderingContext||!e.getContext("webgl")&&!e.getContext("experimental-webgl"))}catch(e){return!1}},h=c,l=function(){function e(e,i,s){var o=this;this.cdr=e,this.eleRef=i,this.ngZone=s,this.stlModels=[],this.hasControls=!0,this.camera=new n.PerspectiveCamera(35,window.innerWidth/window.innerHeight,1,15),this.cameraTarget=new n.Vector3(0,0,0),this.light=new n.PointLight(16777215),this.material=new n.MeshPhongMaterial({color:12895428,shininess:100,specular:1118481}),this.scene=new n.Scene,this.renderer=new n.WebGLRenderer({antialias:!0}),this.controls=null,this.meshOptions=[],this.rendered=new t.EventEmitter,this.hasWebGL=c(),this.meshGroup=new n.Object3D,this.isRendered=!1,this.showStlModel=!0,this.stlLoader=new r.STLLoader,this.render=function(){o.renderer.render(o.scene,o.camera)},this.onWindowResize=function(){o.setSizes(),o.render()},this.cdr.detach(),this.light.position.set(1,1,2),this.camera.position.set(3,3,3),this.scene.background=new n.Color(16777215),this.renderer.setPixelRatio(window.devicePixelRatio),this.renderer.shadowMap.enabled=!0}return e.prototype.ngOnInit=function(){var e=this;this.hasWebGL?this.ngZone.runOutsideAngular((function(){e.init()})):console.error("stl-model-viewer: Seems like your system does not support webgl.")},e.prototype.ngOnDestroy=function(){var e=this;window.removeEventListener("resize",this.onWindowResize,!1),this.meshGroup.remove(),this.renderer&&(this.renderer.renderLists.dispose(),this.renderer.dispose()),this.camera&&this.camera.remove(),this.light&&this.light.remove(),this.material&&this.material.dispose(),this.controls&&(this.controls.removeEventListener("change",this.render),this.controls.dispose()),this.scene&&this.scene.children.forEach((function(t){e.scene.remove(t)}))},e.prototype.createMesh=function(e,t){return void 0===t&&(t={}),s(this,void 0,void 0,(function(){var r,i,s,c;return o(this,(function(o){switch(o.label){case 0:return[4,this.stlLoader.loadAsync(e)];case 1:return r=o.sent(),i=new n.Mesh(r,this.material),s=["position","scale","up"],c=Object.assign({},a,t),Object.getOwnPropertyNames(c).forEach((function(e){if(s.indexOf(e)>-1){var t=c[e];i[e].set(t.x,t.y,t.z)}else i[e]=c[e]})),[2,i]}}))}))},e.prototype.setSizes=function(){var e=this.eleRef.nativeElement.offsetWidth,t=this.eleRef.nativeElement.offsetHeight;this.camera.aspect=e/t,this.camera.updateProjectionMatrix(),this.renderer.setSize(e,t)},e.prototype.init=function(){return s(this,void 0,void 0,(function(){var e,t=this;return o(this,(function(n){switch(n.label){case 0:return this.camera.add(this.light),this.scene.add(this.camera),this.hasControls&&!this.controls&&(this.controls=new i.OrbitControls(this.camera,this.renderer.domElement),this.controls.enableZoom=!0,this.controls.minDistance=1,this.controls.maxDistance=7,this.controls.addEventListener("change",this.render)),window.addEventListener("resize",this.onWindowResize,!1),e=this.stlModels.map((function(e,n){return t.createMesh(e,t.meshOptions[n])})),[4,Promise.all(e)];case 1:return n.sent().map((function(e){return t.meshGroup.add(e)})),this.scene.add(this.meshGroup),this.eleRef.nativeElement.appendChild(this.renderer.domElement),this.setSizes(),this.render(),this.ngZone.run((function(){t.isRendered=!0,t.rendered.emit(),t.cdr.detectChanges()})),[2]}}))}))},e}();l.decorators=[{type:t.Component,args:[{changeDetection:t.ChangeDetectionStrategy.OnPush,selector:"stl-model-viewer",template:"",styles:["\n:host {\n width: 100%\n height: 100%\n display: block\n}\n "]}]}],l.ctorParameters=function(){return[{type:t.ChangeDetectorRef},{type:t.ElementRef},{type:t.NgZone}]},l.propDecorators={stlModels:[{type:t.Input}],hasControls:[{type:t.Input}],camera:[{type:t.Input}],cameraTarget:[{type:t.Input}],light:[{type:t.Input}],material:[{type:t.Input}],scene:[{type:t.Input}],renderer:[{type:t.Input}],controls:[{type:t.Input}],meshOptions:[{type:t.Input}],rendered:[{type:t.Output}]};var d=function(){};d.decorators=[{type:t.NgModule,args:[{declarations:[l],exports:[l],imports:[]}]}],e.StlModelViewerComponent=l,e.StlModelViewerModule=d,e.ɵ0=h,Object.defineProperty(e,"__esModule",{value:!0})})); | ||
//# sourceMappingURL=angular-stl-model-viewer.umd.min.js.map |
@@ -5,2 +5,2 @@ /** | ||
export * from './public-api'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci1zdGwtbW9kZWwtdmlld2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci1zdGwtbW9kZWwtdmlld2VyL3NyYy9hbmd1bGFyLXN0bC1tb2RlbC12aWV3ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci1zdGwtbW9kZWwtdmlld2VyLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItc3RsLW1vZGVsLXZpZXdlci9zcmMvIiwic291cmNlcyI6WyJhbmd1bGFyLXN0bC1tb2RlbC12aWV3ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ== |
@@ -12,3 +12,3 @@ import { __awaiter } from "tslib"; | ||
}; | ||
function isWebGLAvailable() { | ||
const isWebGLAvailable = () => { | ||
try { | ||
@@ -21,3 +21,4 @@ const canvas = document.createElement('canvas'); | ||
} | ||
} | ||
}; | ||
const ɵ0 = isWebGLAvailable; | ||
export class StlModelViewerComponent { | ||
@@ -95,5 +96,30 @@ constructor(cdr, eleRef, ngZone) { | ||
}); | ||
this.scene.dispose(); | ||
} | ||
} | ||
createMesh(path, meshOptions = {}) { | ||
return __awaiter(this, void 0, void 0, function* () { | ||
const geometry = yield this.stlLoader.loadAsync(path); | ||
const mesh = new THREE.Mesh(geometry, this.material); | ||
const vectorOptions = ['position', 'scale', 'up']; | ||
const options = Object.assign({}, defaultMeshOptions, meshOptions); | ||
Object.getOwnPropertyNames(options).forEach((option) => { | ||
if (vectorOptions.indexOf(option) > -1) { | ||
const vector = options[option]; | ||
const meshVectorOption = mesh[option]; | ||
meshVectorOption.set(vector.x, vector.y, vector.z); | ||
} | ||
else { | ||
mesh[option] = options[option]; | ||
} | ||
}); | ||
return mesh; | ||
}); | ||
} | ||
setSizes() { | ||
const width = this.eleRef.nativeElement.offsetWidth; | ||
const height = this.eleRef.nativeElement.offsetHeight; | ||
this.camera.aspect = width / height; | ||
this.camera.updateProjectionMatrix(); | ||
this.renderer.setSize(width, height); | ||
} | ||
init() { | ||
@@ -126,28 +152,2 @@ return __awaiter(this, void 0, void 0, function* () { | ||
} | ||
createMesh(path, meshOptions = {}) { | ||
return __awaiter(this, void 0, void 0, function* () { | ||
const geometry = yield this.stlLoader.loadAsync(path); | ||
const mesh = new THREE.Mesh(geometry, this.material); | ||
const vectorOptions = ['position', 'scale', 'up']; | ||
const options = Object.assign({}, defaultMeshOptions, meshOptions); | ||
Object.getOwnPropertyNames(options).forEach((option) => { | ||
if (vectorOptions.indexOf(option) > -1) { | ||
const vector = options[option]; | ||
const meshVectorOption = mesh[option]; | ||
meshVectorOption.set(vector.x, vector.y, vector.z); | ||
} | ||
else { | ||
mesh[option] = options[option]; | ||
} | ||
}); | ||
return mesh; | ||
}); | ||
} | ||
setSizes() { | ||
const width = this.eleRef.nativeElement.offsetWidth; | ||
const height = this.eleRef.nativeElement.offsetHeight; | ||
this.camera.aspect = width / height; | ||
this.camera.updateProjectionMatrix(); | ||
this.renderer.setSize(width, height); | ||
} | ||
} | ||
@@ -161,5 +161,5 @@ StlModelViewerComponent.decorators = [ | ||
:host { | ||
width: 100%; | ||
height: 100%; | ||
display: block; | ||
width: 100% | ||
height: 100% | ||
display: block | ||
} | ||
@@ -187,2 +187,3 @@ `] | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-stl-model-viewer.component.js","sourceRoot":"","sources":["../../../../projects/angular-stl-model-viewer/src/lib/angular-stl-model-viewer.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Output,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef\n} from '@angular/core'\n\nimport * as THREE from 'three'\n\nimport { STLLoader } from 'three/examples/jsm/loaders/STLLoader'\nimport { OrbitControls } from 'three/examples/jsm/controls/OrbitControls'\n\nimport { Vector3 } from 'three'\n\nexport interface MeshOptions {\n  castShadow?: boolean\n  position?: THREE.Vector3\n  receiveShadow?: boolean\n  scale?: THREE.Vector3\n  up?: THREE.Vector3\n  userData?: {[key: string]: any}\n  visible?: boolean\n}\n\nconst defaultMeshOptions = {\n  castShadow: true,\n  position: new THREE.Vector3(0, 0, 0),\n  receiveShadow: true,\n  scale: new THREE.Vector3(0.03, 0.03, 0.03)\n}\n\nfunction isWebGLAvailable() {\n  try {\n    const canvas = document.createElement('canvas')\n    return !! (window.WebGLRenderingContext && (canvas.getContext('webgl') || canvas.getContext( 'experimental-webgl')))\n  } catch (e) {\n    return false\n  }\n}\n\n@Component({\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  selector: 'stl-model-viewer',\n  styles: [`\n:host {\n  width: 100%;\n  height: 100%;\n  display: block;\n}\n  `],\n  template: ''\n})\nexport class StlModelViewerComponent implements OnInit, OnDestroy {\n  @Input() stlModels: string[] = []\n  @Input() hasControls = true\n  @Input() camera: THREE.PerspectiveCamera = new THREE.PerspectiveCamera(35, window.innerWidth / window.innerHeight, 1, 15)\n  @Input() cameraTarget: THREE.Vector3 = new THREE.Vector3( 0, 0, 0 )\n  @Input() light: THREE.Light = new THREE.PointLight( 0xffffff )\n  @Input() material: THREE.Material = new THREE.MeshPhongMaterial({ color: 0xc4c4c4, shininess: 100, specular: 0x111111 })\n  @Input() scene: THREE.Scene = new THREE.Scene()\n  @Input() renderer: THREE.WebGLRenderer = new THREE.WebGLRenderer({ antialias: true })\n  @Input() controls: any | null = null\n  @Input() meshOptions: MeshOptions[] = []\n\n  @Output() rendered = new EventEmitter<void>()\n\n  hasWebGL = isWebGLAvailable()\n  meshGroup = new THREE.Object3D()\n  isRendered = false\n  showStlModel = true\n  stlLoader = new STLLoader()\n\n  constructor(\n    private cdr: ChangeDetectorRef,\n    private eleRef: ElementRef,\n    private ngZone: NgZone\n  ) {\n    this.cdr.detach()\n    // default light position\n    this.light.position.set(1, 1, 2)\n\n    // default camera position\n    this.camera.position.set(3, 3, 3)\n\n    // default scene background\n    this.scene.background = new THREE.Color(0xffffff)\n\n    // default renderer options\n    this.renderer.setPixelRatio(window.devicePixelRatio)\n    this.renderer.shadowMap.enabled = true\n  }\n\n  ngOnInit() {\n    if (!this.hasWebGL) {\n      console.error('stl-model-viewer: Seems like your system does not support webgl.')\n      return\n    }\n\n    this.ngZone.runOutsideAngular(() => {\n      this.init()\n    })\n  }\n\n  ngOnDestroy() {\n    window.removeEventListener('resize', this.onWindowResize, false)\n\n    this.meshGroup.remove()\n\n    if (this.renderer) {\n      this.renderer.renderLists.dispose()\n      this.renderer.dispose()\n    }\n\n    if (this.camera) {\n      this.camera.remove()\n    }\n\n    if (this.light) {\n      this.light.remove()\n    }\n\n    if (this.material) {\n      this.material.dispose()\n    }\n\n    if (this.controls) {\n      this.controls.removeEventListener('change', this.render)\n      this.controls.dispose()\n    }\n\n    if (this.scene) {\n      this.scene.children.forEach((child) => {\n        this.scene.remove(child)\n      })\n      this.scene.dispose()\n    }\n  }\n\n  private async init() {\n    this.camera.add(this.light)\n    this.scene.add(this.camera)\n\n    // use default controls\n    if (this.hasControls && !this.controls) {\n      this.controls = new OrbitControls(this.camera, this.renderer.domElement)\n      this.controls.enableZoom = true\n      this.controls.minDistance = 1\n      this.controls.maxDistance = 7\n\n      this.controls.addEventListener('change', this.render)\n    }\n\n    window.addEventListener('resize', this.onWindowResize, false)\n\n    const meshCreations = this.stlModels.map((modelPath, index) => this.createMesh(modelPath, this.meshOptions[index]))\n    const meshes: THREE.Object3D[] = await Promise.all(meshCreations)\n\n    meshes.map((mesh) => this.meshGroup.add(mesh))\n    this.scene.add(this.meshGroup)\n    this.eleRef.nativeElement.appendChild(this.renderer.domElement)\n    this.setSizes()\n    this.render()\n    this.ngZone.run(() => {\n      this.isRendered = true\n      this.rendered.emit()\n      this.cdr.detectChanges()\n    })\n  }\n\n  async createMesh(path: string, meshOptions: MeshOptions = {}): Promise<THREE.Mesh> {\n    const geometry: THREE.BufferGeometry = await this.stlLoader.loadAsync(path)\n    const mesh = new THREE.Mesh(geometry, this.material)\n\n    const vectorOptions = ['position', 'scale', 'up']\n    const options = Object.assign({}, defaultMeshOptions, meshOptions)\n\n    Object.getOwnPropertyNames(options).forEach((option) => {\n      if (vectorOptions.indexOf(option) > -1) {\n        const vector = options[option] as Vector3\n        const meshVectorOption = mesh[option] as Vector3\n        meshVectorOption.set(vector.x, vector.y, vector.z)\n      } else {\n        mesh[option] = options[option]\n      }\n    })\n\n    return mesh\n  }\n\n  render = () => {\n    this.renderer.render(this.scene, this.camera)\n  }\n\n  setSizes() {\n    const width = this.eleRef.nativeElement.offsetWidth\n    const height = this.eleRef.nativeElement.offsetHeight\n\n    this.camera.aspect = width / height\n    this.camera.updateProjectionMatrix()\n\n    this.renderer.setSize(width, height)\n  }\n\n  onWindowResize = () => {\n    this.setSizes()\n    this.render()\n  }\n}\n"]} | ||
export { ɵ0 }; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-stl-model-viewer.component.js","sourceRoot":"../../../projects/angular-stl-model-viewer/src/","sources":["lib/angular-stl-model-viewer.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Output,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef\n} from '@angular/core'\n\nimport * as THREE from 'three'\n\nimport { STLLoader } from 'three/examples/jsm/loaders/STLLoader'\nimport { OrbitControls } from 'three/examples/jsm/controls/OrbitControls'\n\nimport { Vector3 } from 'three'\n\nexport interface MeshOptions {\n  castShadow?: boolean\n  position?: THREE.Vector3\n  receiveShadow?: boolean\n  scale?: THREE.Vector3\n  up?: THREE.Vector3\n  userData?: {[key: string]: any}\n  visible?: boolean\n}\n\nconst defaultMeshOptions = {\n  castShadow: true,\n  position: new THREE.Vector3(0, 0, 0),\n  receiveShadow: true,\n  scale: new THREE.Vector3(0.03, 0.03, 0.03)\n}\n\nconst isWebGLAvailable = () => {\n  try {\n    const canvas = document.createElement('canvas')\n    return !! (window.WebGLRenderingContext && (canvas.getContext('webgl') || canvas.getContext( 'experimental-webgl')))\n  } catch (e) {\n    return false\n  }\n}\n\n@Component({\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  selector: 'stl-model-viewer',\n  styles: [`\n:host {\n  width: 100%\n  height: 100%\n  display: block\n}\n  `],\n  template: ''\n})\nexport class StlModelViewerComponent implements OnInit, OnDestroy {\n  @Input() stlModels: string[] = []\n  @Input() hasControls = true\n  @Input() camera: THREE.PerspectiveCamera = new THREE.PerspectiveCamera(35, window.innerWidth / window.innerHeight, 1, 15)\n  @Input() cameraTarget: THREE.Vector3 = new THREE.Vector3( 0, 0, 0 )\n  @Input() light: THREE.Light = new THREE.PointLight( 0xffffff )\n  @Input() material: THREE.Material = new THREE.MeshPhongMaterial({ color: 0xc4c4c4, shininess: 100, specular: 0x111111 })\n  @Input() scene: THREE.Scene = new THREE.Scene()\n  @Input() renderer: THREE.WebGLRenderer = new THREE.WebGLRenderer({ antialias: true })\n  @Input() controls: any | null = null\n  @Input() meshOptions: MeshOptions[] = []\n\n  @Output() rendered = new EventEmitter<void>()\n\n  hasWebGL = isWebGLAvailable()\n  meshGroup = new THREE.Object3D()\n  isRendered = false\n  showStlModel = true\n  stlLoader = new STLLoader()\n\n  constructor(\n    private cdr: ChangeDetectorRef,\n    private eleRef: ElementRef,\n    private ngZone: NgZone\n  ) {\n    this.cdr.detach()\n    // default light position\n    this.light.position.set(1, 1, 2)\n\n    // default camera position\n    this.camera.position.set(3, 3, 3)\n\n    // default scene background\n    this.scene.background = new THREE.Color(0xffffff)\n\n    // default renderer options\n    this.renderer.setPixelRatio(window.devicePixelRatio)\n    this.renderer.shadowMap.enabled = true\n  }\n\n  ngOnInit() {\n    if (!this.hasWebGL) {\n      console.error('stl-model-viewer: Seems like your system does not support webgl.')\n      return\n    }\n\n    this.ngZone.runOutsideAngular(() => {\n      this.init()\n    })\n  }\n\n  ngOnDestroy() {\n    window.removeEventListener('resize', this.onWindowResize, false)\n\n    this.meshGroup.remove()\n\n    if (this.renderer) {\n      this.renderer.renderLists.dispose()\n      this.renderer.dispose()\n    }\n\n    if (this.camera) {\n      this.camera.remove()\n    }\n\n    if (this.light) {\n      this.light.remove()\n    }\n\n    if (this.material) {\n      this.material.dispose()\n    }\n\n    if (this.controls) {\n      this.controls.removeEventListener('change', this.render)\n      this.controls.dispose()\n    }\n\n    if (this.scene) {\n      this.scene.children.forEach((child) => {\n        this.scene.remove(child)\n      })\n    }\n  }\n\n  async createMesh(path: string, meshOptions: MeshOptions = {}): Promise<THREE.Mesh> {\n    const geometry: THREE.BufferGeometry = await this.stlLoader.loadAsync(path)\n    const mesh = new THREE.Mesh(geometry, this.material)\n\n    const vectorOptions = ['position', 'scale', 'up']\n    const options = Object.assign({}, defaultMeshOptions, meshOptions)\n\n    Object.getOwnPropertyNames(options).forEach((option) => {\n      if (vectorOptions.indexOf(option) > -1) {\n        const vector = options[option] as Vector3\n        const meshVectorOption = mesh[option] as Vector3\n        meshVectorOption.set(vector.x, vector.y, vector.z)\n      } else {\n        mesh[option] = options[option]\n      }\n    })\n\n    return mesh\n  }\n\n  render = () => {\n    this.renderer.render(this.scene, this.camera)\n  }\n\n  setSizes() {\n    const width = this.eleRef.nativeElement.offsetWidth\n    const height = this.eleRef.nativeElement.offsetHeight\n\n    this.camera.aspect = width / height\n    this.camera.updateProjectionMatrix()\n\n    this.renderer.setSize(width, height)\n  }\n\n  onWindowResize = () => {\n    this.setSizes()\n    this.render()\n  }\n\n  private async init() {\n    this.camera.add(this.light)\n    this.scene.add(this.camera)\n\n    // use default controls\n    if (this.hasControls && !this.controls) {\n      this.controls = new OrbitControls(this.camera, this.renderer.domElement)\n      this.controls.enableZoom = true\n      this.controls.minDistance = 1\n      this.controls.maxDistance = 7\n\n      this.controls.addEventListener('change', this.render)\n    }\n\n    window.addEventListener('resize', this.onWindowResize, false)\n\n    const meshCreations = this.stlModels.map((modelPath, index) => this.createMesh(modelPath, this.meshOptions[index]))\n    const meshes: THREE.Object3D[] = await Promise.all(meshCreations)\n\n    meshes.map((mesh) => this.meshGroup.add(mesh))\n    this.scene.add(this.meshGroup)\n    this.eleRef.nativeElement.appendChild(this.renderer.domElement)\n    this.setSizes()\n    this.render()\n    this.ngZone.run(() => {\n      this.isRendered = true\n      this.rendered.emit()\n      this.cdr.detectChanges()\n    })\n  }\n}\n"]} |
@@ -12,2 +12,2 @@ import { NgModule } from '@angular/core'; | ||
]; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci1zdGwtbW9kZWwtdmlld2VyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItc3RsLW1vZGVsLXZpZXdlci9zcmMvbGliL2FuZ3VsYXItc3RsLW1vZGVsLXZpZXdlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUN4QyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQTtBQVE5RSxNQUFNLE9BQU8sb0JBQW9COzs7WUFOaEMsUUFBUSxTQUFDO2dCQUNSLFlBQVksRUFBRSxDQUFDLHVCQUF1QixDQUFDO2dCQUN2QyxPQUFPLEVBQUUsQ0FBQyx1QkFBdUIsQ0FBQztnQkFDbEMsT0FBTyxFQUFFLEVBQ1I7YUFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcbmltcG9ydCB7IFN0bE1vZGVsVmlld2VyQ29tcG9uZW50IH0gZnJvbSAnLi9hbmd1bGFyLXN0bC1tb2RlbC12aWV3ZXIuY29tcG9uZW50J1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtTdGxNb2RlbFZpZXdlckNvbXBvbmVudF0sXG4gIGV4cG9ydHM6IFtTdGxNb2RlbFZpZXdlckNvbXBvbmVudF0sXG4gIGltcG9ydHM6IFtcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBTdGxNb2RlbFZpZXdlck1vZHVsZSB7IH1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci1zdGwtbW9kZWwtdmlld2VyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIuLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXN0bC1tb2RlbC12aWV3ZXIvc3JjLyIsInNvdXJjZXMiOlsibGliL2FuZ3VsYXItc3RsLW1vZGVsLXZpZXdlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUN4QyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQTtBQVE5RSxNQUFNLE9BQU8sb0JBQW9COzs7WUFOaEMsUUFBUSxTQUFDO2dCQUNSLFlBQVksRUFBRSxDQUFDLHVCQUF1QixDQUFDO2dCQUN2QyxPQUFPLEVBQUUsQ0FBQyx1QkFBdUIsQ0FBQztnQkFDbEMsT0FBTyxFQUFFLEVBQ1I7YUFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcbmltcG9ydCB7IFN0bE1vZGVsVmlld2VyQ29tcG9uZW50IH0gZnJvbSAnLi9hbmd1bGFyLXN0bC1tb2RlbC12aWV3ZXIuY29tcG9uZW50J1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtTdGxNb2RlbFZpZXdlckNvbXBvbmVudF0sXG4gIGV4cG9ydHM6IFtTdGxNb2RlbFZpZXdlckNvbXBvbmVudF0sXG4gIGltcG9ydHM6IFtcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBTdGxNb2RlbFZpZXdlck1vZHVsZSB7IH1cbiJdfQ== |
@@ -6,2 +6,2 @@ /* | ||
export * from './lib/angular-stl-model-viewer.module'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItc3RsLW1vZGVsLXZpZXdlci9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsMENBQTBDLENBQUE7QUFDeEQsY0FBYyx1Q0FBdUMsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgYW5ndWxhci1zdGwtbW9kZWwtdmlld2VyXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvYW5ndWxhci1zdGwtbW9kZWwtdmlld2VyLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FuZ3VsYXItc3RsLW1vZGVsLXZpZXdlci5tb2R1bGUnXG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIuLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXN0bC1tb2RlbC12aWV3ZXIvc3JjLyIsInNvdXJjZXMiOlsicHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsMENBQTBDLENBQUE7QUFDeEQsY0FBYyx1Q0FBdUMsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgYW5ndWxhci1zdGwtbW9kZWwtdmlld2VyXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvYW5ndWxhci1zdGwtbW9kZWwtdmlld2VyLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FuZ3VsYXItc3RsLW1vZGVsLXZpZXdlci5tb2R1bGUnXG4iXX0= |
@@ -13,3 +13,3 @@ import { __awaiter } from 'tslib'; | ||
}; | ||
function isWebGLAvailable() { | ||
const isWebGLAvailable = () => { | ||
try { | ||
@@ -22,3 +22,4 @@ const canvas = document.createElement('canvas'); | ||
} | ||
} | ||
}; | ||
const ɵ0 = isWebGLAvailable; | ||
class StlModelViewerComponent { | ||
@@ -96,5 +97,30 @@ constructor(cdr, eleRef, ngZone) { | ||
}); | ||
this.scene.dispose(); | ||
} | ||
} | ||
createMesh(path, meshOptions = {}) { | ||
return __awaiter(this, void 0, void 0, function* () { | ||
const geometry = yield this.stlLoader.loadAsync(path); | ||
const mesh = new Mesh(geometry, this.material); | ||
const vectorOptions = ['position', 'scale', 'up']; | ||
const options = Object.assign({}, defaultMeshOptions, meshOptions); | ||
Object.getOwnPropertyNames(options).forEach((option) => { | ||
if (vectorOptions.indexOf(option) > -1) { | ||
const vector = options[option]; | ||
const meshVectorOption = mesh[option]; | ||
meshVectorOption.set(vector.x, vector.y, vector.z); | ||
} | ||
else { | ||
mesh[option] = options[option]; | ||
} | ||
}); | ||
return mesh; | ||
}); | ||
} | ||
setSizes() { | ||
const width = this.eleRef.nativeElement.offsetWidth; | ||
const height = this.eleRef.nativeElement.offsetHeight; | ||
this.camera.aspect = width / height; | ||
this.camera.updateProjectionMatrix(); | ||
this.renderer.setSize(width, height); | ||
} | ||
init() { | ||
@@ -127,28 +153,2 @@ return __awaiter(this, void 0, void 0, function* () { | ||
} | ||
createMesh(path, meshOptions = {}) { | ||
return __awaiter(this, void 0, void 0, function* () { | ||
const geometry = yield this.stlLoader.loadAsync(path); | ||
const mesh = new Mesh(geometry, this.material); | ||
const vectorOptions = ['position', 'scale', 'up']; | ||
const options = Object.assign({}, defaultMeshOptions, meshOptions); | ||
Object.getOwnPropertyNames(options).forEach((option) => { | ||
if (vectorOptions.indexOf(option) > -1) { | ||
const vector = options[option]; | ||
const meshVectorOption = mesh[option]; | ||
meshVectorOption.set(vector.x, vector.y, vector.z); | ||
} | ||
else { | ||
mesh[option] = options[option]; | ||
} | ||
}); | ||
return mesh; | ||
}); | ||
} | ||
setSizes() { | ||
const width = this.eleRef.nativeElement.offsetWidth; | ||
const height = this.eleRef.nativeElement.offsetHeight; | ||
this.camera.aspect = width / height; | ||
this.camera.updateProjectionMatrix(); | ||
this.renderer.setSize(width, height); | ||
} | ||
} | ||
@@ -162,5 +162,5 @@ StlModelViewerComponent.decorators = [ | ||
:host { | ||
width: 100%; | ||
height: 100%; | ||
display: block; | ||
width: 100% | ||
height: 100% | ||
display: block | ||
} | ||
@@ -207,3 +207,3 @@ `] | ||
export { StlModelViewerComponent, StlModelViewerModule }; | ||
export { StlModelViewerComponent, StlModelViewerModule, ɵ0 }; | ||
//# sourceMappingURL=angular-stl-model-viewer.js.map |
@@ -38,3 +38,2 @@ import { ElementRef, EventEmitter, NgZone, OnDestroy, OnInit, ChangeDetectorRef } from '@angular/core'; | ||
ngOnDestroy(): void; | ||
private init; | ||
createMesh(path: string, meshOptions?: MeshOptions): Promise<THREE.Mesh>; | ||
@@ -44,2 +43,3 @@ render: () => void; | ||
onWindowResize: () => void; | ||
private init; | ||
} |
{ | ||
"name": "angular-stl-model-viewer", | ||
"license": "MIT", | ||
"version": "2.0.0", | ||
"version": "3.0.0", | ||
"author": "Marcus Kirsch & Bengt Weiße", | ||
@@ -6,0 +6,0 @@ "description": "Angular component for rendering a STL model", |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
1007
147779