|
@@ -248,27 +248,27 @@ Fa.g+e.g;Fa.b=Fa.b+e.b}else if(d instanceof THREE.PointLight){Ra.r=Ra.r+e.r;Ra.g
|
|
|
g.distance,1));if(i!=0){i=i*g.intensity;d.r=d.r+h.r*i;d.g=d.g+h.g*i;d.b=d.b+h.b*i}}}}}function q(a,f,g){b(g.opacity);c(g.blending);var h,k,i,j,l,m;if(g instanceof THREE.ParticleBasicMaterial){if(g.map!==null){j=g.map.image;l=j.width>>1;m=j.height>>1;g=f.scale.x*p;i=f.scale.y*r;h=g*l;k=i*m;Aa.set(a.x-h,a.y-k,a.x+h,a.y+k);if(Ua.intersects(Aa)!==false){o.save();o.translate(a.x,a.y);o.rotate(-f.rotation);o.scale(g,-i);o.translate(-l,-m);o.drawImage(j,0,0);o.restore()}}}else if(g instanceof THREE.ParticleCanvasMaterial){h=
|
|
|
f.scale.x*p;k=f.scale.y*r;Aa.set(a.x-h,a.y-k,a.x+h,a.y+k);if(Ua.intersects(Aa)!==false){d(g.color.getContextStyle());e(g.color.getContextStyle());o.save();o.translate(a.x,a.y);o.rotate(-f.rotation);o.scale(h,k);g.program(o);o.restore()}}}function s(a,e,f,g){b(g.opacity);c(g.blending);o.beginPath();o.moveTo(a.positionScreen.x,a.positionScreen.y);o.lineTo(e.positionScreen.x,e.positionScreen.y);o.closePath();if(g instanceof THREE.LineBasicMaterial){a=g.linewidth;if(C!==a)C=o.lineWidth=a;a=g.linecap;
|
|
|
if(D!==a)D=o.lineCap=a;a=g.linejoin;if(z!==a)z=o.lineJoin=a;d(g.color.getContextStyle());o.stroke();Aa.inflate(g.linewidth*2)}}function t(a,d,e,g,h,k,j,m){f.info.render.vertices=f.info.render.vertices+3;f.info.render.faces++;b(m.opacity);c(m.blending);B=a.positionScreen.x;F=a.positionScreen.y;Q=d.positionScreen.x;E=d.positionScreen.y;aa=e.positionScreen.x;T=e.positionScreen.y;w(B,F,Q,E,aa,T);if(m instanceof THREE.MeshBasicMaterial)if(m.map!==null){if(m.map.mapping instanceof THREE.UVMapping){bb=j.uvs[0];
|
|
|
-kd(B,F,Q,E,aa,T,bb[g].u,bb[g].v,bb[h].u,bb[h].v,bb[k].u,bb[k].v,m.map)}}else if(m.envMap!==null){if(m.envMap.mapping instanceof THREE.SphericalReflectionMapping){a=l.matrixWorldInverse;sa.copy(j.vertexNormalsWorld[g]);nb=(sa.x*a.elements[0]+sa.y*a.elements[4]+sa.z*a.elements[8])*0.5+0.5;gb=-(sa.x*a.elements[1]+sa.y*a.elements[5]+sa.z*a.elements[9])*0.5+0.5;sa.copy(j.vertexNormalsWorld[h]);Ob=(sa.x*a.elements[0]+sa.y*a.elements[4]+sa.z*a.elements[8])*0.5+0.5;ob=-(sa.x*a.elements[1]+sa.y*a.elements[5]+
|
|
|
-sa.z*a.elements[9])*0.5+0.5;sa.copy(j.vertexNormalsWorld[k]);kb=(sa.x*a.elements[0]+sa.y*a.elements[4]+sa.z*a.elements[8])*0.5+0.5;ec=-(sa.x*a.elements[1]+sa.y*a.elements[5]+sa.z*a.elements[9])*0.5+0.5;kd(B,F,Q,E,aa,T,nb,gb,Ob,ob,kb,ec,m.envMap)}}else m.wireframe===true?Pb(m.color,m.wireframeLinewidth,m.wireframeLinecap,m.wireframeLinejoin):Hb(m.color);else if(m instanceof THREE.MeshLambertMaterial)if(hb===true)if(m.wireframe===false&&m.shading==THREE.SmoothShading&&j.vertexNormalsWorld.length==3){R.r=
|
|
|
+kd(B,F,Q,E,aa,T,bb[g].u,bb[g].v,bb[h].u,bb[h].v,bb[k].u,bb[k].v,m.map)}}else if(m.envMap!==null){if(m.envMap.mapping instanceof THREE.SphericalReflectionMapping){a=l.matrixWorldInverse;sa.copy(j.vertexNormalsWorld[g]);nb=(sa.x*a.elements[0]+sa.y*a.elements[4]+sa.z*a.elements[8])*0.5+0.5;gb=(sa.x*a.elements[1]+sa.y*a.elements[5]+sa.z*a.elements[9])*0.5+0.5;sa.copy(j.vertexNormalsWorld[h]);Ob=(sa.x*a.elements[0]+sa.y*a.elements[4]+sa.z*a.elements[8])*0.5+0.5;ob=(sa.x*a.elements[1]+sa.y*a.elements[5]+
|
|
|
+sa.z*a.elements[9])*0.5+0.5;sa.copy(j.vertexNormalsWorld[k]);kb=(sa.x*a.elements[0]+sa.y*a.elements[4]+sa.z*a.elements[8])*0.5+0.5;ec=(sa.x*a.elements[1]+sa.y*a.elements[5]+sa.z*a.elements[9])*0.5+0.5;kd(B,F,Q,E,aa,T,nb,gb,Ob,ob,kb,ec,m.envMap)}}else m.wireframe===true?Pb(m.color,m.wireframeLinewidth,m.wireframeLinecap,m.wireframeLinejoin):Hb(m.color);else if(m instanceof THREE.MeshLambertMaterial)if(hb===true)if(m.wireframe===false&&m.shading==THREE.SmoothShading&&j.vertexNormalsWorld.length==3){R.r=
|
|
|
P.r=U.r=qa.r;R.g=P.g=U.g=qa.g;R.b=P.b=U.b=qa.b;n(i,j.v1.positionWorld,j.vertexNormalsWorld[0],R);n(i,j.v2.positionWorld,j.vertexNormalsWorld[1],P);n(i,j.v3.positionWorld,j.vertexNormalsWorld[2],U);R.r=Math.max(0,Math.min(m.color.r*R.r,1));R.g=Math.max(0,Math.min(m.color.g*R.g,1));R.b=Math.max(0,Math.min(m.color.b*R.b,1));P.r=Math.max(0,Math.min(m.color.r*P.r,1));P.g=Math.max(0,Math.min(m.color.g*P.g,1));P.b=Math.max(0,Math.min(m.color.b*P.b,1));U.r=Math.max(0,Math.min(m.color.r*U.r,1));U.g=Math.max(0,
|
|
|
Math.min(m.color.g*U.g,1));U.b=Math.max(0,Math.min(m.color.b*U.b,1));fa.r=(P.r+U.r)*0.5;fa.g=(P.g+U.g)*0.5;fa.b=(P.b+U.b)*0.5;Pa=Ic(R,P,U,fa);mc(B,F,Q,E,aa,T,0,0,1,0,0,1,Pa)}else{S.r=qa.r;S.g=qa.g;S.b=qa.b;n(i,j.centroidWorld,j.normalWorld,S);S.r=Math.max(0,Math.min(m.color.r*S.r,1));S.g=Math.max(0,Math.min(m.color.g*S.g,1));S.b=Math.max(0,Math.min(m.color.b*S.b,1));m.wireframe===true?Pb(S,m.wireframeLinewidth,m.wireframeLinecap,m.wireframeLinejoin):Hb(S)}else m.wireframe===true?Pb(m.color,m.wireframeLinewidth,
|
|
|
m.wireframeLinecap,m.wireframeLinejoin):Hb(m.color);else if(m instanceof THREE.MeshDepthMaterial){na=l.near;Oa=l.far;R.r=R.g=R.b=1-gc(a.positionScreen.z,na,Oa);P.r=P.g=P.b=1-gc(d.positionScreen.z,na,Oa);U.r=U.g=U.b=1-gc(e.positionScreen.z,na,Oa);fa.r=(P.r+U.r)*0.5;fa.g=(P.g+U.g)*0.5;fa.b=(P.b+U.b)*0.5;Pa=Ic(R,P,U,fa);mc(B,F,Q,E,aa,T,0,0,1,0,0,1,Pa)}else if(m instanceof THREE.MeshNormalMaterial){S.r=nc(j.normalWorld.x);S.g=nc(j.normalWorld.y);S.b=nc(j.normalWorld.z);m.wireframe===true?Pb(S,m.wireframeLinewidth,
|
|
|
-m.wireframeLinecap,m.wireframeLinejoin):Hb(S)}}function v(a,d,e,g,h,k,j,m,o){f.info.render.vertices=f.info.render.vertices+4;f.info.render.faces++;b(m.opacity);c(m.blending);if(m.map!==null||m.envMap!==null){t(a,d,g,0,1,3,j,m,o);t(h,e,k,1,2,3,j,m,o)}else{B=a.positionScreen.x;F=a.positionScreen.y;Q=d.positionScreen.x;E=d.positionScreen.y;aa=e.positionScreen.x;T=e.positionScreen.y;N=g.positionScreen.x;W=g.positionScreen.y;ba=h.positionScreen.x;H=h.positionScreen.y;ca=k.positionScreen.x;ia=k.positionScreen.y;
|
|
|
-if(m instanceof THREE.MeshBasicMaterial){x(B,F,Q,E,aa,T,N,W);m.wireframe===true?Pb(m.color,m.wireframeLinewidth,m.wireframeLinecap,m.wireframeLinejoin):Hb(m.color)}else if(m instanceof THREE.MeshLambertMaterial)if(hb===true)if(!m.wireframe&&m.shading==THREE.SmoothShading&&j.vertexNormalsWorld.length==4){R.r=P.r=U.r=fa.r=qa.r;R.g=P.g=U.g=fa.g=qa.g;R.b=P.b=U.b=fa.b=qa.b;n(i,j.v1.positionWorld,j.vertexNormalsWorld[0],R);n(i,j.v2.positionWorld,j.vertexNormalsWorld[1],P);n(i,j.v4.positionWorld,j.vertexNormalsWorld[3],
|
|
|
-U);n(i,j.v3.positionWorld,j.vertexNormalsWorld[2],fa);R.r=Math.max(0,Math.min(m.color.r*R.r,1));R.g=Math.max(0,Math.min(m.color.g*R.g,1));R.b=Math.max(0,Math.min(m.color.b*R.b,1));P.r=Math.max(0,Math.min(m.color.r*P.r,1));P.g=Math.max(0,Math.min(m.color.g*P.g,1));P.b=Math.max(0,Math.min(m.color.b*P.b,1));U.r=Math.max(0,Math.min(m.color.r*U.r,1));U.g=Math.max(0,Math.min(m.color.g*U.g,1));U.b=Math.max(0,Math.min(m.color.b*U.b,1));fa.r=Math.max(0,Math.min(m.color.r*fa.r,1));fa.g=Math.max(0,Math.min(m.color.g*
|
|
|
-fa.g,1));fa.b=Math.max(0,Math.min(m.color.b*fa.b,1));Pa=Ic(R,P,U,fa);w(B,F,Q,E,N,W);mc(B,F,Q,E,N,W,0,0,1,0,0,1,Pa);w(ba,H,aa,T,ca,ia);mc(ba,H,aa,T,ca,ia,1,0,1,1,0,1,Pa)}else{S.r=qa.r;S.g=qa.g;S.b=qa.b;n(i,j.centroidWorld,j.normalWorld,S);S.r=Math.max(0,Math.min(m.color.r*S.r,1));S.g=Math.max(0,Math.min(m.color.g*S.g,1));S.b=Math.max(0,Math.min(m.color.b*S.b,1));x(B,F,Q,E,aa,T,N,W);m.wireframe===true?Pb(S,m.wireframeLinewidth,m.wireframeLinecap,m.wireframeLinejoin):Hb(S)}else{x(B,F,Q,E,aa,T,N,W);m.wireframe===
|
|
|
-true?Pb(m.color,m.wireframeLinewidth,m.wireframeLinecap,m.wireframeLinejoin):Hb(m.color)}else if(m instanceof THREE.MeshNormalMaterial){S.r=nc(j.normalWorld.x);S.g=nc(j.normalWorld.y);S.b=nc(j.normalWorld.z);x(B,F,Q,E,aa,T,N,W);m.wireframe===true?Pb(S,m.wireframeLinewidth,m.wireframeLinecap,m.wireframeLinejoin):Hb(S)}else if(m instanceof THREE.MeshDepthMaterial){na=l.near;Oa=l.far;R.r=R.g=R.b=1-gc(a.positionScreen.z,na,Oa);P.r=P.g=P.b=1-gc(d.positionScreen.z,na,Oa);U.r=U.g=U.b=1-gc(g.positionScreen.z,
|
|
|
-na,Oa);fa.r=fa.g=fa.b=1-gc(e.positionScreen.z,na,Oa);Pa=Ic(R,P,U,fa);w(B,F,Q,E,N,W);mc(B,F,Q,E,N,W,0,0,1,0,0,1,Pa);w(ba,H,aa,T,ca,ia);mc(ba,H,aa,T,ca,ia,1,0,1,1,0,1,Pa)}}}function w(a,b,c,d,e,f){o.beginPath();o.moveTo(a,b);o.lineTo(c,d);o.lineTo(e,f);o.lineTo(a,b)}function x(a,b,c,d,e,f,g,h){o.beginPath();o.moveTo(a,b);o.lineTo(c,d);o.lineTo(e,f);o.lineTo(g,h);o.lineTo(a,b)}function Pb(a,b,c,e){if(C!==b)C=o.lineWidth=b;if(D!==c)D=o.lineCap=c;if(z!==e)z=o.lineJoin=e;d(a.getContextStyle());o.stroke();
|
|
|
-Aa.inflate(b*2)}function Hb(a){e(a.getContextStyle());o.fill()}function kd(a,b,c,d,f,g,h,k,i,j,m,l,n){if(!(n.image===void 0||n.image.width===0)){if(n.needsUpdate===true||ma[n.id]===void 0){var p=n.wrapS==THREE.RepeatWrapping,fc=n.wrapT==THREE.RepeatWrapping;ma[n.id]=o.createPattern(n.image,p===true&&fc===true?"repeat":p===true&&fc===false?"repeat-x":p===false&&fc===true?"repeat-y":"no-repeat");n.needsUpdate=false}e(ma[n.id]);var p=n.offset.x/n.repeat.x,fc=n.offset.y/n.repeat.y,r=n.image.width*n.repeat.x,
|
|
|
-q=n.image.height*n.repeat.y,h=(h+p)*r,k=(k+fc)*q,c=c-a,d=d-b,f=f-a,g=g-b,i=(i+p)*r-h,j=(j+fc)*q-k,m=(m+p)*r-h,l=(l+fc)*q-k,p=i*l-m*j;if(p===0){if(Ga[n.id]===void 0){b=document.createElement("canvas");b.width=n.image.width;b.height=n.image.height;b=b.getContext("2d");b.drawImage(n.image,0,0);Ga[n.id]=b.getImageData(0,0,n.image.width,n.image.height).data}b=Ga[n.id];h=(Math.floor(h)+Math.floor(k)*n.image.width)*4;S.setRGB(b[h]/255,b[h+1]/255,b[h+2]/255);Hb(S)}else{p=1/p;n=(l*c-j*f)*p;j=(l*d-j*g)*p;c=
|
|
|
-(i*f-m*c)*p;d=(i*g-m*d)*p;a=a-n*h-c*k;h=b-j*h-d*k;o.save();o.transform(n,j,c,d,a,h);o.fill();o.restore()}}}function mc(a,b,c,d,e,f,g,h,k,i,j,m,l){var n,p;n=l.width-1;p=l.height-1;g=g*n;h=h*p;c=c-a;d=d-b;e=e-a;f=f-b;k=k*n-g;i=i*p-h;j=j*n-g;m=m*p-h;p=1/(k*m-j*i);n=(m*c-i*e)*p;i=(m*d-i*f)*p;c=(k*e-j*c)*p;d=(k*f-j*d)*p;a=a-n*g-c*h;b=b-i*g-d*h;o.save();o.transform(n,i,c,d,a,b);o.clip();o.drawImage(l,0,0);o.restore()}function Ic(a,b,c,d){var e=~~(a.r*255),f=~~(a.g*255),a=~~(a.b*255),g=~~(b.r*255),h=~~(b.g*
|
|
|
-255),b=~~(b.b*255),i=~~(c.r*255),j=~~(c.g*255),c=~~(c.b*255),m=~~(d.r*255),l=~~(d.g*255),d=~~(d.b*255);Va[0]=e<0?0:e>255?255:e;Va[1]=f<0?0:f>255?255:f;Va[2]=a<0?0:a>255?255:a;Va[4]=g<0?0:g>255?255:g;Va[5]=h<0?0:h>255?255:h;Va[6]=b<0?0:b>255?255:b;Va[8]=i<0?0:i>255?255:i;Va[9]=j<0?0:j>255?255:j;Va[10]=c<0?0:c>255?255:c;Va[12]=m<0?0:m>255?255:m;Va[13]=l<0?0:l>255?255:l;Va[14]=d<0?0:d>255?255:d;Ya.putImageData(Gb,0,0);pb.drawImage(k,0,0);return cb}function gc(a,b,c){a=(a-b)/(c-b);return a*a*(3-2*a)}
|
|
|
-function nc(a){a=(a+1)*0.5;return a<0?0:a>1?1:a}function Qb(a,b){var c=b.x-a.x,d=b.y-a.y,e=c*c+d*d;if(e!==0){e=1/Math.sqrt(e);c=c*e;d=d*e;b.x=b.x+c;b.y=b.y+d;a.x=a.x-c;a.y=a.y-d}}var Jc,ld,Ma,ib;this.autoClear===true?this.clear():o.setTransform(1,0,0,-1,p,r);f.info.render.vertices=0;f.info.render.faces=0;g=j.projectScene(a,l,this.sortElements);h=g.elements;i=g.lights;hb=i.length>0;hb===true&&m(i);Jc=0;for(ld=h.length;Jc<ld;Jc++){Ma=h[Jc];ib=Ma.material;ib=ib instanceof THREE.MeshFaceMaterial?Ma.faceMaterial:
|
|
|
-ib;if(!(ib===void 0||ib.visible===false)){Aa.empty();if(Ma instanceof THREE.RenderableParticle){u=Ma;u.x=u.x*p;u.y=u.y*r;q(u,Ma,ib,a)}else if(Ma instanceof THREE.RenderableLine){u=Ma.v1;G=Ma.v2;u.positionScreen.x=u.positionScreen.x*p;u.positionScreen.y=u.positionScreen.y*r;G.positionScreen.x=G.positionScreen.x*p;G.positionScreen.y=G.positionScreen.y*r;Aa.addPoint(u.positionScreen.x,u.positionScreen.y);Aa.addPoint(G.positionScreen.x,G.positionScreen.y);Ua.intersects(Aa)===true&&s(u,G,Ma,ib,a)}else if(Ma instanceof
|
|
|
-THREE.RenderableFace3){u=Ma.v1;G=Ma.v2;J=Ma.v3;u.positionScreen.x=u.positionScreen.x*p;u.positionScreen.y=u.positionScreen.y*r;G.positionScreen.x=G.positionScreen.x*p;G.positionScreen.y=G.positionScreen.y*r;J.positionScreen.x=J.positionScreen.x*p;J.positionScreen.y=J.positionScreen.y*r;if(ib.overdraw===true){Qb(u.positionScreen,G.positionScreen);Qb(G.positionScreen,J.positionScreen);Qb(J.positionScreen,u.positionScreen)}Aa.add3Points(u.positionScreen.x,u.positionScreen.y,G.positionScreen.x,G.positionScreen.y,
|
|
|
-J.positionScreen.x,J.positionScreen.y);Ua.intersects(Aa)===true&&t(u,G,J,0,1,2,Ma,ib,a)}else if(Ma instanceof THREE.RenderableFace4){u=Ma.v1;G=Ma.v2;J=Ma.v3;M=Ma.v4;u.positionScreen.x=u.positionScreen.x*p;u.positionScreen.y=u.positionScreen.y*r;G.positionScreen.x=G.positionScreen.x*p;G.positionScreen.y=G.positionScreen.y*r;J.positionScreen.x=J.positionScreen.x*p;J.positionScreen.y=J.positionScreen.y*r;M.positionScreen.x=M.positionScreen.x*p;M.positionScreen.y=M.positionScreen.y*r;O.positionScreen.copy(G.positionScreen);
|
|
|
-X.positionScreen.copy(M.positionScreen);if(ib.overdraw===true){Qb(u.positionScreen,G.positionScreen);Qb(G.positionScreen,M.positionScreen);Qb(M.positionScreen,u.positionScreen);Qb(J.positionScreen,O.positionScreen);Qb(J.positionScreen,X.positionScreen)}Aa.addPoint(u.positionScreen.x,u.positionScreen.y);Aa.addPoint(G.positionScreen.x,G.positionScreen.y);Aa.addPoint(J.positionScreen.x,J.positionScreen.y);Aa.addPoint(M.positionScreen.x,M.positionScreen.y);Ua.intersects(Aa)===true&&v(u,G,J,M,O,X,Ma,ib,
|
|
|
-a)}Da.addRectangle(Aa)}}o.setTransform(1,0,0,1,0,0)}};
|
|
|
+m.wireframeLinecap,m.wireframeLinejoin):Hb(S)}}function v(a,d,e,g,h,k,j,m,o){f.info.render.vertices=f.info.render.vertices+4;f.info.render.faces++;b(m.opacity);c(m.blending);if(m.map!==void 0&&m.map!==null||m.envMap!==void 0&&m.envMap!==null){t(a,d,g,0,1,3,j,m,o);t(h,e,k,1,2,3,j,m,o)}else{B=a.positionScreen.x;F=a.positionScreen.y;Q=d.positionScreen.x;E=d.positionScreen.y;aa=e.positionScreen.x;T=e.positionScreen.y;N=g.positionScreen.x;W=g.positionScreen.y;ba=h.positionScreen.x;H=h.positionScreen.y;
|
|
|
+ca=k.positionScreen.x;ia=k.positionScreen.y;if(m instanceof THREE.MeshBasicMaterial){x(B,F,Q,E,aa,T,N,W);m.wireframe===true?Pb(m.color,m.wireframeLinewidth,m.wireframeLinecap,m.wireframeLinejoin):Hb(m.color)}else if(m instanceof THREE.MeshLambertMaterial)if(hb===true)if(!m.wireframe&&m.shading==THREE.SmoothShading&&j.vertexNormalsWorld.length==4){R.r=P.r=U.r=fa.r=qa.r;R.g=P.g=U.g=fa.g=qa.g;R.b=P.b=U.b=fa.b=qa.b;n(i,j.v1.positionWorld,j.vertexNormalsWorld[0],R);n(i,j.v2.positionWorld,j.vertexNormalsWorld[1],
|
|
|
+P);n(i,j.v4.positionWorld,j.vertexNormalsWorld[3],U);n(i,j.v3.positionWorld,j.vertexNormalsWorld[2],fa);R.r=Math.max(0,Math.min(m.color.r*R.r,1));R.g=Math.max(0,Math.min(m.color.g*R.g,1));R.b=Math.max(0,Math.min(m.color.b*R.b,1));P.r=Math.max(0,Math.min(m.color.r*P.r,1));P.g=Math.max(0,Math.min(m.color.g*P.g,1));P.b=Math.max(0,Math.min(m.color.b*P.b,1));U.r=Math.max(0,Math.min(m.color.r*U.r,1));U.g=Math.max(0,Math.min(m.color.g*U.g,1));U.b=Math.max(0,Math.min(m.color.b*U.b,1));fa.r=Math.max(0,Math.min(m.color.r*
|
|
|
+fa.r,1));fa.g=Math.max(0,Math.min(m.color.g*fa.g,1));fa.b=Math.max(0,Math.min(m.color.b*fa.b,1));Pa=Ic(R,P,U,fa);w(B,F,Q,E,N,W);mc(B,F,Q,E,N,W,0,0,1,0,0,1,Pa);w(ba,H,aa,T,ca,ia);mc(ba,H,aa,T,ca,ia,1,0,1,1,0,1,Pa)}else{S.r=qa.r;S.g=qa.g;S.b=qa.b;n(i,j.centroidWorld,j.normalWorld,S);S.r=Math.max(0,Math.min(m.color.r*S.r,1));S.g=Math.max(0,Math.min(m.color.g*S.g,1));S.b=Math.max(0,Math.min(m.color.b*S.b,1));x(B,F,Q,E,aa,T,N,W);m.wireframe===true?Pb(S,m.wireframeLinewidth,m.wireframeLinecap,m.wireframeLinejoin):
|
|
|
+Hb(S)}else{x(B,F,Q,E,aa,T,N,W);m.wireframe===true?Pb(m.color,m.wireframeLinewidth,m.wireframeLinecap,m.wireframeLinejoin):Hb(m.color)}else if(m instanceof THREE.MeshNormalMaterial){S.r=nc(j.normalWorld.x);S.g=nc(j.normalWorld.y);S.b=nc(j.normalWorld.z);x(B,F,Q,E,aa,T,N,W);m.wireframe===true?Pb(S,m.wireframeLinewidth,m.wireframeLinecap,m.wireframeLinejoin):Hb(S)}else if(m instanceof THREE.MeshDepthMaterial){na=l.near;Oa=l.far;R.r=R.g=R.b=1-gc(a.positionScreen.z,na,Oa);P.r=P.g=P.b=1-gc(d.positionScreen.z,
|
|
|
+na,Oa);U.r=U.g=U.b=1-gc(g.positionScreen.z,na,Oa);fa.r=fa.g=fa.b=1-gc(e.positionScreen.z,na,Oa);Pa=Ic(R,P,U,fa);w(B,F,Q,E,N,W);mc(B,F,Q,E,N,W,0,0,1,0,0,1,Pa);w(ba,H,aa,T,ca,ia);mc(ba,H,aa,T,ca,ia,1,0,1,1,0,1,Pa)}}}function w(a,b,c,d,e,f){o.beginPath();o.moveTo(a,b);o.lineTo(c,d);o.lineTo(e,f);o.lineTo(a,b)}function x(a,b,c,d,e,f,g,h){o.beginPath();o.moveTo(a,b);o.lineTo(c,d);o.lineTo(e,f);o.lineTo(g,h);o.lineTo(a,b)}function Pb(a,b,c,e){if(C!==b)C=o.lineWidth=b;if(D!==c)D=o.lineCap=c;if(z!==e)z=o.lineJoin=
|
|
|
+e;d(a.getContextStyle());o.stroke();Aa.inflate(b*2)}function Hb(a){e(a.getContextStyle());o.fill()}function kd(a,b,c,d,f,g,h,k,i,j,m,l,n){if(!(n.image===void 0||n.image.width===0)){if(n.needsUpdate===true||ma[n.id]===void 0){var p=n.wrapS==THREE.RepeatWrapping,fc=n.wrapT==THREE.RepeatWrapping;ma[n.id]=o.createPattern(n.image,p===true&&fc===true?"repeat":p===true&&fc===false?"repeat-x":p===false&&fc===true?"repeat-y":"no-repeat");n.needsUpdate=false}e(ma[n.id]);var p=n.offset.x/n.repeat.x,fc=n.offset.y/
|
|
|
+n.repeat.y,r=n.image.width*n.repeat.x,q=n.image.height*n.repeat.y,h=(h+p)*r,k=(1-k+fc)*q,c=c-a,d=d-b,f=f-a,g=g-b,i=(i+p)*r-h,j=(1-j+fc)*q-k,m=(m+p)*r-h,l=(1-l+fc)*q-k,p=i*l-m*j;if(p===0){if(Ga[n.id]===void 0){b=document.createElement("canvas");b.width=n.image.width;b.height=n.image.height;b=b.getContext("2d");b.drawImage(n.image,0,0);Ga[n.id]=b.getImageData(0,0,n.image.width,n.image.height).data}b=Ga[n.id];h=(Math.floor(h)+Math.floor(k)*n.image.width)*4;S.setRGB(b[h]/255,b[h+1]/255,b[h+2]/255);Hb(S)}else{p=
|
|
|
+1/p;n=(l*c-j*f)*p;j=(l*d-j*g)*p;c=(i*f-m*c)*p;d=(i*g-m*d)*p;a=a-n*h-c*k;h=b-j*h-d*k;o.save();o.transform(n,j,c,d,a,h);o.fill();o.restore()}}}function mc(a,b,c,d,e,f,g,h,k,i,j,m,l){var n,p;n=l.width-1;p=l.height-1;g=g*n;h=h*p;c=c-a;d=d-b;e=e-a;f=f-b;k=k*n-g;i=i*p-h;j=j*n-g;m=m*p-h;p=1/(k*m-j*i);n=(m*c-i*e)*p;i=(m*d-i*f)*p;c=(k*e-j*c)*p;d=(k*f-j*d)*p;a=a-n*g-c*h;b=b-i*g-d*h;o.save();o.transform(n,i,c,d,a,b);o.clip();o.drawImage(l,0,0);o.restore()}function Ic(a,b,c,d){var e=~~(a.r*255),f=~~(a.g*255),
|
|
|
+a=~~(a.b*255),g=~~(b.r*255),h=~~(b.g*255),b=~~(b.b*255),i=~~(c.r*255),j=~~(c.g*255),c=~~(c.b*255),m=~~(d.r*255),l=~~(d.g*255),d=~~(d.b*255);Va[0]=e<0?0:e>255?255:e;Va[1]=f<0?0:f>255?255:f;Va[2]=a<0?0:a>255?255:a;Va[4]=g<0?0:g>255?255:g;Va[5]=h<0?0:h>255?255:h;Va[6]=b<0?0:b>255?255:b;Va[8]=i<0?0:i>255?255:i;Va[9]=j<0?0:j>255?255:j;Va[10]=c<0?0:c>255?255:c;Va[12]=m<0?0:m>255?255:m;Va[13]=l<0?0:l>255?255:l;Va[14]=d<0?0:d>255?255:d;Ya.putImageData(Gb,0,0);pb.drawImage(k,0,0);return cb}function gc(a,b,
|
|
|
+c){a=(a-b)/(c-b);return a*a*(3-2*a)}function nc(a){a=(a+1)*0.5;return a<0?0:a>1?1:a}function Qb(a,b){var c=b.x-a.x,d=b.y-a.y,e=c*c+d*d;if(e!==0){e=1/Math.sqrt(e);c=c*e;d=d*e;b.x=b.x+c;b.y=b.y+d;a.x=a.x-c;a.y=a.y-d}}var Jc,ld,Ma,ib;this.autoClear===true?this.clear():o.setTransform(1,0,0,-1,p,r);f.info.render.vertices=0;f.info.render.faces=0;g=j.projectScene(a,l,this.sortElements);h=g.elements;i=g.lights;hb=i.length>0;hb===true&&m(i);Jc=0;for(ld=h.length;Jc<ld;Jc++){Ma=h[Jc];ib=Ma.material;ib=ib instanceof
|
|
|
+THREE.MeshFaceMaterial?Ma.faceMaterial:ib;if(!(ib===void 0||ib.visible===false)){Aa.empty();if(Ma instanceof THREE.RenderableParticle){u=Ma;u.x=u.x*p;u.y=u.y*r;q(u,Ma,ib,a)}else if(Ma instanceof THREE.RenderableLine){u=Ma.v1;G=Ma.v2;u.positionScreen.x=u.positionScreen.x*p;u.positionScreen.y=u.positionScreen.y*r;G.positionScreen.x=G.positionScreen.x*p;G.positionScreen.y=G.positionScreen.y*r;Aa.addPoint(u.positionScreen.x,u.positionScreen.y);Aa.addPoint(G.positionScreen.x,G.positionScreen.y);Ua.intersects(Aa)===
|
|
|
+true&&s(u,G,Ma,ib,a)}else if(Ma instanceof THREE.RenderableFace3){u=Ma.v1;G=Ma.v2;J=Ma.v3;u.positionScreen.x=u.positionScreen.x*p;u.positionScreen.y=u.positionScreen.y*r;G.positionScreen.x=G.positionScreen.x*p;G.positionScreen.y=G.positionScreen.y*r;J.positionScreen.x=J.positionScreen.x*p;J.positionScreen.y=J.positionScreen.y*r;if(ib.overdraw===true){Qb(u.positionScreen,G.positionScreen);Qb(G.positionScreen,J.positionScreen);Qb(J.positionScreen,u.positionScreen)}Aa.add3Points(u.positionScreen.x,u.positionScreen.y,
|
|
|
+G.positionScreen.x,G.positionScreen.y,J.positionScreen.x,J.positionScreen.y);Ua.intersects(Aa)===true&&t(u,G,J,0,1,2,Ma,ib,a)}else if(Ma instanceof THREE.RenderableFace4){u=Ma.v1;G=Ma.v2;J=Ma.v3;M=Ma.v4;u.positionScreen.x=u.positionScreen.x*p;u.positionScreen.y=u.positionScreen.y*r;G.positionScreen.x=G.positionScreen.x*p;G.positionScreen.y=G.positionScreen.y*r;J.positionScreen.x=J.positionScreen.x*p;J.positionScreen.y=J.positionScreen.y*r;M.positionScreen.x=M.positionScreen.x*p;M.positionScreen.y=
|
|
|
+M.positionScreen.y*r;O.positionScreen.copy(G.positionScreen);X.positionScreen.copy(M.positionScreen);if(ib.overdraw===true){Qb(u.positionScreen,G.positionScreen);Qb(G.positionScreen,M.positionScreen);Qb(M.positionScreen,u.positionScreen);Qb(J.positionScreen,O.positionScreen);Qb(J.positionScreen,X.positionScreen)}Aa.addPoint(u.positionScreen.x,u.positionScreen.y);Aa.addPoint(G.positionScreen.x,G.positionScreen.y);Aa.addPoint(J.positionScreen.x,J.positionScreen.y);Aa.addPoint(M.positionScreen.x,M.positionScreen.y);
|
|
|
+Ua.intersects(Aa)===true&&v(u,G,J,M,O,X,Ma,ib,a)}Da.addRectangle(Aa)}}o.setTransform(1,0,0,1,0,0)}};
|
|
|
THREE.ShaderChunk={fog_pars_fragment:"#ifdef USE_FOG\nuniform vec3 fogColor;\n#ifdef FOG_EXP2\nuniform float fogDensity;\n#else\nuniform float fogNear;\nuniform float fogFar;\n#endif\n#endif",fog_fragment:"#ifdef USE_FOG\nfloat depth = gl_FragCoord.z / gl_FragCoord.w;\n#ifdef FOG_EXP2\nconst float LOG2 = 1.442695;\nfloat fogFactor = exp2( - fogDensity * fogDensity * depth * depth * LOG2 );\nfogFactor = 1.0 - clamp( fogFactor, 0.0, 1.0 );\n#else\nfloat fogFactor = smoothstep( fogNear, fogFar, depth );\n#endif\ngl_FragColor = mix( gl_FragColor, vec4( fogColor, gl_FragColor.w ), fogFactor );\n#endif",envmap_pars_fragment:"#ifdef USE_ENVMAP\nvarying vec3 vReflect;\nuniform float reflectivity;\nuniform samplerCube envMap;\nuniform float flipEnvMap;\nuniform int combine;\n#endif",
|
|
|
envmap_fragment:"#ifdef USE_ENVMAP\n#ifdef DOUBLE_SIDED\nfloat flipNormal = ( -1.0 + 2.0 * float( gl_FrontFacing ) );\nvec4 cubeColor = textureCube( envMap, flipNormal * vec3( flipEnvMap * vReflect.x, vReflect.yz ) );\n#else\nvec4 cubeColor = textureCube( envMap, vec3( flipEnvMap * vReflect.x, vReflect.yz ) );\n#endif\n#ifdef GAMMA_INPUT\ncubeColor.xyz *= cubeColor.xyz;\n#endif\nif ( combine == 1 ) {\ngl_FragColor.xyz = mix( gl_FragColor.xyz, cubeColor.xyz, reflectivity );\n} else {\ngl_FragColor.xyz = gl_FragColor.xyz * cubeColor.xyz;\n}\n#endif",
|
|
|
envmap_pars_vertex:"#ifdef USE_ENVMAP\nvarying vec3 vReflect;\nuniform float refractionRatio;\nuniform bool useRefract;\n#endif",envmap_vertex:"#ifdef USE_ENVMAP\nvec4 mPosition = objectMatrix * vec4( position, 1.0 );\nvec3 nWorld = mat3( objectMatrix[ 0 ].xyz, objectMatrix[ 1 ].xyz, objectMatrix[ 2 ].xyz ) * normal;\nif ( useRefract ) {\nvReflect = refract( normalize( mPosition.xyz - cameraPosition ), normalize( nWorld.xyz ), refractionRatio );\n} else {\nvReflect = reflect( normalize( mPosition.xyz - cameraPosition ), normalize( nWorld.xyz ) );\n}\n#endif",
|