@soonspacejs/plugin-clipping-controls 2.11.11 → 2.11.13

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/README.md CHANGED
@@ -1,5 +1,5 @@
1
- # @soonspacejs/plugin-clipping-controls
2
-
3
- > Clipping controls plugin for SoonSpace.js
4
-
5
- Document: [http://www.xwbuilders.com:8800/plugin/clipping-controls.html](http://www.xwbuilders.com:8800/plugin/clipping-controls.html)
1
+ # @soonspacejs/plugin-clipping-controls
2
+
3
+ > Clipping controls plugin for SoonSpace.js
4
+
5
+ Document: [http://www.xwbuilders.com:8800/plugin/clipping-controls.html](http://www.xwbuilders.com:8800/plugin/clipping-controls.html)
package/dist/index.esm.js CHANGED
@@ -1 +1 @@
1
- import e from"soonspacejs";import{Vector3 as s,Plane as n,Box3 as i}from"three";class t{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=e.utils.getBoundingBox(this.ssp.viewport.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])));if(P)P.normal=g[r],P.constant=p;else{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,n=s.findIndex((s=>1===Math.abs(s.normal[e])));s.splice(n,1)}else this.ssp.viewport.renderer.clippingPlanes=[];this.ssp.signals.sceneChanged.dispatch()}modelClipping(e,t){const{axis:a,clipPercent:l,isForward:r=!0,openHelper:p=!0}=t,c=(new i).setFromObject(e);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_${e.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)};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[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){if(e.clippingPlanes){const n=e.clippingPlanes.findIndex((e=>1===Math.abs(e.normal[s])));e.clippingPlanes.splice(n,1)}}else e.clippingPlanes=[]};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{t as default};
1
+ import e from"soonspacejs";import{Vector3 as s,Plane as i,Box3 as n}from"three";class a{constructor(e){this.ssp=e,this.scenePlaneHelpers={x:null,y:null,z:null,"-x":null,"-y":null,"-z":null}}addPlaneHelper(e,s,i){const n=this.ssp.addPlaneHelper(Object.assign(Object.assign({},s),{opacity:.3}));this.scenePlaneHelpers[e]=n,i&&this.ssp.addObject(n,i)}sceneClipping(n){var a,l,r;const{axis:t,clipPoint:o,isForward:p=!0,openHelper:c=!0}=n,d=p?t:`-${t}`,h=p?o-1:1-o,w=`scene_clippingPlaneHelper_${d}`;if(c)if(this.scenePlaneHelpers[d])switch(d){case"x":null===(a=this.scenePlaneHelpers[d])||void 0===a||a.position.setX(h);break;case"y":null===(l=this.scenePlaneHelpers[d])||void 0===l||l.position.setY(h);break;case"z":null===(r=this.scenePlaneHelpers[d])||void 0===r||r.position.setZ(h)}else{const i=e.utils.getBoundingBox(this.ssp.viewport.scene),n=i.getSize(new s);let a=0,l=0,r="green";const o=i.getCenter(new s).clone(),p={x:0,y:0,z:0};switch(t){case"x":a=n.z,l=n.y,r="green",o.x=h,p.y=Math.PI/2;break;case"y":a=n.x,l=n.z,r="blue",o.y=h,p.x=Math.PI/2;break;case"z":a=n.x,l=n.y,o.z=h,r="red"}this.addPlaneHelper(d,{id:w,width:a,height:l,color:r,position:o,rotation:p})}else this.scenePlaneHelpers[d]&&(this.ssp.removeHelperById(w),this.scenePlaneHelpers[d]=null);const x={x:new s(-1,0,0),"-x":new s(1,0,0),y:new s(0,-1,0),"-y":new s(0,1,0),z:new s(0,0,-1),"-z":new s(0,0,1)},g=x[d][t],y=this.ssp.viewport.renderer.clippingPlanes.find((e=>e.normal[t]===g));if(y)y.constant=o;else{this.ssp.viewport.renderer.clippingPlanes.push(new i(x[d],o))}this.ssp.signals.sceneChanged.dispatch()}removeSceneClipping(e,s=!0){const i=e?[{axis:e,isForward:s}]:[{axis:"x",isForward:!0},{axis:"x",isForward:!1},{axis:"y",isForward:!0},{axis:"y",isForward:!1},{axis:"z",isForward:!0},{axis:"z",isForward:!1}];for(const{axis:e,isForward:s}of i){const i=s?-1:1,n=s?e:`-${e}`,a=this.ssp.viewport.renderer.clippingPlanes,l=a.findIndex((s=>s.normal[e]===i));a.splice(l,1);const r=`scene_clippingPlaneHelper_${n}`;this.ssp.removeHelperById(r),this.scenePlaneHelpers[n]=null}this.ssp.signals.sceneChanged.dispatch()}modelClipping(e,a){const{axis:l,clipPercent:r,isForward:t=!0,openHelper:o=!0}=a,p=t?l:`-${l}`,c=(new n).setFromObject(e);c.max.add(new s(2,2,2)),c.min.sub(new s(2,2,2));const d=c.getSize(new s),h=t?c.max[l]-r/100*d[l]+1:c.min[l]+r/100*d[l]-1,w=t?h+1:h-1,x=`model_${e.sid}_clippingPlaneHelper_${p}`,g=this.ssp.getObjectById(x);if(o)if(g)switch(l){case"x":null==g||g.position.setX(w);break;case"y":null==g||g.position.setY(w);break;case"z":null==g||g.position.setZ(w)}else{const e=c.getSize(new s);let i=0,n=0,a="green";const r=c.getCenter(new s).clone(),t={x:0,y:0,z:0};switch(l){case"x":i=e.z,n=e.y,a="green",r.x=w,t.y=Math.PI/2;break;case"y":i=e.x,n=e.z,a="blue",r.y=w,t.x=Math.PI/2;break;case"z":i=e.x,n=e.y,r.z=w,a="red"}this.addPlaneHelper(p,{id:x,width:i,height:n,color:a,position:r,rotation:t})}else g&&this.ssp.removeObjectById(x);const y={x:new s(-1,0,0),y:new s(0,-1,0),z:new s(0,0,-1),"-x":new s(1,0,0),"-y":new s(0,1,0),"-z":new s(0,0,1)},P=y[p][l];e.traverse((e=>{if(e.material){const s=e,n=e=>{e.clippingPlanes||(e.clippingPlanes=[]);const s=e.clippingPlanes.find((e=>e.normal[l]===P));if(s)s.normal=y[p],s.constant=h,t||s.negate();else{const s=new i(y[p],h);t||s.negate(),e.clippingPlanes.push(s)}};Array.isArray(s.material)?s.material.forEach((e=>n(e))):n(s.material)}})),this.ssp.signals.sceneChanged.dispatch()}removeModelClipping(e,s,i=!0){const n=e=>{if(s){if(e.clippingPlanes){const i=e.clippingPlanes.findIndex((e=>1===Math.abs(e.normal[s])));e.clippingPlanes.splice(i,1)}}else e.clippingPlanes=[]};e.traverse((e=>{if(e.material){const s=e;Array.isArray(s.material)?s.material.forEach((e=>n(e))):n(s.material)}}));const a=s?[{axis:s,isForward:i}]:[{axis:"x",isForward:!0},{axis:"x",isForward:!1},{axis:"y",isForward:!0},{axis:"y",isForward:!1},{axis:"z",isForward:!0},{axis:"z",isForward:!1}];for(const{axis:s,isForward:i}of a){const n=i?s:`-${s}`,a=`model_${e.sid}_clippingPlaneHelper_${n}`;this.ssp.removeHelperById(a)}this.ssp.signals.sceneChanged.dispatch()}}export{a 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.11.11",
4
+ "version": "2.11.13",
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": "xunwei",
15
15
  "license": "UNLICENSED",
16
- "gitHead": "bf833bb0611737efcad85f9d4a147a135cfa5e92",
16
+ "gitHead": "0ecdef9d6546f8cd0e7f8ea38e7eb84fda951e4b",
17
17
  "peerDependencies": {
18
- "soonspacejs": "2.11.11"
18
+ "soonspacejs": "2.11.13"
19
19
  }
20
20
  }
