mirror of
https://github.com/DaanVandenBosch/phantasmal-world.git
synced 2025-04-05 15:28:29 +08:00
1 line
11 KiB
JavaScript
1 line
11 KiB
JavaScript
![]() |
(window.webpackJsonp=window.webpackJsonp||[]).push([[17],{463:function(t,e,i){"use strict";i.d(e,"b",(function(){return n})),i.d(e,"g",(function(){return s})),i.d(e,"c",(function(){return r})),i.d(e,"j",(function(){return h})),i.d(e,"h",(function(){return o})),i.d(e,"i",(function(){return c})),i.d(e,"d",(function(){return d})),i.d(e,"a",(function(){return u})),i.d(e,"e",(function(){return b})),i.d(e,"f",(function(){return _}));var a=i(40);class n{constructor(t,e){this.x=t,this.y=e}get u(){return this.x}get v(){return this.y}}function s(t,e){return new n(t.x-e.x,t.y-e.y)}class r{constructor(t,e,i){this.x=t,this.y=e,this.z=i}magnitude(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z)}normalize(){const t=1/this.magnitude();this.x*=t,this.y*=t,this.z*=t}}function h(t,e){return new r(t.x-e.x,t.y-e.y,t.z-e.z)}function o(t,e){return new r(t.y*e.z-t.z*e.y,t.z*e.x-t.x*e.z,t.x*e.y-t.y*e.x)}function c(t,e){return t.x*e.x+t.y*e.y+t.z*e.z}class l{constructor(t){this.data=t,Object(a.d)(9===t.length,"data should be of length 9.")}static of(t,e,i,a,n,s,r,h,o){return new l(new Float32Array([t,a,r,e,n,h,i,s,o]))}static identity(){return l.of(1,0,0,0,1,0,0,0,1)}get(t,e){return this.data[t+3*e]}set(t,e,i){this.data[t+3*e]=i}clone(){return new l(new Float32Array(this.data))}transpose(){let t;const e=this.data;t=e[1],e[1]=e[3],e[3]=t,t=e[2],e[2]=e[6],e[6]=t,t=e[5],e[5]=e[7],e[7]=t}inverse(){const t=this.clone();return t.invert(),t}invert(){const t=this.data[0],e=this.data[1],i=this.data[2],a=this.data[3],n=this.data[4],s=this.data[5],r=this.data[6],h=this.data[7],o=this.data[8],c=o*n-s*h,l=s*r-o*a,d=h*a-n*r,u=t*c+e*l+i*d;if(0===u)return this.data[0]=1,this.data[1]=0,this.data[2]=0,this.data[3]=0,this.data[4]=1,this.data[5]=0,this.data[6]=0,this.data[7]=0,void(this.data[8]=1);const b=1/u;this.data[0]=c*b,this.data[1]=(i*h-o*e)*b,this.data[2]=(s*e-i*n)*b,this.data[3]=l*b,this.data[4]=(o*t-i*r)*b,this.data[5]=(i*a-s*t)*b,this.data[6]=d*b,this.data[7]=(e*r-h*t)*b,this.data[8]=(n*t-e*a)*b}}function d(t,e,i){const a=t.get(0,0)*e.x+t.get(0,1)*e.y+t.get(0,2)*e.z,n=t.get(1,0)*e.x+t.get(1,1)*e.y+t.get(1,2)*e.z,s=t.get(2,0)*e.x+t.get(2,1)*e.y+t.get(2,2)*e.z;i.x=a,i.y=n,i.z=s}class u{constructor(t){this.data=t,Object(a.d)(16===t.length,"data should be of length 16.")}static of(t,e,i,a,n,s,r,h,o,c,l,d,b,f,_,w){return new u(new Float32Array([t,n,o,b,e,s,c,f,i,r,l,_,a,h,d,w]))}static identity(){return u.of(1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1)}static translation(t,e,i){return u.of(1,0,0,t,0,1,0,e,0,0,1,i,0,0,0,1)}static scale(t,e,i){return u.of(t,0,0,1,0,e,0,1,0,0,i,1,0,0,0,1)}static compose(t,e,i){const a=e.w,n=e.x,s=e.y,r=e.z,h=n+n,o=s+s,c=r+r,l=n*h,d=n*o,b=n*c,f=s*o,_=s*c,w=r*c,p=a*h,y=a*o,v=a*c,g=i.x,m=i.y,x=i.z;return u.of((1-(f+w))*g,(d-v)*m,(b+y)*x,t.x,(d+v)*g,(1-(l+w))*m,(_-p)*x,t.y,(b-y)*g,(_+p)*m,(1-(l+f))*x,t.z,0,0,0,1)}get(t,e){return this.data[t+4*e]}set(t,e,i){this.data[t+4*e]=i}set_all(t,e,i,a,n,s,r,h,o,c,l,d,u,b,f,_){this.data[0]=t,this.data[1]=n,this.data[2]=o,this.data[3]=u,this.data[4]=e,this.data[5]=s,this.data[6]=c,this.data[7]=b,this.data[8]=i,this.data[9]=r,this.data[10]=l,this.data[11]=f,this.data[12]=a,this.data[13]=h,this.data[14]=d,this.data[15]=_}transpose(){let t;const e=this.data;t=e[1],e[1]=e[4],e[4]=t,t=e[2],e[2]=e[8],e[8]=t,t=e[6],e[6]=e[9],e[9]=t,t=e[3],e[3]=e[12],e[12]=t,t=e[7],e[7]=e[13],e[13]=t,t=e[11],e[11]=e[14],e[14]=t}clone(){return new u(new Float32Array(this.data))}normal_mat3(){const t=l.of(this.data[0],this.data[4],this.data[8],this.data[1],this.data[5],this.data[9],this.data[2],this.data[6],this.data[10]);return t.invert(),t.transpose(),t}}function b(t,e){const i=new u(new Float32Array(16));return f(i.data,t,e),i}function f(t,e,i){for(let a=0;a<4;a++)for(let n=0;n<4;n++)for(let s=0;s<4;s++)t[a+4*n]+=e.data[a+4*s]*i.data[s+4*n]}function _(t,e,i){const a=t.get(0,0)*e.x+t.get(0,1)*e.y+t.get(0,2)*e.z+t.get(0,3),n=t.get(1,0)*e.x+t.get(1,1)*e.y+t.get(1,2)*e.z+t.get(1,3),s=t.get(2,0)*e.x+t.get(2,1)*e.y+t.get(2,2)*e.z+t.get(2,3);i.x=a,i.y=n,i.z=s}},532:function(t,e,i){"use strict";i.d(e,"d",(function(){return s}
|