@kitware/trame-vtklocal
Advanced tools
Comparing version
@@ -1,1 +0,1 @@ | ||
(function(o,c){typeof exports=="object"&&typeof module<"u"?c(exports):typeof define=="function"&&define.amd?define(["exports"],c):(o=typeof globalThis<"u"?globalThis:o||self,c(o.trame_vtklocal={}))})(this,function(o){"use strict";const c="",l=[];function u(h){return new Promise(function(e,s){if(l.indexOf(h)===-1){l.push(h);var t=document.createElement("script");t.type="module",t.src=h,t.onload=e,t.onerror=s,document.body.appendChild(t)}else e(!1)})}class f{constructor(){this.updateInProgress=0,this.loaded=!1,this.currentMTime=1,this.stateMTimes={},this.hashesMTime={},this.pendingArrays={},this.networkFetchState=null,this.networkFetchHash=null,this.networkFetchStatus=null,this.cameraIds=new Set,this.stateCache={},this.renderWindowIds=new Set,this.renderWindowIdToInteractorId=new Map,this.renderWindowSizes={},this.offlineCanvasContainer=document.createElement("div"),this.offlineCanvasContainer.setAttribute("class","unused-canvas"),document.body.appendChild(this.offlineCanvasContainer)}async load(e){if(this.loaded)return;const s=`${e}/vtkWasmSceneManager.mjs`;await u(s);const t=await window.createVTKWasmSceneManager();t.initialize(),this.loaded=!0,this.sceneManager=t}bindNetwork(e,s,t){this.networkFetchState=e,this.networkFetchHash=s,this.networkFetchStatus=t}freeMemory(e=0){const s=this.sceneManager.getTotalBlobMemoryUsage(),t=Number(e);if(s>t){const n={};let r=this.currentMTime;for(Object.entries(this.hashesMTime).forEach(([i,a])=>{a<r&&(r=a);const d=a.toString();n[d]?n[d].push(i):n[d]=[i]});this.sceneManager.getTotalBlobMemoryUsage()>t;){const i=n[r];if(i)for(let a=0;a<i.length;a++)this.sceneManager.unRegisterBlob(i[a]),delete this.hashesMTime[i[a]];r++}}}async fetchState(e){const s=await this.networkFetchState(e);return this.patchState(s)}patchState(e){var s;if(e.length>0){const t=JSON.parse(e),{Id:n,MTime:r}=t;return this.stateMTimes[n]=r,this.renderWindowIds.has(n)&&((s=t==null?void 0:t.Interactor)!=null&&s.Id)?(this.renderWindowIdToInteractorId.set(t.Interactor.Id,n),t.CanvasSelector=this.getCanvasSelector(n),delete t.Size,this.renderWindowSizes[n]&&(t.Size=this.renderWindowSizes[n]),JSON.stringify(t)):this.renderWindowIdToInteractorId.has(n)?(t.CanvasSelector=this.getCanvasSelector(this.renderWindowIdToInteractorId.get(n)),JSON.stringify(t)):e}}async fetchHash(e){if(this.pendingArrays[e]){await this.pendingArrays[e],this.hashesMTime[e]=this.currentMTime,delete this.pendingArrays[e];return}const s=await this.networkFetchHash(e);return this.sceneManager.registerBlob(e,s),this.hashesMTime[e]=this.currentMTime,s}pushHash(e,s){return this.pendingArrays[e]=new Promise(t=>{s.arrayBuffer?s.arrayBuffer().then(n=>{this.sceneManager.registerBlob(e,new Uint8Array(n)),this.hashesMTime[e]=this.currentMTime,t()}):(this.sceneManager.registerBlob(e,s),this.hashesMTime[e]=this.currentMTime,t())}),this.pendingArrays[e]}async update(e){if(this.renderWindowIds.add(e),this.updateInProgress++,this.updateInProgress===1)try{const s=await this.networkFetchStatus(e),t=[],n=[];s.ids.forEach(([i,a])=>{(!this.stateMTimes[i]||this.stateMTimes[i]<a)&&n.push(this.fetchState(i))}),s.hashes.forEach(i=>{this.hashesMTime[i]||t.push(this.fetchHash(i)),this.hashesMTime[i]=this.currentMTime}),s.cameras.forEach(i=>Number(this.cameraIds.add(i))),s.ignore_ids.forEach(i=>this.sceneManager.unRegisterState(i)),await Promise.all(t),await Promise.all(Object.values(this.pendingArrays));const r=await Promise.all(n);for(this.currentMTime++;r.length;){const i=r.pop();i&&this.sceneManager.registerState(i)}try{this.sceneManager.updateObjectsFromStates();const[i,a]=this.renderWindowSizes[e]||[10,10];this.sceneManager.setSize(e,i,a),this.sceneManager.render(e)}catch(i){console.error("WASM update failed"),console.log(i)}}catch(s){console.error("Error in update",s)}finally{this.updateInProgress--,this.updateInProgress&&(this.updateInProgress=0,await this.update(e))}}getState(e,s=!1){const t=Number(e);return s&&this.stateCache[t]?this.stateCache[t]:(this.sceneManager.updateStateFromObject(t),this.sceneManager.getState(t))}clearStateCache(){this.stateCache={}}getStateValue(e,s=!1){const t=Array.isArray(e)?e:[e];let n=null;for(let r=0;r<t.length;r++){const i=t[r];r===0?n=this.getState(i,s):(n=n[i],n.Id&&(n=this.getState(n.Id,s)))}return n}getCanvasSelector(e){return`.vtk-wasm-${e}`}bindCanvasToDOM(e,s){const t=this.getCanvasSelector(e);let n=this.offlineCanvasContainer.querySelector(t);return n||(n=document.createElement("canvas"),n.setAttribute("class",t.substring(1)),n.setAttribute("tabindex","0")),s.appendChild(n),t}unbindCanvasToDOM(e){const s=this.getCanvasSelector(e),t=document.querySelector(s);t&&this.offlineCanvasContainer.appendChild(t)}setSize(e,s,t){this.renderWindowSizes[e]=[s,t];const n=this.getCanvasSelector(e),r=document.querySelector(n);r&&(r.width=s,r.height=t,this.sceneManager.setSize(e,s,t),this.sceneManager.render(e))}}o.VtkWASMHandler=f,Object.defineProperty(o,Symbol.toStringTag,{value:"Module"})}); | ||
(function(o,c){typeof exports=="object"&&typeof module<"u"?c(exports):typeof define=="function"&&define.amd?define(["exports"],c):(o=typeof globalThis<"u"?globalThis:o||self,c(o.trame_vtklocal={}))})(this,function(o){"use strict";const c="",l=[];function u(h){return new Promise(function(e,s){if(l.indexOf(h)===-1){l.push(h);var t=document.createElement("script");t.type="module",t.src=h,t.onload=e,t.onerror=s,document.body.appendChild(t)}else e(!1)})}class f{constructor(){this.updateInProgress=0,this.loaded=!1,this.currentMTime=1,this.stateMTimes={},this.hashesMTime={},this.pendingArrays={},this.networkFetchState=null,this.networkFetchHash=null,this.networkFetchStatus=null,this.cameraIds=new Set,this.stateCache={},this.renderWindowIds=new Set,this.renderWindowIdToInteractorId=new Map,this.renderWindowSizes={},this.offlineCanvasContainer=document.createElement("div"),this.offlineCanvasContainer.setAttribute("class","unused-canvas"),document.body.appendChild(this.offlineCanvasContainer)}async load(e){if(this.loaded)return;const s=`${e}/vtkWasmSceneManager.mjs`;await u(s);const t=await window.createVTKWasmSceneManager();t.initialize(),this.loaded=!0,this.sceneManager=t}bindNetwork(e,s,t){this.networkFetchState=e,this.networkFetchHash=s,this.networkFetchStatus=t}freeMemory(e=0){const s=this.sceneManager.getTotalBlobMemoryUsage(),t=Number(e);if(s>t){const n={};let a=this.currentMTime;for(Object.entries(this.hashesMTime).forEach(([i,r])=>{r<a&&(a=r);const d=r.toString();n[d]?n[d].push(i):n[d]=[i]});this.sceneManager.getTotalBlobMemoryUsage()>t;){const i=n[a];if(i)for(let r=0;r<i.length;r++)this.sceneManager.unRegisterBlob(i[r]),delete this.hashesMTime[i[r]];a++}}}async fetchState(e){const s=await this.networkFetchState(e);return this.patchState(s)}patchState(e){var s;if(e.length>0){const t=JSON.parse(e),{Id:n,MTime:a}=t;return this.stateMTimes[n]=a,this.renderWindowIds.has(n)&&((s=t==null?void 0:t.Interactor)!=null&&s.Id)?(this.renderWindowIdToInteractorId.set(t.Interactor.Id,n),t.CanvasSelector=this.getCanvasSelector(n),delete t.Size,this.renderWindowSizes[n]&&(t.Size=this.renderWindowSizes[n]),t.ClassName="vtkCocoaRenderWindow",JSON.stringify(t)):this.renderWindowIdToInteractorId.has(n)?(t.CanvasSelector=this.getCanvasSelector(this.renderWindowIdToInteractorId.get(n)),JSON.stringify(t)):e}}async fetchHash(e){if(this.pendingArrays[e]){await this.pendingArrays[e],this.hashesMTime[e]=this.currentMTime,delete this.pendingArrays[e];return}const s=await this.networkFetchHash(e);return this.sceneManager.registerBlob(e,s),this.hashesMTime[e]=this.currentMTime,s}pushHash(e,s){return this.pendingArrays[e]=new Promise(t=>{s.arrayBuffer?s.arrayBuffer().then(n=>{this.sceneManager.registerBlob(e,new Uint8Array(n)),this.hashesMTime[e]=this.currentMTime,t()}):(this.sceneManager.registerBlob(e,s),this.hashesMTime[e]=this.currentMTime,t())}),this.pendingArrays[e]}async update(e){if(this.renderWindowIds.add(e),this.updateInProgress++,this.updateInProgress===1)try{const s=await this.networkFetchStatus(e),t=[],n=[];s.ids.forEach(([i,r])=>{(!this.stateMTimes[i]||this.stateMTimes[i]<r)&&n.push(this.fetchState(i))}),s.hashes.forEach(i=>{this.hashesMTime[i]||t.push(this.fetchHash(i)),this.hashesMTime[i]=this.currentMTime}),s.cameras.forEach(i=>Number(this.cameraIds.add(i))),s.ignore_ids.forEach(i=>this.sceneManager.unRegisterState(i)),await Promise.all(t),await Promise.all(Object.values(this.pendingArrays));const a=await Promise.all(n);for(this.currentMTime++;a.length;){const i=a.pop();i&&this.sceneManager.registerState(i)}try{this.sceneManager.updateObjectsFromStates();const[i,r]=this.renderWindowSizes[e]||[10,10];this.sceneManager.setSize(e,i,r),this.sceneManager.render(e)}catch(i){console.error("WASM update failed"),console.log(i)}}catch(s){console.error("Error in update",s)}finally{this.updateInProgress--,this.updateInProgress&&(this.updateInProgress=0,await this.update(e))}}getState(e,s=!1){const t=Number(e);return s&&this.stateCache[t]?this.stateCache[t]:(this.sceneManager.updateStateFromObject(t),this.sceneManager.getState(t))}clearStateCache(){this.stateCache={}}getStateValue(e,s=!1){const t=Array.isArray(e)?e:[e];let n=null;for(let a=0;a<t.length;a++){const i=t[a];a===0?n=this.getState(i,s):(n=n[i],n.Id&&(n=this.getState(n.Id,s)))}return n}getCanvasSelector(e){return`.vtk-wasm-${e}`}bindCanvasToDOM(e,s){const t=this.getCanvasSelector(e);let n=this.offlineCanvasContainer.querySelector(t);return n||(n=document.createElement("canvas"),n.setAttribute("class",t.substring(1)),n.setAttribute("tabindex","0")),s.appendChild(n),t}unbindCanvasToDOM(e){const s=this.getCanvasSelector(e),t=document.querySelector(s);t&&this.offlineCanvasContainer.appendChild(t)}setSize(e,s,t){this.renderWindowSizes[e]=[s,t];const n=this.getCanvasSelector(e),a=document.querySelector(n);a&&(a.width=s,a.height=t,this.sceneManager.setSize(e,s,t),this.sceneManager.render(e))}}o.VtkWASMHandler=f,Object.defineProperty(o,Symbol.toStringTag,{value:"Module"})}); |
{ | ||
"name": "@kitware/trame-vtklocal", | ||
"version": "0.6.3", | ||
"version": "0.6.4", | ||
"license": "Apache-2.0", | ||
@@ -5,0 +5,0 @@ "main": "./dist/trame-vtklocal.umd.js", |
Sorry, the diff of this file is not supported yet
14491
0.51%