package/dist/index.d.ts DELETED
@@ -1,32 +0,0 @@
1
- import SoonSpace, { IColor, AxisType, Position, Rotation } from 'soonspacejs';
2
- import type { BaseObject3D, BaseMesh } from 'soonspacejs/types/Library';
3
- export interface SceneClippingOptions {
4
- axis: AxisType;
5
- clipPoint: number;
6
- isForward?: boolean;
7
- openHelper?: boolean;
8
- }
9
- export interface ModelClippingOptions {
10
- axis: AxisType;
11
- clipPercent: number;
12
- isForward?: boolean;
13
- openHelper?: boolean;
14
- }
15
- export interface ClippingPlaneHelperOptions {
16
- id: string;
17
- width: number;
18
- height: number;
19
- color: IColor;
20
- position: Position;
21
- rotation: Rotation;
22
- }
23
- export default class ClippingControlsPlugin {
24
- private readonly ssp;
25
- scenePlaneHelpers: Record<AxisType, BaseMesh | null>;
26
- constructor(ssp: SoonSpace);
27
- private addPlaneHelper;
28
- sceneClipping(options: SceneClippingOptions): void;
29
- removeSceneClipping(axis?: AxisType): void;
30
- modelClipping(model: BaseObject3D, options: ModelClippingOptions): void;
31
- removeModelClipping(model: BaseObject3D, axis?: AxisType): void;
32
- }