ss-component-new 1.1.1007 → 1.2.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/OrbitControls-D1lM0xvz.cjs +1 -0
- package/dist/OrbitControls-DI8fa9gz.js +419 -0
- package/dist/STLLoader-KxFIlfhN.cjs +6 -0
- package/dist/STLLoader-memlq1bT.js +609 -0
- package/dist/{animationData-Bu38Hl4M.js → animationData-BDq02_ir.js} +14 -14
- package/dist/animationData-BRDoJBuV.cjs +1 -0
- package/dist/{array-DljC5ibo.js → array-A59WrroX.js} +1 -1
- package/dist/{array-BPHS7JFA.cjs → array-BtZq8qON.cjs} +1 -1
- package/dist/config.js +1 -1
- package/dist/{iconfont-pt17sMx3.js → iconfont-7cEds3Xj.js} +2 -2
- package/dist/{iconfont-t5epssvu.cjs → iconfont-CsuwJCas.cjs} +1 -1
- package/dist/{index-d6tSWKtY.cjs → index-1z9RrjZc.cjs} +1 -1
- package/dist/{index-QSIG57Cs.cjs → index-6t33eejU.cjs} +1 -1
- package/dist/{index-DqAoBcTD.cjs → index-B1ul2ExO.cjs} +1 -1
- package/dist/{index-BlbmO49N.js → index-B35e4i9n.js} +2 -2
- package/dist/{index-Da8C2puT.js → index-B9j8fCyS.js} +2 -2
- package/dist/index-BB6zZsmY.cjs +1 -0
- package/dist/{index-Cxyot1Se.js → index-BTrjEMt1.js} +4 -4
- package/dist/{index-CZ3UyOmT.cjs → index-B_k7wRBo.cjs} +1 -1
- package/dist/{index-B2lf8ui6.cjs → index-BdL8I_2i.cjs} +1 -1
- package/dist/{index-DQ4-s08u.js → index-BeTQ6ief.js} +4 -4
- package/dist/{index--7AqRoC1.js → index-BgJn4mlV.js} +4 -4
- package/dist/{index-BCeME5xm.js → index-BqCCREh3.js} +6 -6
- package/dist/{index-D3DLg4SF.js → index-BvPC1LSv.js} +18 -18
- package/dist/{index-oNErZJKp.js → index-BwjuTBrR.js} +1 -1
- package/dist/index-BxPnA2or.js +7294 -0
- package/dist/{index-CabdCJxd.js → index-C23iUpXa.js} +7 -7
- package/dist/{index-VfEaAkaq.cjs → index-C3CD2NW8.cjs} +1 -1
- package/dist/{index-DmXN3-YT.js → index-C461j30b.js} +1 -1
- package/dist/{index-B8xZFJ-x.js → index-C6Uddqal.js} +2 -2
- package/dist/{index-BtHzGwZt.js → index-CFg3-0Tk.js} +2 -2
- package/dist/{index-BstWDfX-.cjs → index-CJzA3AAO.cjs} +1 -1
- package/dist/{index-BRJVgxUP.cjs → index-CNJzNn6z.cjs} +1 -1
- package/dist/{index-C-KrU6Qo.cjs → index-CVl84S8B.cjs} +1 -1
- package/dist/{index-CZEK1c2_.js → index-CYp77kPp.js} +176 -176
- package/dist/{index-BCIKC9PE.js → index-C_VamYcq.js} +6 -6
- package/dist/{index-CmlXlH2b.cjs → index-CjI5pDiU.cjs} +1 -1
- package/dist/{index-efKjAh7G.cjs → index-CrWFG4Wb.cjs} +1 -1
- package/dist/{index-DIehhXd9.cjs → index-Crd4LGue.cjs} +1 -1
- package/dist/{index-feAp8_X8.cjs → index-CtG-uyjY.cjs} +1 -1
- package/dist/{index-DHy1RHXi.cjs → index-CtPy-3S1.cjs} +1 -1
- package/dist/{index-D3VTHlZh.js → index-CvEj4aiY.js} +4 -4
- package/dist/{index-DzcelPVu.cjs → index-Cx302rHQ.cjs} +1 -1
- package/dist/{index-BrsIZVyD.cjs → index-CxnH4vfV.cjs} +1 -1
- package/dist/{index-hsKO-I_N.js → index-Cz03X-rX.js} +1 -1
- package/dist/{index-DxggSUtV.cjs → index-D8S0DVkq.cjs} +1 -1
- package/dist/{index-BuBVqjpx.js → index-DH0dVg0N.js} +7 -7
- package/dist/{index-oCii55Zs.cjs → index-DIm3MBK_.cjs} +1 -1
- package/dist/{index-CnqhOUek.js → index-DNE4QDIf.js} +3 -3
- package/dist/{index-BCXz_U9h.cjs → index-DQTI3BuS.cjs} +1 -1
- package/dist/{index-De9VWWmT.cjs → index-DS3OziT5.cjs} +1 -1
- package/dist/{index-Hm2_zeiV.js → index-DVvt9_w0.js} +1 -1
- package/dist/{index-DqhAoamS.cjs → index-DmB0dlGH.cjs} +1 -1
- package/dist/index-Dn9I5-1H.cjs +1 -0
- package/dist/{index-s1sBvg7-.cjs → index-DqaA5Rvx.cjs} +1 -1
- package/dist/{index-Bu-yHmJc.cjs → index-DqquxuCt.cjs} +1 -1
- package/dist/{index-DsIUgynO.js → index-DygW4mGC.js} +6 -6
- package/dist/{index-1gIP1dMc.cjs → index-HFf3Z0Ft.cjs} +1 -1
- package/dist/{index-BvDv1IKK.cjs → index-Kg96Vvn5.cjs} +1 -1
- package/dist/{index-DaBbEkRJ.js → index-N7dEiXLQ.js} +13 -13
- package/dist/index-TXrydBPq.cjs +1 -0
- package/dist/{index-BcBpmCfF.cjs → index-XQxaEXgz.cjs} +1 -1
- package/dist/{index-BHNtRl-8.js → index-Y5i13RsM.js} +3 -3
- package/dist/{index-CrKg8KZt.js → index-YQnrEK_K.js} +1069 -1061
- package/dist/{index-Jyps1gRD.js → index-aneoZx5F.js} +24 -24
- package/dist/{index-BdY8Qg-6.cjs → index-byBdKAky.cjs} +1 -1
- package/dist/{index-DWuAa5Ws.js → index-db5CgGrA.js} +394 -394
- package/dist/{index-TwtUdAMm.js → index-dqBbhGfy.js} +6 -6
- package/dist/{index-Dw_nYMhJ.cjs → index-gjDjqhNq.cjs} +2 -2
- package/dist/{index-K1m0RQMs.js → index-nq9fleOT.js} +2 -2
- package/dist/{index-oI1HUneF.js → index-qoqka5Nb.js} +1 -1
- package/dist/{index-DZHLGAn0.js → index-wHil9Fox.js} +2 -2
- package/dist/{index-Dtk-Fgm3.js → index-wq8KZGnQ.js} +5 -5
- package/dist/{index.vue_vue_type_style_index_0_scoped_0f027c8c_lang-CPiIzB84.cjs → index.vue_vue_type_style_index_0_scoped_0f027c8c_lang-CzcK5mCc.cjs} +1 -1
- package/dist/{index.vue_vue_type_style_index_0_scoped_0f027c8c_lang-DC4zFlOQ.js → index.vue_vue_type_style_index_0_scoped_0f027c8c_lang-Dmm4yqcc.js} +2 -2
- package/dist/{index.vue_vue_type_style_index_0_scoped_92477073_lang-DMhv31o4.js → index.vue_vue_type_style_index_0_scoped_92477073_lang-B0Ivzvcp.js} +6 -6
- package/dist/{index.vue_vue_type_style_index_0_scoped_92477073_lang-DV4d1URg.cjs → index.vue_vue_type_style_index_0_scoped_92477073_lang-xm0hMPwT.cjs} +1 -1
- package/dist/index.vue_vue_type_style_index_0_scoped_bcdf4fb0_lang-CMx9TLjC.cjs +56 -0
- package/dist/index.vue_vue_type_style_index_0_scoped_bcdf4fb0_lang-Czu5g16A.js +37436 -0
- package/dist/{index.vue_vue_type_style_index_1_lang-DgDibOnl.js → index.vue_vue_type_style_index_1_lang-AXp5rRSK.js} +76 -76
- package/dist/{index.vue_vue_type_style_index_1_lang-B1fiFPmj.js → index.vue_vue_type_style_index_1_lang-BxEXAMMV.js} +5012 -5100
- package/dist/{index.vue_vue_type_style_index_1_lang-CwJCb_rE.cjs → index.vue_vue_type_style_index_1_lang-CXwGS60-.cjs} +45 -46
- package/dist/{index.vue_vue_type_style_index_1_lang-B2vK-1an.cjs → index.vue_vue_type_style_index_1_lang-j5HrYuvy.cjs} +1 -1
- package/dist/{isString-D3DhambW.js → isString-BNK38WbE.js} +1 -1
- package/dist/{isString-ChvWbctO.cjs → isString-BmAegMGI.cjs} +1 -1
- package/dist/{main-YesjKNW0.cjs → main-BgpAXuSa.cjs} +1 -1
- package/dist/{main-DjvWp72p.js → main-t7yIujwl.js} +5 -5
- package/dist/ss-component.cjs +1 -1
- package/dist/ss-component.css +1 -1
- package/dist/ss-component.js +11 -11
- package/dist/ss-component2.cjs +1 -1
- package/dist/ss-component2.js +12 -12
- package/dist/three-viewport-gizmo-BxFHxv_x.js +18587 -0
- package/dist/three-viewport-gizmo-CwaL5sMV.cjs +4195 -0
- package/dist/{threeLatheView-DfSxRY8B.cjs → threeLatheView-BzHB-t_G.cjs} +1 -1
- package/dist/{threeLatheView-Mc00lYo0.js → threeLatheView-sTBlm0tt.js} +4 -4
- package/dist/{threeModel-DgfyuwYi.js → threeModel-11Yk8w2d.js} +5 -5
- package/dist/{threeModel-B7tOOzr9.cjs → threeModel-BudPgWiX.cjs} +1 -1
- package/dist/threePreview-Cy7NY-gw.cjs +1 -0
- package/dist/threePreview-DPyqhBkJ.js +1873 -0
- package/dist/threeSceneView-Bwed326O.js +1469 -0
- package/dist/threeSceneView-DT-STxuj.cjs +5 -0
- package/dist/{threeSceneViewForCPMPIP-Dw2bZRas.js → threeSceneViewForCPMPIP-PgPPGBxu.js} +90 -91
- package/dist/{threeSceneViewForCPMPIP-fWzzwARt.cjs → threeSceneViewForCPMPIP-RRDb_tZ0.cjs} +3 -3
- package/dist/{threeViewerHost-C9qoD_Tp.cjs → threeViewerHost-Brgx-J3Q.cjs} +1 -1
- package/dist/{threeViewerHost-D6c0lK4U.js → threeViewerHost-k5I66uBW.js} +8 -8
- package/dist/useRayCaster-CLcetetd.cjs +1 -0
- package/dist/{useRayCaster-Y_Q5getG.js → useRayCaster-TCYe6KMI.js} +14 -14
- package/package.json +1 -1
- package/public/config.js +1 -1
- package/dist/OrbitControls-C0QRmW6_.js +0 -458
- package/dist/OrbitControls-Co_9huz0.cjs +0 -1
- package/dist/STLLoader-CiUjaQtA.js +0 -657
- package/dist/STLLoader-RU7KqloS.cjs +0 -6
- package/dist/animationData-BjR16KKI.cjs +0 -1
- package/dist/index-BIg5JGtJ.js +0 -3370
- package/dist/index-BgImAL2B.cjs +0 -1
- package/dist/index-BuijIgJr.cjs +0 -1
- package/dist/index-Daqeta0F.cjs +0 -1
- package/dist/index-LnraLHWy.js +0 -7214
- package/dist/index-ama5teB1.cjs +0 -1
- package/dist/index.vue_vue_type_style_index_0_scoped_bcdf4fb0_lang-CycvdKIn.js +0 -34104
- package/dist/index.vue_vue_type_style_index_0_scoped_bcdf4fb0_lang-DnbT8HgZ.cjs +0 -56
- package/dist/isUndefined-7lpU02Ef.cjs +0 -1
- package/dist/isUndefined-BqsKWawv.js +0 -84
- package/dist/three-viewport-gizmo-BV37JzRa.cjs +0 -4197
- package/dist/three-viewport-gizmo-CkQ98n-T.js +0 -26015
- package/dist/threePreview-ByUYJkts.cjs +0 -1
- package/dist/threePreview-CkZ9LLXO.js +0 -1972
- package/dist/threeSceneView-BxK4ycgs.js +0 -1472
- package/dist/threeSceneView-DK1eRng9.cjs +0 -5
- package/dist/useRayCaster-BkcK_aF1.cjs +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";const n=require("./three-viewport-gizmo-CwaL5sMV.cjs"),ye={type:"change"},B={type:"start"},ge={type:"end"},_=new n.Ray,Ee=new n.Plane,_e=Math.cos(70*n.MathUtils.DEG2RAD);class He extends n.EventDispatcher{constructor(H,Te){super(),this.object=H,this.domElement=Te,this.domElement.style.touchAction="none",this.enabled=!0,this.target=new n.Vector3,this.cursor=new n.Vector3,this.minDistance=0,this.maxDistance=1/0,this.minZoom=0,this.maxZoom=1/0,this.minTargetRadius=0,this.maxTargetRadius=1/0,this.minPolarAngle=0,this.maxPolarAngle=Math.PI,this.minAzimuthAngle=-1/0,this.maxAzimuthAngle=1/0,this.enableDamping=!1,this.dampingFactor=.05,this.enableZoom=!0,this.zoomSpeed=1,this.enableRotate=!0,this.rotateSpeed=1,this.enablePan=!0,this.panSpeed=1,this.screenSpacePanning=!0,this.keyPanSpeed=7,this.zoomToCursor=!1,this.autoRotate=!1,this.autoRotateSpeed=2,this.keys={LEFT:"ArrowLeft",UP:"ArrowUp",RIGHT:"ArrowRight",BOTTOM:"ArrowDown"},this.mouseButtons={LEFT:n.MOUSE.ROTATE,MIDDLE:n.MOUSE.DOLLY,RIGHT:n.MOUSE.PAN},this.touches={ONE:n.TOUCH.ROTATE,TWO:n.TOUCH.DOLLY_PAN},this.target0=this.target.clone(),this.position0=this.object.position.clone(),this.zoom0=this.object.zoom,this._domElementKeyEvents=null,this.getPolarAngle=function(){return r.phi},this.getAzimuthalAngle=function(){return r.theta},this.getDistance=function(){return this.object.position.distanceTo(this.target)},this.listenToKeyEvents=function(t){t.addEventListener("keydown",q),this._domElementKeyEvents=t},this.stopListenToKeyEvents=function(){this._domElementKeyEvents.removeEventListener("keydown",q),this._domElementKeyEvents=null},this.saveState=function(){e.target0.copy(e.target),e.position0.copy(e.object.position),e.zoom0=e.object.zoom},this.reset=function(){e.target.copy(e.target0),e.object.position.copy(e.position0),e.object.zoom=e.zoom0,e.object.updateProjectionMatrix(),e.dispatchEvent(ye),e.update(),c=i.NONE},this.update=function(){const t=new n.Vector3,o=new n.Quaternion().setFromUnitVectors(H.up,new n.Vector3(0,1,0)),a=o.clone().invert(),s=new n.Vector3,u=new n.Quaternion,y=new n.Vector3,d=2*Math.PI;return function(Ve=null){const fe=e.object.position;t.copy(fe).sub(e.target),t.applyQuaternion(o),r.setFromVector3(t),e.autoRotate&&c===i.NONE&&N(Pe(Ve)),e.enableDamping?(r.theta+=m.theta*e.dampingFactor,r.phi+=m.phi*e.dampingFactor):(r.theta+=m.theta,r.phi+=m.phi);let p=e.minAzimuthAngle,h=e.maxAzimuthAngle;isFinite(p)&&isFinite(h)&&(p<-Math.PI?p+=d:p>Math.PI&&(p-=d),h<-Math.PI?h+=d:h>Math.PI&&(h-=d),p<=h?r.theta=Math.max(p,Math.min(h,r.theta)):r.theta=r.theta>(p+h)/2?Math.max(p,r.theta):Math.min(h,r.theta)),r.phi=Math.max(e.minPolarAngle,Math.min(e.maxPolarAngle,r.phi)),r.makeSafe(),e.enableDamping===!0?e.target.addScaledVector(w,e.dampingFactor):e.target.add(w),e.target.sub(e.cursor),e.target.clampLength(e.minTargetRadius,e.maxTargetRadius),e.target.add(e.cursor);let C=!1;if(e.zoomToCursor&&Y||e.object.isOrthographicCamera)r.radius=W(r.radius);else{const f=r.radius;r.radius=W(r.radius*g),C=f!=r.radius}if(t.setFromSpherical(r),t.applyQuaternion(a),fe.copy(e.target).add(t),e.object.lookAt(e.target),e.enableDamping===!0?(m.theta*=1-e.dampingFactor,m.phi*=1-e.dampingFactor,w.multiplyScalar(1-e.dampingFactor)):(m.set(0,0,0),w.set(0,0,0)),e.zoomToCursor&&Y){let f=null;if(e.object.isPerspectiveCamera){const I=t.length();f=W(I*g);const V=I-f;e.object.position.addScaledVector(Q,V),e.object.updateMatrixWorld(),C=!!V}else if(e.object.isOrthographicCamera){const I=new n.Vector3(b.x,b.y,0);I.unproject(e.object);const V=e.object.zoom;e.object.zoom=Math.max(e.minZoom,Math.min(e.maxZoom,e.object.zoom/g)),e.object.updateProjectionMatrix(),C=V!==e.object.zoom;const be=new n.Vector3(b.x,b.y,0);be.unproject(e.object),e.object.position.sub(be).add(I),e.object.updateMatrixWorld(),f=t.length()}else console.warn("WARNING: OrbitControls.js encountered an unknown camera type - zoom to cursor disabled."),e.zoomToCursor=!1;f!==null&&(this.screenSpacePanning?e.target.set(0,0,-1).transformDirection(e.object.matrix).multiplyScalar(f).add(e.object.position):(_.origin.copy(e.object.position),_.direction.set(0,0,-1).transformDirection(e.object.matrix),Math.abs(e.object.up.dot(_.direction))<_e?H.lookAt(e.target):(Ee.setFromNormalAndCoplanarPoint(e.object.up,e.target),_.intersectPlane(Ee,e.target))))}else if(e.object.isOrthographicCamera){const f=e.object.zoom;e.object.zoom=Math.max(e.minZoom,Math.min(e.maxZoom,e.object.zoom/g)),f!==e.object.zoom&&(e.object.updateProjectionMatrix(),C=!0)}return g=1,Y=!1,C||s.distanceToSquared(e.object.position)>K||8*(1-u.dot(e.object.quaternion))>K||y.distanceToSquared(e.target)>K?(e.dispatchEvent(ye),s.copy(e.object.position),u.copy(e.object.quaternion),y.copy(e.target),!0):!1}}(),this.dispose=function(){e.domElement.removeEventListener("contextmenu",pe),e.domElement.removeEventListener("pointerdown",ce),e.domElement.removeEventListener("pointercancel",k),e.domElement.removeEventListener("wheel",le),e.domElement.removeEventListener("pointermove",G),e.domElement.removeEventListener("pointerup",k),e.domElement.getRootNode().removeEventListener("keydown",ue,{capture:!0}),e._domElementKeyEvents!==null&&(e._domElementKeyEvents.removeEventListener("keydown",q),e._domElementKeyEvents=null)};const e=this,i={NONE:-1,ROTATE:0,DOLLY:1,PAN:2,TOUCH_ROTATE:3,TOUCH_PAN:4,TOUCH_DOLLY_PAN:5,TOUCH_DOLLY_ROTATE:6};let c=i.NONE;const K=1e-6,r=new n.Spherical,m=new n.Spherical;let g=1;const w=new n.Vector3,E=new n.Vector2,T=new n.Vector2,j=new n.Vector2,P=new n.Vector2,O=new n.Vector2,A=new n.Vector2,L=new n.Vector2,D=new n.Vector2,M=new n.Vector2,Q=new n.Vector3,b=new n.Vector2;let Y=!1;const l=[],x={};let Z=!1;function Pe(t){return t!==null?2*Math.PI/60*e.autoRotateSpeed*t:2*Math.PI/60/60*e.autoRotateSpeed}function z(t){const o=Math.abs(t*.01);return Math.pow(.95,e.zoomSpeed*o)}function N(t){m.theta-=t}function U(t){m.phi-=t}const v=function(){const t=new n.Vector3;return function(a,s){t.setFromMatrixColumn(s,0),t.multiplyScalar(-a),w.add(t)}}(),J=function(){const t=new n.Vector3;return function(a,s){e.screenSpacePanning===!0?t.setFromMatrixColumn(s,1):(t.setFromMatrixColumn(s,0),t.crossVectors(e.object.up,t)),t.multiplyScalar(a),w.add(t)}}(),R=function(){const t=new n.Vector3;return function(a,s){const u=e.domElement;if(e.object.isPerspectiveCamera){const y=e.object.position;t.copy(y).sub(e.target);let d=t.length();d*=Math.tan(e.object.fov/2*Math.PI/180),v(2*a*d/u.clientHeight,e.object.matrix),J(2*s*d/u.clientHeight,e.object.matrix)}else e.object.isOrthographicCamera?(v(a*(e.object.right-e.object.left)/e.object.zoom/u.clientWidth,e.object.matrix),J(s*(e.object.top-e.object.bottom)/e.object.zoom/u.clientHeight,e.object.matrix)):(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - pan disabled."),e.enablePan=!1)}}();function X(t){e.object.isPerspectiveCamera||e.object.isOrthographicCamera?g/=t:(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled."),e.enableZoom=!1)}function $(t){e.object.isPerspectiveCamera||e.object.isOrthographicCamera?g*=t:(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled."),e.enableZoom=!1)}function F(t,o){if(!e.zoomToCursor)return;Y=!0;const a=e.domElement.getBoundingClientRect(),s=t-a.left,u=o-a.top,y=a.width,d=a.height;b.x=s/y*2-1,b.y=-(u/d)*2+1,Q.set(b.x,b.y,1).unproject(e.object).sub(e.object.position).normalize()}function W(t){return Math.max(e.minDistance,Math.min(e.maxDistance,t))}function ee(t){E.set(t.clientX,t.clientY)}function Oe(t){F(t.clientX,t.clientX),L.set(t.clientX,t.clientY)}function te(t){P.set(t.clientX,t.clientY)}function Me(t){T.set(t.clientX,t.clientY),j.subVectors(T,E).multiplyScalar(e.rotateSpeed);const o=e.domElement;N(2*Math.PI*j.x/o.clientHeight),U(2*Math.PI*j.y/o.clientHeight),E.copy(T),e.update()}function we(t){D.set(t.clientX,t.clientY),M.subVectors(D,L),M.y>0?X(z(M.y)):M.y<0&&$(z(M.y)),L.copy(D),e.update()}function je(t){O.set(t.clientX,t.clientY),A.subVectors(O,P).multiplyScalar(e.panSpeed),R(A.x,A.y),P.copy(O),e.update()}function Ae(t){F(t.clientX,t.clientY),t.deltaY<0?$(z(t.deltaY)):t.deltaY>0&&X(z(t.deltaY)),e.update()}function Le(t){let o=!1;switch(t.code){case e.keys.UP:t.ctrlKey||t.metaKey||t.shiftKey?U(2*Math.PI*e.rotateSpeed/e.domElement.clientHeight):R(0,e.keyPanSpeed),o=!0;break;case e.keys.BOTTOM:t.ctrlKey||t.metaKey||t.shiftKey?U(-2*Math.PI*e.rotateSpeed/e.domElement.clientHeight):R(0,-e.keyPanSpeed),o=!0;break;case e.keys.LEFT:t.ctrlKey||t.metaKey||t.shiftKey?N(2*Math.PI*e.rotateSpeed/e.domElement.clientHeight):R(e.keyPanSpeed,0),o=!0;break;case e.keys.RIGHT:t.ctrlKey||t.metaKey||t.shiftKey?N(-2*Math.PI*e.rotateSpeed/e.domElement.clientHeight):R(-e.keyPanSpeed,0),o=!0;break}o&&(t.preventDefault(),e.update())}function oe(t){if(l.length===1)E.set(t.pageX,t.pageY);else{const o=S(t),a=.5*(t.pageX+o.x),s=.5*(t.pageY+o.y);E.set(a,s)}}function ne(t){if(l.length===1)P.set(t.pageX,t.pageY);else{const o=S(t),a=.5*(t.pageX+o.x),s=.5*(t.pageY+o.y);P.set(a,s)}}function ae(t){const o=S(t),a=t.pageX-o.x,s=t.pageY-o.y,u=Math.sqrt(a*a+s*s);L.set(0,u)}function De(t){e.enableZoom&&ae(t),e.enablePan&&ne(t)}function Re(t){e.enableZoom&&ae(t),e.enableRotate&&oe(t)}function ie(t){if(l.length==1)T.set(t.pageX,t.pageY);else{const a=S(t),s=.5*(t.pageX+a.x),u=.5*(t.pageY+a.y);T.set(s,u)}j.subVectors(T,E).multiplyScalar(e.rotateSpeed);const o=e.domElement;N(2*Math.PI*j.x/o.clientHeight),U(2*Math.PI*j.y/o.clientHeight),E.copy(T)}function se(t){if(l.length===1)O.set(t.pageX,t.pageY);else{const o=S(t),a=.5*(t.pageX+o.x),s=.5*(t.pageY+o.y);O.set(a,s)}A.subVectors(O,P).multiplyScalar(e.panSpeed),R(A.x,A.y),P.copy(O)}function re(t){const o=S(t),a=t.pageX-o.x,s=t.pageY-o.y,u=Math.sqrt(a*a+s*s);D.set(0,u),M.set(0,Math.pow(D.y/L.y,e.zoomSpeed)),X(M.y),L.copy(D);const y=(t.pageX+o.x)*.5,d=(t.pageY+o.y)*.5;F(y,d)}function Se(t){e.enableZoom&&re(t),e.enablePan&&se(t)}function xe(t){e.enableZoom&&re(t),e.enableRotate&&ie(t)}function ce(t){e.enabled!==!1&&(l.length===0&&(e.domElement.setPointerCapture(t.pointerId),e.domElement.addEventListener("pointermove",G),e.domElement.addEventListener("pointerup",k)),!Ue(t)&&(Ye(t),t.pointerType==="touch"?me(t):Ne(t)))}function G(t){e.enabled!==!1&&(t.pointerType==="touch"?Ie(t):ke(t))}function k(t){switch(ze(t),l.length){case 0:e.domElement.releasePointerCapture(t.pointerId),e.domElement.removeEventListener("pointermove",G),e.domElement.removeEventListener("pointerup",k),e.dispatchEvent(ge),c=i.NONE;break;case 1:const o=l[0],a=x[o];me({pointerId:o,pageX:a.x,pageY:a.y});break}}function Ne(t){let o;switch(t.button){case 0:o=e.mouseButtons.LEFT;break;case 1:o=e.mouseButtons.MIDDLE;break;case 2:o=e.mouseButtons.RIGHT;break;default:o=-1}switch(o){case n.MOUSE.DOLLY:if(e.enableZoom===!1)return;Oe(t),c=i.DOLLY;break;case n.MOUSE.ROTATE:if(t.ctrlKey||t.metaKey||t.shiftKey){if(e.enablePan===!1)return;te(t),c=i.PAN}else{if(e.enableRotate===!1)return;ee(t),c=i.ROTATE}break;case n.MOUSE.PAN:if(t.ctrlKey||t.metaKey||t.shiftKey){if(e.enableRotate===!1)return;ee(t),c=i.ROTATE}else{if(e.enablePan===!1)return;te(t),c=i.PAN}break;default:c=i.NONE}c!==i.NONE&&e.dispatchEvent(B)}function ke(t){switch(c){case i.ROTATE:if(e.enableRotate===!1)return;Me(t);break;case i.DOLLY:if(e.enableZoom===!1)return;we(t);break;case i.PAN:if(e.enablePan===!1)return;je(t);break}}function le(t){e.enabled===!1||e.enableZoom===!1||c!==i.NONE||(t.preventDefault(),e.dispatchEvent(B),Ae(Ce(t)),e.dispatchEvent(ge))}function Ce(t){const o=t.deltaMode,a={clientX:t.clientX,clientY:t.clientY,deltaY:t.deltaY};switch(o){case 1:a.deltaY*=16;break;case 2:a.deltaY*=100;break}return t.ctrlKey&&!Z&&(a.deltaY*=10),a}function ue(t){t.key==="Control"&&(Z=!0,e.domElement.getRootNode().addEventListener("keyup",de,{passive:!0,capture:!0}))}function de(t){t.key==="Control"&&(Z=!1,e.domElement.getRootNode().removeEventListener("keyup",de,{passive:!0,capture:!0}))}function q(t){e.enabled===!1||e.enablePan===!1||Le(t)}function me(t){switch(he(t),l.length){case 1:switch(e.touches.ONE){case n.TOUCH.ROTATE:if(e.enableRotate===!1)return;oe(t),c=i.TOUCH_ROTATE;break;case n.TOUCH.PAN:if(e.enablePan===!1)return;ne(t),c=i.TOUCH_PAN;break;default:c=i.NONE}break;case 2:switch(e.touches.TWO){case n.TOUCH.DOLLY_PAN:if(e.enableZoom===!1&&e.enablePan===!1)return;De(t),c=i.TOUCH_DOLLY_PAN;break;case n.TOUCH.DOLLY_ROTATE:if(e.enableZoom===!1&&e.enableRotate===!1)return;Re(t),c=i.TOUCH_DOLLY_ROTATE;break;default:c=i.NONE}break;default:c=i.NONE}c!==i.NONE&&e.dispatchEvent(B)}function Ie(t){switch(he(t),c){case i.TOUCH_ROTATE:if(e.enableRotate===!1)return;ie(t),e.update();break;case i.TOUCH_PAN:if(e.enablePan===!1)return;se(t),e.update();break;case i.TOUCH_DOLLY_PAN:if(e.enableZoom===!1&&e.enablePan===!1)return;Se(t),e.update();break;case i.TOUCH_DOLLY_ROTATE:if(e.enableZoom===!1&&e.enableRotate===!1)return;xe(t),e.update();break;default:c=i.NONE}}function pe(t){e.enabled!==!1&&t.preventDefault()}function Ye(t){l.push(t.pointerId)}function ze(t){delete x[t.pointerId];for(let o=0;o<l.length;o++)if(l[o]==t.pointerId){l.splice(o,1);return}}function Ue(t){for(let o=0;o<l.length;o++)if(l[o]==t.pointerId)return!0;return!1}function he(t){let o=x[t.pointerId];o===void 0&&(o=new n.Vector2,x[t.pointerId]=o),o.set(t.pageX,t.pageY)}function S(t){const o=t.pointerId===l[0]?l[1]:l[0];return x[o]}e.domElement.addEventListener("contextmenu",pe),e.domElement.addEventListener("pointerdown",ce),e.domElement.addEventListener("pointercancel",k),e.domElement.addEventListener("wheel",le,{passive:!1}),e.domElement.getRootNode().addEventListener("keydown",ue,{passive:!0,capture:!0}),this.update()}}exports.OrbitControls=He;
|
|
@@ -0,0 +1,419 @@
|
|
|
1
|
+
import { aJ as Ve, V as u, M as k, aK as S, aL as Pe, Q as Te, J as m, aM as We, j as Ge, l as qe } from "./three-viewport-gizmo-BxFHxv_x.js";
|
|
2
|
+
const Oe = { type: "change" }, J = { type: "start" }, we = { type: "end" }, X = new We(), Me = new Ge(), Be = Math.cos(70 * qe.DEG2RAD);
|
|
3
|
+
class et extends Ve {
|
|
4
|
+
constructor(F, je) {
|
|
5
|
+
super(), this.object = F, this.domElement = je, this.domElement.style.touchAction = "none", this.enabled = !0, this.target = new u(), this.cursor = new u(), this.minDistance = 0, this.maxDistance = 1 / 0, this.minZoom = 0, this.maxZoom = 1 / 0, this.minTargetRadius = 0, this.maxTargetRadius = 1 / 0, this.minPolarAngle = 0, this.maxPolarAngle = Math.PI, this.minAzimuthAngle = -1 / 0, this.maxAzimuthAngle = 1 / 0, this.enableDamping = !1, this.dampingFactor = 0.05, this.enableZoom = !0, this.zoomSpeed = 1, this.enableRotate = !0, this.rotateSpeed = 1, this.enablePan = !0, this.panSpeed = 1, this.screenSpacePanning = !0, this.keyPanSpeed = 7, this.zoomToCursor = !1, this.autoRotate = !1, this.autoRotateSpeed = 2, this.keys = { LEFT: "ArrowLeft", UP: "ArrowUp", RIGHT: "ArrowRight", BOTTOM: "ArrowDown" }, this.mouseButtons = { LEFT: k.ROTATE, MIDDLE: k.DOLLY, RIGHT: k.PAN }, this.touches = { ONE: S.ROTATE, TWO: S.DOLLY_PAN }, this.target0 = this.target.clone(), this.position0 = this.object.position.clone(), this.zoom0 = this.object.zoom, this._domElementKeyEvents = null, this.getPolarAngle = function() {
|
|
6
|
+
return s.phi;
|
|
7
|
+
}, this.getAzimuthalAngle = function() {
|
|
8
|
+
return s.theta;
|
|
9
|
+
}, this.getDistance = function() {
|
|
10
|
+
return this.object.position.distanceTo(this.target);
|
|
11
|
+
}, this.listenToKeyEvents = function(t) {
|
|
12
|
+
t.addEventListener("keydown", v), this._domElementKeyEvents = t;
|
|
13
|
+
}, this.stopListenToKeyEvents = function() {
|
|
14
|
+
this._domElementKeyEvents.removeEventListener("keydown", v), this._domElementKeyEvents = null;
|
|
15
|
+
}, this.saveState = function() {
|
|
16
|
+
e.target0.copy(e.target), e.position0.copy(e.object.position), e.zoom0 = e.object.zoom;
|
|
17
|
+
}, this.reset = function() {
|
|
18
|
+
e.target.copy(e.target0), e.object.position.copy(e.position0), e.object.zoom = e.zoom0, e.object.updateProjectionMatrix(), e.dispatchEvent(Oe), e.update(), r = a.NONE;
|
|
19
|
+
}, this.update = function() {
|
|
20
|
+
const t = new u(), o = new Te().setFromUnitVectors(F.up, new u(0, 1, 0)), n = o.clone().invert(), i = new u(), l = new Te(), g = new u(), d = 2 * Math.PI;
|
|
21
|
+
return function(Fe = null) {
|
|
22
|
+
const ge = e.object.position;
|
|
23
|
+
t.copy(ge).sub(e.target), t.applyQuaternion(o), s.setFromVector3(t), e.autoRotate && r === a.NONE && C(Ae(Fe)), e.enableDamping ? (s.theta += p.theta * e.dampingFactor, s.phi += p.phi * e.dampingFactor) : (s.theta += p.theta, s.phi += p.phi);
|
|
24
|
+
let h = e.minAzimuthAngle, f = e.maxAzimuthAngle;
|
|
25
|
+
isFinite(h) && isFinite(f) && (h < -Math.PI ? h += d : h > Math.PI && (h -= d), f < -Math.PI ? f += d : f > Math.PI && (f -= d), h <= f ? s.theta = Math.max(h, Math.min(f, s.theta)) : s.theta = s.theta > (h + f) / 2 ? Math.max(h, s.theta) : Math.min(f, s.theta)), s.phi = Math.max(e.minPolarAngle, Math.min(e.maxPolarAngle, s.phi)), s.makeSafe(), e.enableDamping === !0 ? e.target.addScaledVector(j, e.dampingFactor) : e.target.add(j), e.target.sub(e.cursor), e.target.clampLength(e.minTargetRadius, e.maxTargetRadius), e.target.add(e.cursor);
|
|
26
|
+
let z = !1;
|
|
27
|
+
if (e.zoomToCursor && K || e.object.isOrthographicCamera)
|
|
28
|
+
s.radius = B(s.radius);
|
|
29
|
+
else {
|
|
30
|
+
const b = s.radius;
|
|
31
|
+
s.radius = B(s.radius * E), z = b != s.radius;
|
|
32
|
+
}
|
|
33
|
+
if (t.setFromSpherical(s), t.applyQuaternion(n), ge.copy(e.target).add(t), e.object.lookAt(e.target), e.enableDamping === !0 ? (p.theta *= 1 - e.dampingFactor, p.phi *= 1 - e.dampingFactor, j.multiplyScalar(1 - e.dampingFactor)) : (p.set(0, 0, 0), j.set(0, 0, 0)), e.zoomToCursor && K) {
|
|
34
|
+
let b = null;
|
|
35
|
+
if (e.object.isPerspectiveCamera) {
|
|
36
|
+
const _ = t.length();
|
|
37
|
+
b = B(_ * E);
|
|
38
|
+
const Z = _ - b;
|
|
39
|
+
e.object.position.addScaledVector($, Z), e.object.updateMatrixWorld(), z = !!Z;
|
|
40
|
+
} else if (e.object.isOrthographicCamera) {
|
|
41
|
+
const _ = new u(y.x, y.y, 0);
|
|
42
|
+
_.unproject(e.object);
|
|
43
|
+
const Z = e.object.zoom;
|
|
44
|
+
e.object.zoom = Math.max(e.minZoom, Math.min(e.maxZoom, e.object.zoom / E)), e.object.updateProjectionMatrix(), z = Z !== e.object.zoom;
|
|
45
|
+
const Ee = new u(y.x, y.y, 0);
|
|
46
|
+
Ee.unproject(e.object), e.object.position.sub(Ee).add(_), e.object.updateMatrixWorld(), b = t.length();
|
|
47
|
+
} else
|
|
48
|
+
console.warn("WARNING: OrbitControls.js encountered an unknown camera type - zoom to cursor disabled."), e.zoomToCursor = !1;
|
|
49
|
+
b !== null && (this.screenSpacePanning ? e.target.set(0, 0, -1).transformDirection(e.object.matrix).multiplyScalar(b).add(e.object.position) : (X.origin.copy(e.object.position), X.direction.set(0, 0, -1).transformDirection(e.object.matrix), Math.abs(e.object.up.dot(X.direction)) < Be ? F.lookAt(e.target) : (Me.setFromNormalAndCoplanarPoint(e.object.up, e.target), X.intersectPlane(Me, e.target))));
|
|
50
|
+
} else if (e.object.isOrthographicCamera) {
|
|
51
|
+
const b = e.object.zoom;
|
|
52
|
+
e.object.zoom = Math.max(e.minZoom, Math.min(e.maxZoom, e.object.zoom / E)), b !== e.object.zoom && (e.object.updateProjectionMatrix(), z = !0);
|
|
53
|
+
}
|
|
54
|
+
return E = 1, K = !1, z || i.distanceToSquared(e.object.position) > V || 8 * (1 - l.dot(e.object.quaternion)) > V || g.distanceToSquared(e.target) > V ? (e.dispatchEvent(Oe), i.copy(e.object.position), l.copy(e.object.quaternion), g.copy(e.target), !0) : !1;
|
|
55
|
+
};
|
|
56
|
+
}(), this.dispose = function() {
|
|
57
|
+
e.domElement.removeEventListener("contextmenu", be), e.domElement.removeEventListener("pointerdown", de), e.domElement.removeEventListener("pointercancel", Y), e.domElement.removeEventListener("wheel", me), e.domElement.removeEventListener("pointermove", Q), e.domElement.removeEventListener("pointerup", Y), e.domElement.getRootNode().removeEventListener("keydown", pe, { capture: !0 }), e._domElementKeyEvents !== null && (e._domElementKeyEvents.removeEventListener("keydown", v), e._domElementKeyEvents = null);
|
|
58
|
+
};
|
|
59
|
+
const e = this, a = {
|
|
60
|
+
NONE: -1,
|
|
61
|
+
ROTATE: 0,
|
|
62
|
+
DOLLY: 1,
|
|
63
|
+
PAN: 2,
|
|
64
|
+
TOUCH_ROTATE: 3,
|
|
65
|
+
TOUCH_PAN: 4,
|
|
66
|
+
TOUCH_DOLLY_PAN: 5,
|
|
67
|
+
TOUCH_DOLLY_ROTATE: 6
|
|
68
|
+
};
|
|
69
|
+
let r = a.NONE;
|
|
70
|
+
const V = 1e-6, s = new Pe(), p = new Pe();
|
|
71
|
+
let E = 1;
|
|
72
|
+
const j = new u(), P = new m(), T = new m(), A = new m(), O = new m(), w = new m(), L = new m(), D = new m(), R = new m(), M = new m(), $ = new u(), y = new m();
|
|
73
|
+
let K = !1;
|
|
74
|
+
const c = [], I = {};
|
|
75
|
+
let W = !1;
|
|
76
|
+
function Ae(t) {
|
|
77
|
+
return t !== null ? 2 * Math.PI / 60 * e.autoRotateSpeed * t : 2 * Math.PI / 60 / 60 * e.autoRotateSpeed;
|
|
78
|
+
}
|
|
79
|
+
function H(t) {
|
|
80
|
+
const o = Math.abs(t * 0.01);
|
|
81
|
+
return Math.pow(0.95, e.zoomSpeed * o);
|
|
82
|
+
}
|
|
83
|
+
function C(t) {
|
|
84
|
+
p.theta -= t;
|
|
85
|
+
}
|
|
86
|
+
function U(t) {
|
|
87
|
+
p.phi -= t;
|
|
88
|
+
}
|
|
89
|
+
const ee = function() {
|
|
90
|
+
const t = new u();
|
|
91
|
+
return function(n, i) {
|
|
92
|
+
t.setFromMatrixColumn(i, 0), t.multiplyScalar(-n), j.add(t);
|
|
93
|
+
};
|
|
94
|
+
}(), te = function() {
|
|
95
|
+
const t = new u();
|
|
96
|
+
return function(n, i) {
|
|
97
|
+
e.screenSpacePanning === !0 ? t.setFromMatrixColumn(i, 1) : (t.setFromMatrixColumn(i, 0), t.crossVectors(e.object.up, t)), t.multiplyScalar(n), j.add(t);
|
|
98
|
+
};
|
|
99
|
+
}(), x = function() {
|
|
100
|
+
const t = new u();
|
|
101
|
+
return function(n, i) {
|
|
102
|
+
const l = e.domElement;
|
|
103
|
+
if (e.object.isPerspectiveCamera) {
|
|
104
|
+
const g = e.object.position;
|
|
105
|
+
t.copy(g).sub(e.target);
|
|
106
|
+
let d = t.length();
|
|
107
|
+
d *= Math.tan(e.object.fov / 2 * Math.PI / 180), ee(2 * n * d / l.clientHeight, e.object.matrix), te(2 * i * d / l.clientHeight, e.object.matrix);
|
|
108
|
+
} else e.object.isOrthographicCamera ? (ee(n * (e.object.right - e.object.left) / e.object.zoom / l.clientWidth, e.object.matrix), te(i * (e.object.top - e.object.bottom) / e.object.zoom / l.clientHeight, e.object.matrix)) : (console.warn("WARNING: OrbitControls.js encountered an unknown camera type - pan disabled."), e.enablePan = !1);
|
|
109
|
+
};
|
|
110
|
+
}();
|
|
111
|
+
function G(t) {
|
|
112
|
+
e.object.isPerspectiveCamera || e.object.isOrthographicCamera ? E /= t : (console.warn("WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled."), e.enableZoom = !1);
|
|
113
|
+
}
|
|
114
|
+
function oe(t) {
|
|
115
|
+
e.object.isPerspectiveCamera || e.object.isOrthographicCamera ? E *= t : (console.warn("WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled."), e.enableZoom = !1);
|
|
116
|
+
}
|
|
117
|
+
function q(t, o) {
|
|
118
|
+
if (!e.zoomToCursor)
|
|
119
|
+
return;
|
|
120
|
+
K = !0;
|
|
121
|
+
const n = e.domElement.getBoundingClientRect(), i = t - n.left, l = o - n.top, g = n.width, d = n.height;
|
|
122
|
+
y.x = i / g * 2 - 1, y.y = -(l / d) * 2 + 1, $.set(y.x, y.y, 1).unproject(e.object).sub(e.object.position).normalize();
|
|
123
|
+
}
|
|
124
|
+
function B(t) {
|
|
125
|
+
return Math.max(e.minDistance, Math.min(e.maxDistance, t));
|
|
126
|
+
}
|
|
127
|
+
function ne(t) {
|
|
128
|
+
P.set(t.clientX, t.clientY);
|
|
129
|
+
}
|
|
130
|
+
function Le(t) {
|
|
131
|
+
q(t.clientX, t.clientX), D.set(t.clientX, t.clientY);
|
|
132
|
+
}
|
|
133
|
+
function ae(t) {
|
|
134
|
+
O.set(t.clientX, t.clientY);
|
|
135
|
+
}
|
|
136
|
+
function De(t) {
|
|
137
|
+
T.set(t.clientX, t.clientY), A.subVectors(T, P).multiplyScalar(e.rotateSpeed);
|
|
138
|
+
const o = e.domElement;
|
|
139
|
+
C(2 * Math.PI * A.x / o.clientHeight), U(2 * Math.PI * A.y / o.clientHeight), P.copy(T), e.update();
|
|
140
|
+
}
|
|
141
|
+
function Re(t) {
|
|
142
|
+
R.set(t.clientX, t.clientY), M.subVectors(R, D), M.y > 0 ? G(H(M.y)) : M.y < 0 && oe(H(M.y)), D.copy(R), e.update();
|
|
143
|
+
}
|
|
144
|
+
function xe(t) {
|
|
145
|
+
w.set(t.clientX, t.clientY), L.subVectors(w, O).multiplyScalar(e.panSpeed), x(L.x, L.y), O.copy(w), e.update();
|
|
146
|
+
}
|
|
147
|
+
function Ne(t) {
|
|
148
|
+
q(t.clientX, t.clientY), t.deltaY < 0 ? oe(H(t.deltaY)) : t.deltaY > 0 && G(H(t.deltaY)), e.update();
|
|
149
|
+
}
|
|
150
|
+
function ke(t) {
|
|
151
|
+
let o = !1;
|
|
152
|
+
switch (t.code) {
|
|
153
|
+
case e.keys.UP:
|
|
154
|
+
t.ctrlKey || t.metaKey || t.shiftKey ? U(2 * Math.PI * e.rotateSpeed / e.domElement.clientHeight) : x(0, e.keyPanSpeed), o = !0;
|
|
155
|
+
break;
|
|
156
|
+
case e.keys.BOTTOM:
|
|
157
|
+
t.ctrlKey || t.metaKey || t.shiftKey ? U(-2 * Math.PI * e.rotateSpeed / e.domElement.clientHeight) : x(0, -e.keyPanSpeed), o = !0;
|
|
158
|
+
break;
|
|
159
|
+
case e.keys.LEFT:
|
|
160
|
+
t.ctrlKey || t.metaKey || t.shiftKey ? C(2 * Math.PI * e.rotateSpeed / e.domElement.clientHeight) : x(e.keyPanSpeed, 0), o = !0;
|
|
161
|
+
break;
|
|
162
|
+
case e.keys.RIGHT:
|
|
163
|
+
t.ctrlKey || t.metaKey || t.shiftKey ? C(-2 * Math.PI * e.rotateSpeed / e.domElement.clientHeight) : x(-e.keyPanSpeed, 0), o = !0;
|
|
164
|
+
break;
|
|
165
|
+
}
|
|
166
|
+
o && (t.preventDefault(), e.update());
|
|
167
|
+
}
|
|
168
|
+
function ie(t) {
|
|
169
|
+
if (c.length === 1)
|
|
170
|
+
P.set(t.pageX, t.pageY);
|
|
171
|
+
else {
|
|
172
|
+
const o = N(t), n = 0.5 * (t.pageX + o.x), i = 0.5 * (t.pageY + o.y);
|
|
173
|
+
P.set(n, i);
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
function se(t) {
|
|
177
|
+
if (c.length === 1)
|
|
178
|
+
O.set(t.pageX, t.pageY);
|
|
179
|
+
else {
|
|
180
|
+
const o = N(t), n = 0.5 * (t.pageX + o.x), i = 0.5 * (t.pageY + o.y);
|
|
181
|
+
O.set(n, i);
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
function re(t) {
|
|
185
|
+
const o = N(t), n = t.pageX - o.x, i = t.pageY - o.y, l = Math.sqrt(n * n + i * i);
|
|
186
|
+
D.set(0, l);
|
|
187
|
+
}
|
|
188
|
+
function Se(t) {
|
|
189
|
+
e.enableZoom && re(t), e.enablePan && se(t);
|
|
190
|
+
}
|
|
191
|
+
function Ie(t) {
|
|
192
|
+
e.enableZoom && re(t), e.enableRotate && ie(t);
|
|
193
|
+
}
|
|
194
|
+
function ce(t) {
|
|
195
|
+
if (c.length == 1)
|
|
196
|
+
T.set(t.pageX, t.pageY);
|
|
197
|
+
else {
|
|
198
|
+
const n = N(t), i = 0.5 * (t.pageX + n.x), l = 0.5 * (t.pageY + n.y);
|
|
199
|
+
T.set(i, l);
|
|
200
|
+
}
|
|
201
|
+
A.subVectors(T, P).multiplyScalar(e.rotateSpeed);
|
|
202
|
+
const o = e.domElement;
|
|
203
|
+
C(2 * Math.PI * A.x / o.clientHeight), U(2 * Math.PI * A.y / o.clientHeight), P.copy(T);
|
|
204
|
+
}
|
|
205
|
+
function le(t) {
|
|
206
|
+
if (c.length === 1)
|
|
207
|
+
w.set(t.pageX, t.pageY);
|
|
208
|
+
else {
|
|
209
|
+
const o = N(t), n = 0.5 * (t.pageX + o.x), i = 0.5 * (t.pageY + o.y);
|
|
210
|
+
w.set(n, i);
|
|
211
|
+
}
|
|
212
|
+
L.subVectors(w, O).multiplyScalar(e.panSpeed), x(L.x, L.y), O.copy(w);
|
|
213
|
+
}
|
|
214
|
+
function ue(t) {
|
|
215
|
+
const o = N(t), n = t.pageX - o.x, i = t.pageY - o.y, l = Math.sqrt(n * n + i * i);
|
|
216
|
+
R.set(0, l), M.set(0, Math.pow(R.y / D.y, e.zoomSpeed)), G(M.y), D.copy(R);
|
|
217
|
+
const g = (t.pageX + o.x) * 0.5, d = (t.pageY + o.y) * 0.5;
|
|
218
|
+
q(g, d);
|
|
219
|
+
}
|
|
220
|
+
function Ce(t) {
|
|
221
|
+
e.enableZoom && ue(t), e.enablePan && le(t);
|
|
222
|
+
}
|
|
223
|
+
function Ye(t) {
|
|
224
|
+
e.enableZoom && ue(t), e.enableRotate && ce(t);
|
|
225
|
+
}
|
|
226
|
+
function de(t) {
|
|
227
|
+
e.enabled !== !1 && (c.length === 0 && (e.domElement.setPointerCapture(t.pointerId), e.domElement.addEventListener("pointermove", Q), e.domElement.addEventListener("pointerup", Y)), !Xe(t) && (Ue(t), t.pointerType === "touch" ? fe(t) : ze(t)));
|
|
228
|
+
}
|
|
229
|
+
function Q(t) {
|
|
230
|
+
e.enabled !== !1 && (t.pointerType === "touch" ? He(t) : _e(t));
|
|
231
|
+
}
|
|
232
|
+
function Y(t) {
|
|
233
|
+
switch (Ze(t), c.length) {
|
|
234
|
+
case 0:
|
|
235
|
+
e.domElement.releasePointerCapture(t.pointerId), e.domElement.removeEventListener("pointermove", Q), e.domElement.removeEventListener("pointerup", Y), e.dispatchEvent(we), r = a.NONE;
|
|
236
|
+
break;
|
|
237
|
+
case 1:
|
|
238
|
+
const o = c[0], n = I[o];
|
|
239
|
+
fe({ pointerId: o, pageX: n.x, pageY: n.y });
|
|
240
|
+
break;
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
function ze(t) {
|
|
244
|
+
let o;
|
|
245
|
+
switch (t.button) {
|
|
246
|
+
case 0:
|
|
247
|
+
o = e.mouseButtons.LEFT;
|
|
248
|
+
break;
|
|
249
|
+
case 1:
|
|
250
|
+
o = e.mouseButtons.MIDDLE;
|
|
251
|
+
break;
|
|
252
|
+
case 2:
|
|
253
|
+
o = e.mouseButtons.RIGHT;
|
|
254
|
+
break;
|
|
255
|
+
default:
|
|
256
|
+
o = -1;
|
|
257
|
+
}
|
|
258
|
+
switch (o) {
|
|
259
|
+
case k.DOLLY:
|
|
260
|
+
if (e.enableZoom === !1) return;
|
|
261
|
+
Le(t), r = a.DOLLY;
|
|
262
|
+
break;
|
|
263
|
+
case k.ROTATE:
|
|
264
|
+
if (t.ctrlKey || t.metaKey || t.shiftKey) {
|
|
265
|
+
if (e.enablePan === !1) return;
|
|
266
|
+
ae(t), r = a.PAN;
|
|
267
|
+
} else {
|
|
268
|
+
if (e.enableRotate === !1) return;
|
|
269
|
+
ne(t), r = a.ROTATE;
|
|
270
|
+
}
|
|
271
|
+
break;
|
|
272
|
+
case k.PAN:
|
|
273
|
+
if (t.ctrlKey || t.metaKey || t.shiftKey) {
|
|
274
|
+
if (e.enableRotate === !1) return;
|
|
275
|
+
ne(t), r = a.ROTATE;
|
|
276
|
+
} else {
|
|
277
|
+
if (e.enablePan === !1) return;
|
|
278
|
+
ae(t), r = a.PAN;
|
|
279
|
+
}
|
|
280
|
+
break;
|
|
281
|
+
default:
|
|
282
|
+
r = a.NONE;
|
|
283
|
+
}
|
|
284
|
+
r !== a.NONE && e.dispatchEvent(J);
|
|
285
|
+
}
|
|
286
|
+
function _e(t) {
|
|
287
|
+
switch (r) {
|
|
288
|
+
case a.ROTATE:
|
|
289
|
+
if (e.enableRotate === !1) return;
|
|
290
|
+
De(t);
|
|
291
|
+
break;
|
|
292
|
+
case a.DOLLY:
|
|
293
|
+
if (e.enableZoom === !1) return;
|
|
294
|
+
Re(t);
|
|
295
|
+
break;
|
|
296
|
+
case a.PAN:
|
|
297
|
+
if (e.enablePan === !1) return;
|
|
298
|
+
xe(t);
|
|
299
|
+
break;
|
|
300
|
+
}
|
|
301
|
+
}
|
|
302
|
+
function me(t) {
|
|
303
|
+
e.enabled === !1 || e.enableZoom === !1 || r !== a.NONE || (t.preventDefault(), e.dispatchEvent(J), Ne(Ke(t)), e.dispatchEvent(we));
|
|
304
|
+
}
|
|
305
|
+
function Ke(t) {
|
|
306
|
+
const o = t.deltaMode, n = {
|
|
307
|
+
clientX: t.clientX,
|
|
308
|
+
clientY: t.clientY,
|
|
309
|
+
deltaY: t.deltaY
|
|
310
|
+
};
|
|
311
|
+
switch (o) {
|
|
312
|
+
case 1:
|
|
313
|
+
n.deltaY *= 16;
|
|
314
|
+
break;
|
|
315
|
+
case 2:
|
|
316
|
+
n.deltaY *= 100;
|
|
317
|
+
break;
|
|
318
|
+
}
|
|
319
|
+
return t.ctrlKey && !W && (n.deltaY *= 10), n;
|
|
320
|
+
}
|
|
321
|
+
function pe(t) {
|
|
322
|
+
t.key === "Control" && (W = !0, e.domElement.getRootNode().addEventListener("keyup", he, { passive: !0, capture: !0 }));
|
|
323
|
+
}
|
|
324
|
+
function he(t) {
|
|
325
|
+
t.key === "Control" && (W = !1, e.domElement.getRootNode().removeEventListener("keyup", he, { passive: !0, capture: !0 }));
|
|
326
|
+
}
|
|
327
|
+
function v(t) {
|
|
328
|
+
e.enabled === !1 || e.enablePan === !1 || ke(t);
|
|
329
|
+
}
|
|
330
|
+
function fe(t) {
|
|
331
|
+
switch (ye(t), c.length) {
|
|
332
|
+
case 1:
|
|
333
|
+
switch (e.touches.ONE) {
|
|
334
|
+
case S.ROTATE:
|
|
335
|
+
if (e.enableRotate === !1) return;
|
|
336
|
+
ie(t), r = a.TOUCH_ROTATE;
|
|
337
|
+
break;
|
|
338
|
+
case S.PAN:
|
|
339
|
+
if (e.enablePan === !1) return;
|
|
340
|
+
se(t), r = a.TOUCH_PAN;
|
|
341
|
+
break;
|
|
342
|
+
default:
|
|
343
|
+
r = a.NONE;
|
|
344
|
+
}
|
|
345
|
+
break;
|
|
346
|
+
case 2:
|
|
347
|
+
switch (e.touches.TWO) {
|
|
348
|
+
case S.DOLLY_PAN:
|
|
349
|
+
if (e.enableZoom === !1 && e.enablePan === !1) return;
|
|
350
|
+
Se(t), r = a.TOUCH_DOLLY_PAN;
|
|
351
|
+
break;
|
|
352
|
+
case S.DOLLY_ROTATE:
|
|
353
|
+
if (e.enableZoom === !1 && e.enableRotate === !1) return;
|
|
354
|
+
Ie(t), r = a.TOUCH_DOLLY_ROTATE;
|
|
355
|
+
break;
|
|
356
|
+
default:
|
|
357
|
+
r = a.NONE;
|
|
358
|
+
}
|
|
359
|
+
break;
|
|
360
|
+
default:
|
|
361
|
+
r = a.NONE;
|
|
362
|
+
}
|
|
363
|
+
r !== a.NONE && e.dispatchEvent(J);
|
|
364
|
+
}
|
|
365
|
+
function He(t) {
|
|
366
|
+
switch (ye(t), r) {
|
|
367
|
+
case a.TOUCH_ROTATE:
|
|
368
|
+
if (e.enableRotate === !1) return;
|
|
369
|
+
ce(t), e.update();
|
|
370
|
+
break;
|
|
371
|
+
case a.TOUCH_PAN:
|
|
372
|
+
if (e.enablePan === !1) return;
|
|
373
|
+
le(t), e.update();
|
|
374
|
+
break;
|
|
375
|
+
case a.TOUCH_DOLLY_PAN:
|
|
376
|
+
if (e.enableZoom === !1 && e.enablePan === !1) return;
|
|
377
|
+
Ce(t), e.update();
|
|
378
|
+
break;
|
|
379
|
+
case a.TOUCH_DOLLY_ROTATE:
|
|
380
|
+
if (e.enableZoom === !1 && e.enableRotate === !1) return;
|
|
381
|
+
Ye(t), e.update();
|
|
382
|
+
break;
|
|
383
|
+
default:
|
|
384
|
+
r = a.NONE;
|
|
385
|
+
}
|
|
386
|
+
}
|
|
387
|
+
function be(t) {
|
|
388
|
+
e.enabled !== !1 && t.preventDefault();
|
|
389
|
+
}
|
|
390
|
+
function Ue(t) {
|
|
391
|
+
c.push(t.pointerId);
|
|
392
|
+
}
|
|
393
|
+
function Ze(t) {
|
|
394
|
+
delete I[t.pointerId];
|
|
395
|
+
for (let o = 0; o < c.length; o++)
|
|
396
|
+
if (c[o] == t.pointerId) {
|
|
397
|
+
c.splice(o, 1);
|
|
398
|
+
return;
|
|
399
|
+
}
|
|
400
|
+
}
|
|
401
|
+
function Xe(t) {
|
|
402
|
+
for (let o = 0; o < c.length; o++)
|
|
403
|
+
if (c[o] == t.pointerId) return !0;
|
|
404
|
+
return !1;
|
|
405
|
+
}
|
|
406
|
+
function ye(t) {
|
|
407
|
+
let o = I[t.pointerId];
|
|
408
|
+
o === void 0 && (o = new m(), I[t.pointerId] = o), o.set(t.pageX, t.pageY);
|
|
409
|
+
}
|
|
410
|
+
function N(t) {
|
|
411
|
+
const o = t.pointerId === c[0] ? c[1] : c[0];
|
|
412
|
+
return I[o];
|
|
413
|
+
}
|
|
414
|
+
e.domElement.addEventListener("contextmenu", be), e.domElement.addEventListener("pointerdown", de), e.domElement.addEventListener("pointercancel", Y), e.domElement.addEventListener("wheel", me, { passive: !1 }), e.domElement.getRootNode().addEventListener("keydown", pe, { passive: !0, capture: !0 }), this.update();
|
|
415
|
+
}
|
|
416
|
+
}
|
|
417
|
+
export {
|
|
418
|
+
et as O
|
|
419
|
+
};
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use strict";const c=require("./three-viewport-gizmo-CwaL5sMV.cjs"),H=/^[og]\s*(.+)?/,N=/^mtllib /,q=/^usemtl /,J=/^usemap /,R=/\s+/,G=new c.Vector3,z=new c.Vector3,D=new c.Vector3,E=new c.Vector3,j=new c.Vector3,I=new c.Color;function W(){const P={objects:[],object:{},vertices:[],normals:[],colors:[],uvs:[],materials:{},materialLibraries:[],startObject:function(e,s){if(this.object&&this.object.fromDeclaration===!1){this.object.name=e,this.object.fromDeclaration=s!==!1;return}const i=this.object&&typeof this.object.currentMaterial=="function"?this.object.currentMaterial():void 0;if(this.object&&typeof this.object._finalize=="function"&&this.object._finalize(!0),this.object={name:e||"",fromDeclaration:s!==!1,geometry:{vertices:[],normals:[],colors:[],uvs:[],hasUVIndices:!1},materials:[],smooth:!0,startMaterial:function(t,r){const h=this._finalize(!1);h&&(h.inherited||h.groupCount<=0)&&this.materials.splice(h.index,1);const u={index:this.materials.length,name:t||"",mtllib:Array.isArray(r)&&r.length>0?r[r.length-1]:"",smooth:h!==void 0?h.smooth:this.smooth,groupStart:h!==void 0?h.groupEnd:0,groupEnd:-1,groupCount:-1,inherited:!1,clone:function(l){const n={index:typeof l=="number"?l:this.index,name:this.name,mtllib:this.mtllib,smooth:this.smooth,groupStart:0,groupEnd:-1,groupCount:-1,inherited:!1};return n.clone=this.clone.bind(n),n}};return this.materials.push(u),u},currentMaterial:function(){if(this.materials.length>0)return this.materials[this.materials.length-1]},_finalize:function(t){const r=this.currentMaterial();if(r&&r.groupEnd===-1&&(r.groupEnd=this.geometry.vertices.length/3,r.groupCount=r.groupEnd-r.groupStart,r.inherited=!1),t&&this.materials.length>1)for(let h=this.materials.length-1;h>=0;h--)this.materials[h].groupCount<=0&&this.materials.splice(h,1);return t&&this.materials.length===0&&this.materials.push({name:"",smooth:this.smooth}),r}},i&&i.name&&typeof i.clone=="function"){const t=i.clone(0);t.inherited=!0,this.object.materials.push(t)}this.objects.push(this.object)},finalize:function(){this.object&&typeof this.object._finalize=="function"&&this.object._finalize(!0)},parseVertexIndex:function(e,s){const i=parseInt(e,10);return(i>=0?i-1:i+s/3)*3},parseNormalIndex:function(e,s){const i=parseInt(e,10);return(i>=0?i-1:i+s/3)*3},parseUVIndex:function(e,s){const i=parseInt(e,10);return(i>=0?i-1:i+s/2)*2},addVertex:function(e,s,i){const t=this.vertices,r=this.object.geometry.vertices;r.push(t[e+0],t[e+1],t[e+2]),r.push(t[s+0],t[s+1],t[s+2]),r.push(t[i+0],t[i+1],t[i+2])},addVertexPoint:function(e){const s=this.vertices;this.object.geometry.vertices.push(s[e+0],s[e+1],s[e+2])},addVertexLine:function(e){const s=this.vertices;this.object.geometry.vertices.push(s[e+0],s[e+1],s[e+2])},addNormal:function(e,s,i){const t=this.normals,r=this.object.geometry.normals;r.push(t[e+0],t[e+1],t[e+2]),r.push(t[s+0],t[s+1],t[s+2]),r.push(t[i+0],t[i+1],t[i+2])},addFaceNormal:function(e,s,i){const t=this.vertices,r=this.object.geometry.normals;G.fromArray(t,e),z.fromArray(t,s),D.fromArray(t,i),j.subVectors(D,z),E.subVectors(G,z),j.cross(E),j.normalize(),r.push(j.x,j.y,j.z),r.push(j.x,j.y,j.z),r.push(j.x,j.y,j.z)},addColor:function(e,s,i){const t=this.colors,r=this.object.geometry.colors;t[e]!==void 0&&r.push(t[e+0],t[e+1],t[e+2]),t[s]!==void 0&&r.push(t[s+0],t[s+1],t[s+2]),t[i]!==void 0&&r.push(t[i+0],t[i+1],t[i+2])},addUV:function(e,s,i){const t=this.uvs,r=this.object.geometry.uvs;r.push(t[e+0],t[e+1]),r.push(t[s+0],t[s+1]),r.push(t[i+0],t[i+1])},addDefaultUV:function(){const e=this.object.geometry.uvs;e.push(0,0),e.push(0,0),e.push(0,0)},addUVLine:function(e){const s=this.uvs;this.object.geometry.uvs.push(s[e+0],s[e+1])},addFace:function(e,s,i,t,r,h,u,l,n){const o=this.vertices.length;let a=this.parseVertexIndex(e,o),f=this.parseVertexIndex(s,o),m=this.parseVertexIndex(i,o);if(this.addVertex(a,f,m),this.addColor(a,f,m),u!==void 0&&u!==""){const g=this.normals.length;a=this.parseNormalIndex(u,g),f=this.parseNormalIndex(l,g),m=this.parseNormalIndex(n,g),this.addNormal(a,f,m)}else this.addFaceNormal(a,f,m);if(t!==void 0&&t!==""){const g=this.uvs.length;a=this.parseUVIndex(t,g),f=this.parseUVIndex(r,g),m=this.parseUVIndex(h,g),this.addUV(a,f,m),this.object.geometry.hasUVIndices=!0}else this.addDefaultUV()},addPointGeometry:function(e){this.object.geometry.type="Points";const s=this.vertices.length;for(let i=0,t=e.length;i<t;i++){const r=this.parseVertexIndex(e[i],s);this.addVertexPoint(r),this.addColor(r)}},addLineGeometry:function(e,s){this.object.geometry.type="Line";const i=this.vertices.length,t=this.uvs.length;for(let r=0,h=e.length;r<h;r++)this.addVertexLine(this.parseVertexIndex(e[r],i));for(let r=0,h=s.length;r<h;r++)this.addUVLine(this.parseUVIndex(s[r],t))}};return P.startObject("",!1),P}class Z extends c.Loader{constructor(e){super(e),this.materials=null}load(e,s,i,t){const r=this,h=new c.FileLoader(this.manager);h.setPath(this.path),h.setRequestHeader(this.requestHeader),h.setWithCredentials(this.withCredentials),h.load(e,function(u){try{s(r.parse(u))}catch(l){t?t(l):console.error(l),r.manager.itemError(e)}},i,t)}setMaterials(e){return this.materials=e,this}parse(e){const s=new W;e.indexOf(`\r
|
|
2
|
+
`)!==-1&&(e=e.replace(/\r\n/g,`
|
|
3
|
+
`)),e.indexOf(`\\
|
|
4
|
+
`)!==-1&&(e=e.replace(/\\\n/g,""));const i=e.split(`
|
|
5
|
+
`);let t=[];for(let u=0,l=i.length;u<l;u++){const n=i[u].trimStart();if(n.length===0)continue;const o=n.charAt(0);if(o!=="#")if(o==="v"){const a=n.split(R);switch(a[0]){case"v":s.vertices.push(parseFloat(a[1]),parseFloat(a[2]),parseFloat(a[3])),a.length>=7?(I.setRGB(parseFloat(a[4]),parseFloat(a[5]),parseFloat(a[6])).convertSRGBToLinear(),s.colors.push(I.r,I.g,I.b)):s.colors.push(void 0,void 0,void 0);break;case"vn":s.normals.push(parseFloat(a[1]),parseFloat(a[2]),parseFloat(a[3]));break;case"vt":s.uvs.push(parseFloat(a[1]),parseFloat(a[2]));break}}else if(o==="f"){const f=n.slice(1).trim().split(R),m=[];for(let p=0,b=f.length;p<b;p++){const x=f[p];if(x.length>0){const w=x.split("/");m.push(w)}}const g=m[0];for(let p=1,b=m.length-1;p<b;p++){const x=m[p],w=m[p+1];s.addFace(g[0],x[0],w[0],g[1],x[1],w[1],g[2],x[2],w[2])}}else if(o==="l"){const a=n.substring(1).trim().split(" ");let f=[];const m=[];if(n.indexOf("/")===-1)f=a;else for(let g=0,p=a.length;g<p;g++){const b=a[g].split("/");b[0]!==""&&f.push(b[0]),b[1]!==""&&m.push(b[1])}s.addLineGeometry(f,m)}else if(o==="p"){const f=n.slice(1).trim().split(" ");s.addPointGeometry(f)}else if((t=H.exec(n))!==null){const a=(" "+t[0].slice(1).trim()).slice(1);s.startObject(a)}else if(q.test(n))s.object.startMaterial(n.substring(7).trim(),s.materialLibraries);else if(N.test(n))s.materialLibraries.push(n.substring(7).trim());else if(J.test(n))console.warn('THREE.OBJLoader: Rendering identifier "usemap" not supported. Textures must be defined in MTL files.');else if(o==="s"){if(t=n.split(" "),t.length>1){const f=t[1].trim().toLowerCase();s.object.smooth=f!=="0"&&f!=="off"}else s.object.smooth=!0;const a=s.object.currentMaterial();a&&(a.smooth=s.object.smooth)}else{if(n==="\0")continue;console.warn('THREE.OBJLoader: Unexpected line: "'+n+'"')}}s.finalize();const r=new c.Group;if(r.materialLibraries=[].concat(s.materialLibraries),!(s.objects.length===1&&s.objects[0].geometry.vertices.length===0)===!0)for(let u=0,l=s.objects.length;u<l;u++){const n=s.objects[u],o=n.geometry,a=n.materials,f=o.type==="Line",m=o.type==="Points";let g=!1;if(o.vertices.length===0)continue;const p=new c.BufferGeometry;p.setAttribute("position",new c.Float32BufferAttribute(o.vertices,3)),o.normals.length>0&&p.setAttribute("normal",new c.Float32BufferAttribute(o.normals,3)),o.colors.length>0&&(g=!0,p.setAttribute("color",new c.Float32BufferAttribute(o.colors,3))),o.hasUVIndices===!0&&p.setAttribute("uv",new c.Float32BufferAttribute(o.uvs,2));const b=[];for(let w=0,M=a.length;w<M;w++){const L=a[w],A=L.name+"_"+L.smooth+"_"+g;let d=s.materials[A];if(this.materials!==null){if(d=this.materials.create(L.name),f&&d&&!(d instanceof c.LineBasicMaterial)){const y=new c.LineBasicMaterial;c.Material.prototype.copy.call(y,d),y.color.copy(d.color),d=y}else if(m&&d&&!(d instanceof c.PointsMaterial)){const y=new c.PointsMaterial({size:10,sizeAttenuation:!1});c.Material.prototype.copy.call(y,d),y.color.copy(d.color),y.map=d.map,d=y}}d===void 0&&(f?d=new c.LineBasicMaterial:m?d=new c.PointsMaterial({size:1,sizeAttenuation:!1}):d=new c.MeshPhongMaterial,d.name=L.name,d.flatShading=!L.smooth,d.vertexColors=g,s.materials[A]=d),b.push(d)}let x;if(b.length>1){for(let w=0,M=a.length;w<M;w++){const L=a[w];p.addGroup(L.groupStart,L.groupCount,w)}f?x=new c.LineSegments(p,b):m?x=new c.Points(p,b):x=new c.Mesh(p,b)}else f?x=new c.LineSegments(p,b[0]):m?x=new c.Points(p,b[0]):x=new c.Mesh(p,b[0]);x.name=n.name,r.add(x)}else if(s.vertices.length>0){const u=new c.PointsMaterial({size:1,sizeAttenuation:!1}),l=new c.BufferGeometry;l.setAttribute("position",new c.Float32BufferAttribute(s.vertices,3)),s.colors.length>0&&s.colors[0]!==void 0&&(l.setAttribute("color",new c.Float32BufferAttribute(s.colors,3)),u.vertexColors=!0);const n=new c.Points(l,u);r.add(n)}return r}}class X extends c.Loader{constructor(e){super(e)}load(e,s,i,t){const r=this,h=this.path===""?c.LoaderUtils.extractUrlBase(e):this.path,u=new c.FileLoader(this.manager);u.setPath(this.path),u.setRequestHeader(this.requestHeader),u.setWithCredentials(this.withCredentials),u.load(e,function(l){try{s(r.parse(l,h))}catch(n){t?t(n):console.error(n),r.manager.itemError(e)}},i,t)}setMaterialOptions(e){return this.materialOptions=e,this}parse(e,s){const i=e.split(`
|
|
6
|
+
`);let t={};const r=/\s+/,h={};for(let l=0;l<i.length;l++){let n=i[l];if(n=n.trim(),n.length===0||n.charAt(0)==="#")continue;const o=n.indexOf(" ");let a=o>=0?n.substring(0,o):n;a=a.toLowerCase();let f=o>=0?n.substring(o+1):"";if(f=f.trim(),a==="newmtl")t={name:f},h[f]=t;else if(a==="ka"||a==="kd"||a==="ks"||a==="ke"){const m=f.split(r,3);t[a]=[parseFloat(m[0]),parseFloat(m[1]),parseFloat(m[2])]}else t[a]=f}const u=new Y(this.resourcePath||s,this.materialOptions);return u.setCrossOrigin(this.crossOrigin),u.setManager(this.manager),u.setMaterials(h),u}}class Y{constructor(e="",s={}){this.baseUrl=e,this.options=s,this.materialsInfo={},this.materials={},this.materialsArray=[],this.nameLookup={},this.crossOrigin="anonymous",this.side=this.options.side!==void 0?this.options.side:c.FrontSide,this.wrap=this.options.wrap!==void 0?this.options.wrap:c.RepeatWrapping}setCrossOrigin(e){return this.crossOrigin=e,this}setManager(e){this.manager=e}setMaterials(e){this.materialsInfo=this.convert(e),this.materials={},this.materialsArray=[],this.nameLookup={}}convert(e){if(!this.options)return e;const s={};for(const i in e){const t=e[i],r={};s[i]=r;for(const h in t){let u=!0,l=t[h];const n=h.toLowerCase();switch(n){case"kd":case"ka":case"ks":this.options&&this.options.normalizeRGB&&(l=[l[0]/255,l[1]/255,l[2]/255]),this.options&&this.options.ignoreZeroRGBs&&l[0]===0&&l[1]===0&&l[2]===0&&(u=!1);break}u&&(r[n]=l)}}return s}preload(){for(const e in this.materialsInfo)this.create(e)}getIndex(e){return this.nameLookup[e]}getAsArray(){let e=0;for(const s in this.materialsInfo)this.materialsArray[e]=this.create(s),this.nameLookup[s]=e,e++;return this.materialsArray}create(e){return this.materials[e]===void 0&&this.createMaterial_(e),this.materials[e]}createMaterial_(e){const s=this,i=this.materialsInfo[e],t={name:e,side:this.side};function r(u,l){return typeof l!="string"||l===""?"":/^https?:\/\//i.test(l)?l:u+l}function h(u,l){if(t[u])return;const n=s.getTextureParams(l,t),o=s.loadTexture(r(s.baseUrl,n.url));o.repeat.copy(n.scale),o.offset.copy(n.offset),o.wrapS=s.wrap,o.wrapT=s.wrap,(u==="map"||u==="emissiveMap")&&(o.colorSpace=c.SRGBColorSpace),t[u]=o}for(const u in i){const l=i[u];let n;if(l!=="")switch(u.toLowerCase()){case"kd":t.color=new c.Color().fromArray(l).convertSRGBToLinear();break;case"ks":t.specular=new c.Color().fromArray(l).convertSRGBToLinear();break;case"ke":t.emissive=new c.Color().fromArray(l).convertSRGBToLinear();break;case"map_kd":h("map",l);break;case"map_ks":h("specularMap",l);break;case"map_ke":h("emissiveMap",l);break;case"norm":h("normalMap",l);break;case"map_bump":case"bump":h("bumpMap",l);break;case"map_d":h("alphaMap",l),t.transparent=!0;break;case"ns":t.shininess=parseFloat(l);break;case"d":n=parseFloat(l),n<1&&(t.opacity=n,t.transparent=!0);break;case"tr":n=parseFloat(l),this.options&&this.options.invertTrProperty&&(n=1-n),n>0&&(t.opacity=1-n,t.transparent=!0);break}}return this.materials[e]=new c.MeshPhongMaterial(t),this.materials[e]}getTextureParams(e,s){const i={scale:new c.Vector2(1,1),offset:new c.Vector2(0,0)},t=e.split(/\s+/);let r;return r=t.indexOf("-bm"),r>=0&&(s.bumpScale=parseFloat(t[r+1]),t.splice(r,2)),r=t.indexOf("-s"),r>=0&&(i.scale.set(parseFloat(t[r+1]),parseFloat(t[r+2])),t.splice(r,4)),r=t.indexOf("-o"),r>=0&&(i.offset.set(parseFloat(t[r+1]),parseFloat(t[r+2])),t.splice(r,4)),i.url=t.join(" ").trim(),i}loadTexture(e,s,i,t,r){const h=this.manager!==void 0?this.manager:c.DefaultLoadingManager;let u=h.getHandler(e);u===null&&(u=new c.TextureLoader(h)),u.setCrossOrigin&&u.setCrossOrigin(this.crossOrigin);const l=u.load(e,i,t,r);return s!==void 0&&(l.mapping=s),l}}class K extends c.Loader{constructor(e){super(e)}load(e,s,i,t){const r=this,h=new c.FileLoader(this.manager);h.setPath(this.path),h.setResponseType("arraybuffer"),h.setRequestHeader(this.requestHeader),h.setWithCredentials(this.withCredentials),h.load(e,function(u){try{s(r.parse(u))}catch(l){t?t(l):console.error(l),r.manager.itemError(e)}},i,t)}parse(e){function s(n){const o=new DataView(n),a=32/8*3+32/8*3*3+16/8,f=o.getUint32(80,!0);if(80+32/8+f*a===o.byteLength)return!0;const g=[115,111,108,105,100];for(let p=0;p<5;p++)if(i(g,o,p))return!1;return!0}function i(n,o,a){for(let f=0,m=n.length;f<m;f++)if(n[f]!==o.getUint8(a+f))return!1;return!0}function t(n){const o=new DataView(n),a=o.getUint32(80,!0);let f,m,g,p=!1,b,x,w,M,L;for(let v=0;v<70;v++)o.getUint32(v,!1)==1129270351&&o.getUint8(v+4)==82&&o.getUint8(v+5)==61&&(p=!0,b=new Float32Array(a*3*3),x=o.getUint8(v+6)/255,w=o.getUint8(v+7)/255,M=o.getUint8(v+8)/255,L=o.getUint8(v+9)/255);const A=84,d=12*4+2,y=new c.BufferGeometry,C=new Float32Array(a*3*3),_=new Float32Array(a*3*3),B=new c.Color;for(let v=0;v<a;v++){const k=A+v*d,O=o.getFloat32(k,!0),U=o.getFloat32(k+4,!0),S=o.getFloat32(k+8,!0);if(p){const F=o.getUint16(k+48,!0);(F&32768)===0?(f=(F&31)/31,m=(F>>5&31)/31,g=(F>>10&31)/31):(f=x,m=w,g=M)}for(let F=1;F<=3;F++){const T=k+F*12,V=v*3*3+(F-1)*3;C[V]=o.getFloat32(T,!0),C[V+1]=o.getFloat32(T+4,!0),C[V+2]=o.getFloat32(T+8,!0),_[V]=O,_[V+1]=U,_[V+2]=S,p&&(B.set(f,m,g).convertSRGBToLinear(),b[V]=B.r,b[V+1]=B.g,b[V+2]=B.b)}}return y.setAttribute("position",new c.BufferAttribute(C,3)),y.setAttribute("normal",new c.BufferAttribute(_,3)),p&&(y.setAttribute("color",new c.BufferAttribute(b,3)),y.hasColors=!0,y.alpha=L),y}function r(n){const o=new c.BufferGeometry,a=/solid([\s\S]*?)endsolid/g,f=/facet([\s\S]*?)endfacet/g,m=/solid\s(.+)/;let g=0;const p=/[\s]+([+-]?(?:\d*)(?:\.\d*)?(?:[eE][+-]?\d+)?)/.source,b=new RegExp("vertex"+p+p+p,"g"),x=new RegExp("normal"+p+p+p,"g"),w=[],M=[],L=[],A=new c.Vector3;let d,y=0,C=0,_=0;for(;(d=a.exec(n))!==null;){C=_;const B=d[0],v=(d=m.exec(B))!==null?d[1]:"";for(L.push(v);(d=f.exec(B))!==null;){let U=0,S=0;const F=d[0];for(;(d=x.exec(F))!==null;)A.x=parseFloat(d[1]),A.y=parseFloat(d[2]),A.z=parseFloat(d[3]),S++;for(;(d=b.exec(F))!==null;)w.push(parseFloat(d[1]),parseFloat(d[2]),parseFloat(d[3])),M.push(A.x,A.y,A.z),U++,_++;S!==1&&console.error("THREE.STLLoader: Something isn't right with the normal of face number "+g),U!==3&&console.error("THREE.STLLoader: Something isn't right with the vertices of face number "+g),g++}const k=C,O=_-C;o.userData.groupNames=L,o.addGroup(k,O,y),y++}return o.setAttribute("position",new c.Float32BufferAttribute(w,3)),o.setAttribute("normal",new c.Float32BufferAttribute(M,3)),o}function h(n){return typeof n!="string"?new TextDecoder().decode(n):n}function u(n){if(typeof n=="string"){const o=new Uint8Array(n.length);for(let a=0;a<n.length;a++)o[a]=n.charCodeAt(a)&255;return o.buffer||o}else return n}const l=u(e);return s(l)?t(l):r(h(e))}}exports.MTLLoader=X;exports.OBJLoader=Z;exports.STLLoader=K;
|