@soonspacejs/plugin-clipping-controls 2.5.59 → 2.6.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.d.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  import SoonSpace, { IColor, AxisType, Position, Rotation } from 'soonspacejs';
2
- import { BaseObject3D, BaseMesh } from 'soonspacejs/types/Library';
2
+ import type { BaseObject3D, BaseMesh } from 'soonspacejs/types/Library';
3
3
  export interface SceneClippingOptions {
4
4
  axis: AxisType;
5
5
  clipPoint: number;
package/dist/index.esm.js CHANGED
@@ -1 +1 @@
1
- class e{constructor(e){this.ssp=e,this.scenePlaneHelpers={x:null,y:null,z:null}}addPlaneHelper(e,s,n){const i=this.ssp.addPlaneHelper(Object.assign(Object.assign({},s),{opacity:.3}));this.scenePlaneHelpers[e]=i,n&&this.ssp.addObject(i,n)}sceneClipping(e){var s,n,i;const{axis:t,clipPoint:a,isForward:l=!0,openHelper:r=!0}=e,p=l?a-1:1-a,c=`scene_clippingPlaneHelper_${t}`;if(r)if(this.scenePlaneHelpers[t])switch(t){case"x":null===(s=this.scenePlaneHelpers[t])||void 0===s||s.position.setX(p);break;case"y":null===(n=this.scenePlaneHelpers[t])||void 0===n||n.position.setY(p);break;case"z":null===(i=this.scenePlaneHelpers[t])||void 0===i||i.position.setZ(p)}else{const e=(new this.ssp.THREE.Box3).setFromObject(this.ssp.manager.store.modelManager.scene),s=e.getSize(new this.ssp.THREE.Vector3);let n=0,i=0,a="green";const l=e.getCenter(new this.ssp.THREE.Vector3).clone(),r={x:0,y:0,z:0};switch(t){case"x":n=s.z,i=s.y,a="green",l.x=p,r.y=Math.PI/2;break;case"y":n=s.x,i=s.z,a="blue",l.y=p,r.x=Math.PI/2;break;case"z":n=s.x,i=s.y,l.z=p,a="red"}this.addPlaneHelper(t,{id:c,width:n,height:i,color:a,position:l,rotation:r})}else this.scenePlaneHelpers[t]&&(this.ssp.removeHelperById(c),this.scenePlaneHelpers[t]=null);const o={x:new this.ssp.THREE.Vector3(l?-1:1,0,0),y:new this.ssp.THREE.Vector3(0,l?-1:1,0),z:new this.ssp.THREE.Vector3(0,0,l?-1:1)},h=this.ssp.viewport.renderer.clippingPlanes.find((e=>1===Math.abs(e.normal[t])));h?(h.normal=o[t],h.constant=a):this.ssp.viewport.renderer.clippingPlanes.push(new this.ssp.THREE.Plane(o[t],a)),this.ssp.signals.sceneChanged.dispatch()}removeSceneClipping(e){if(e){const s=this.ssp.viewport.renderer.clippingPlanes.findIndex((s=>1===Math.abs(s.normal[e])));this.ssp.viewport.renderer.clippingPlanes.splice(s,1)}else this.ssp.viewport.renderer.clippingPlanes=[];this.ssp.signals.sceneChanged.dispatch()}modelClipping(e,s){const{axis:n,clipPercent:i,isForward:t=!0,openHelper:a=!0}=s,l=(new this.ssp.THREE.Box3).setFromObject(e);l.max.add(new this.ssp.THREE.Vector3(2,2,2)),l.min.sub(new this.ssp.THREE.Vector3(2,2,2));const r=l.getSize(new this.ssp.THREE.Vector3),p=t?l.max[n]-i/100*r[n]+1:l.min[n]+i/100*r[n]-1,c=t?p+1:p-1,o=`model_${e.sid}_clippingPlaneHelper_${n}`,h=this.ssp.getObjectById(o);if(a)if(h)switch(n){case"x":null==h||h.position.setX(c);break;case"y":null==h||h.position.setY(c);break;case"z":null==h||h.position.setZ(c)}else{const e=l.getSize(new this.ssp.THREE.Vector3);let s=0,i=0,t="green";const a=l.getCenter(new this.ssp.THREE.Vector3).clone(),r={x:0,y:0,z:0};switch(n){case"x":s=e.z,i=e.y,t="green",a.x=c,r.y=Math.PI/2;break;case"y":s=e.x,i=e.z,t="blue",a.y=c,r.x=Math.PI/2;break;case"z":s=e.x,i=e.y,a.z=c,t="red"}this.addPlaneHelper(n,{id:o,width:s,height:i,color:t,position:a,rotation:r})}else h&&this.ssp.removeObjectById(o);const d={x:new this.ssp.THREE.Vector3(t?-1:1,0,0),y:new this.ssp.THREE.Vector3(0,t?-1:1,0),z:new this.ssp.THREE.Vector3(0,0,t?-1:1)};e.traverse((e=>{if(e.material){const s=e,i=e=>{e.clippingPlanes||(e.clippingPlanes=[]);const s=e.clippingPlanes.find((e=>1===Math.abs(e.normal[n])));if(s)s.normal=d[n],s.constant=p,t||s.negate();else{const s=new this.ssp.THREE.Plane(d[n],p);t||s.negate(),e.clippingPlanes.push(s)}};Array.isArray(s.material)?s.material.forEach((e=>i(e))):i(s.material)}})),this.ssp.signals.sceneChanged.dispatch()}removeModelClipping(e,s){const n=e=>{if(s){const n=e.clippingPlanes.findIndex((e=>1===Math.abs(e.normal[s])));e.clippingPlanes.splice(n,1)}else e.clippingPlanes=null};e.traverse((e=>{if(e.material){const s=e;Array.isArray(s.material)?s.material.forEach((e=>n(e))):n(s.material)}})),this.ssp.signals.sceneChanged.dispatch()}}export{e as default};
1
+ import{Box3 as e,Vector3 as s,Plane as n}from"three";class i{constructor(e){this.ssp=e,this.scenePlaneHelpers={x:null,y:null,z:null}}addPlaneHelper(e,s,n){const i=this.ssp.addPlaneHelper(Object.assign(Object.assign({},s),{opacity:.3}));this.scenePlaneHelpers[e]=i,n&&this.ssp.addObject(i,n)}sceneClipping(i){var t,a,l;const{axis:r,clipPoint:p,isForward:c=!0,openHelper:o=!0}=i,h=c?p-1:1-p,d=`scene_clippingPlaneHelper_${r}`;if(o)if(this.scenePlaneHelpers[r])switch(r){case"x":null===(t=this.scenePlaneHelpers[r])||void 0===t||t.position.setX(h);break;case"y":null===(a=this.scenePlaneHelpers[r])||void 0===a||a.position.setY(h);break;case"z":null===(l=this.scenePlaneHelpers[r])||void 0===l||l.position.setZ(h)}else{const n=(new e).setFromObject(this.ssp.manager.store.modelManager.scene),i=n.getSize(new s);let t=0,a=0,l="green";const p=n.getCenter(new s).clone(),c={x:0,y:0,z:0};switch(r){case"x":t=i.z,a=i.y,l="green",p.x=h,c.y=Math.PI/2;break;case"y":t=i.x,a=i.z,l="blue",p.y=h,c.x=Math.PI/2;break;case"z":t=i.x,a=i.y,p.z=h,l="red"}this.addPlaneHelper(r,{id:d,width:t,height:a,color:l,position:p,rotation:c})}else this.scenePlaneHelpers[r]&&(this.ssp.removeHelperById(d),this.scenePlaneHelpers[r]=null);const g={x:new s(c?-1:1,0,0),y:new s(0,c?-1:1,0),z:new s(0,0,c?-1:1)},P=this.ssp.viewport.renderer.clippingPlanes.find((e=>1===Math.abs(e.normal[r])));P?(P.normal=g[r],P.constant=p):this.ssp.viewport.renderer.clippingPlanes.push(new n(g[r],p)),this.ssp.signals.sceneChanged.dispatch()}removeSceneClipping(e){if(e){const s=this.ssp.viewport.renderer.clippingPlanes.findIndex((s=>1===Math.abs(s.normal[e])));this.ssp.viewport.renderer.clippingPlanes.splice(s,1)}else this.ssp.viewport.renderer.clippingPlanes=[];this.ssp.signals.sceneChanged.dispatch()}modelClipping(i,t){const{axis:a,clipPercent:l,isForward:r=!0,openHelper:p=!0}=t,c=(new e).setFromObject(i);c.max.add(new s(2,2,2)),c.min.sub(new s(2,2,2));const o=c.getSize(new s),h=r?c.max[a]-l/100*o[a]+1:c.min[a]+l/100*o[a]-1,d=r?h+1:h-1,g=`model_${i.sid}_clippingPlaneHelper_${a}`,P=this.ssp.getObjectById(g);if(p)if(P)switch(a){case"x":null==P||P.position.setX(d);break;case"y":null==P||P.position.setY(d);break;case"z":null==P||P.position.setZ(d)}else{const e=c.getSize(new s);let n=0,i=0,t="green";const l=c.getCenter(new s).clone(),r={x:0,y:0,z:0};switch(a){case"x":n=e.z,i=e.y,t="green",l.x=d,r.y=Math.PI/2;break;case"y":n=e.x,i=e.z,t="blue",l.y=d,r.x=Math.PI/2;break;case"z":n=e.x,i=e.y,l.z=d,t="red"}this.addPlaneHelper(a,{id:g,width:n,height:i,color:t,position:l,rotation:r})}else P&&this.ssp.removeObjectById(g);const m={x:new s(r?-1:1,0,0),y:new s(0,r?-1:1,0),z:new s(0,0,r?-1:1)};i.traverse((e=>{if(e.material){const s=e,i=e=>{e.clippingPlanes||(e.clippingPlanes=[]);const s=e.clippingPlanes.find((e=>1===Math.abs(e.normal[a])));if(s)s.normal=m[a],s.constant=h,r||s.negate();else{const s=new n(m[a],h);r||s.negate(),e.clippingPlanes.push(s)}};Array.isArray(s.material)?s.material.forEach((e=>i(e))):i(s.material)}})),this.ssp.signals.sceneChanged.dispatch()}removeModelClipping(e,s){const n=e=>{if(s){const n=e.clippingPlanes.findIndex((e=>1===Math.abs(e.normal[s])));e.clippingPlanes.splice(n,1)}else e.clippingPlanes=null};e.traverse((e=>{if(e.material){const s=e;Array.isArray(s.material)?s.material.forEach((e=>n(e))):n(s.material)}})),this.ssp.signals.sceneChanged.dispatch()}}export{i as default};
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@soonspacejs/plugin-clipping-controls",
3
3
  "pluginName": "ClippingControlsPlugin",
4
- "version": "2.5.59",
4
+ "version": "2.6.1",
5
5
  "description": "Clipping controls plugin for SoonSpace.js",
6
6
  "main": "dist/index.esm.js",
7
7
  "module": "dist/index.esm.js",
@@ -13,8 +13,8 @@
13
13
  ],
14
14
  "author": "xuek",
15
15
  "license": "UNLICENSED",
16
- "gitHead": "f5f6ce6c41eedf2a3ff0953895ed5c7e603516fa",
16
+ "gitHead": "7c3d5b68b469b40bce705edf9fc5b25aa23d972c",
17
17
  "peerDependencies": {
18
- "soonspacejs": "2.5.59"
18
+ "soonspacejs": "2.6.1"
19
19
  }
20
20
  }