| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849 | /*All material copyright ESRI, All Rights Reserved, unless otherwise specified.See https://js.arcgis.com/4.25/esri/copyright.txt for details.*/import{v as e}from"./mat4.js";import{c as i}from"./mat4f64.js";import{s as o}from"./vec2.js";import{a as r}from"./vec2f64.js";import{Laserline as a}from"../views/3d/webgl-engine/core/shaderLibrary/Laserline.glsl.js";import{Float2PassUniform as t}from"../views/3d/webgl-engine/core/shaderModules/Float2PassUniform.js";import{FloatPassUniform as s}from"../views/3d/webgl-engine/core/shaderModules/FloatPassUniform.js";import{glsl as n}from"../views/3d/webgl-engine/core/shaderModules/interfaces.js";import{Matrix4PassUniform as l}from"../views/3d/webgl-engine/core/shaderModules/Matrix4PassUniform.js";import{ShaderBuilder as d}from"../views/3d/webgl-engine/core/shaderModules/ShaderBuilder.js";import{VertexAttribute as c}from"../views/3d/webgl-engine/lib/VertexAttribute.js";function v(i){const r=new d;r.include(a,i);const{vertex:v,fragment:w}=r;return v.uniforms.add([new l("modelView",((i,o)=>e(m,o.camera.viewMatrix,i.origin))),new l("proj",((e,i)=>i.camera.projectionMatrix)),new s("glowWidth",((e,i)=>e.glowWidth*i.camera.pixelRatio)),new t("pixelToNDC",((e,i)=>o(p,2/i.camera.fullViewport[2],2/i.camera.fullViewport[3])))]),r.attributes.add(c.START,"vec3"),r.attributes.add(c.END,"vec3"),r.attributes.add(c.UP,"vec3"),r.attributes.add(c.EXTRUDE,"vec2"),r.varyings.add("uv","vec2"),r.varyings.add("vViewStart","vec3"),r.varyings.add("vViewEnd","vec3"),r.varyings.add("vViewPlane","vec4"),v.code.add(n`void main() {vec3 pos = mix(start, end, extrude.x);vec4 viewPos = modelView * vec4(pos, 1);vec4 projPos = proj * viewPos;vec2 ndcPos = projPos.xy / projPos.w;vec3 viewUp = (modelView * vec4(extrude.y * up, 0)).xyz;vec4 projPosUp = proj * vec4(viewPos.xyz + viewUp, 1);vec2 projExtrudeDir = normalize(projPosUp.xy / projPosUp.w - ndcPos);vec2 lxy = abs(sign(projExtrudeDir) - ndcPos);ndcPos += length(lxy) * projExtrudeDir;vec3 worldPlaneNormal = normalize(cross(up, normalize(end - start)));vec3 viewPlaneNormal = (modelView * vec4(worldPlaneNormal, 0)).xyz;vViewStart = (modelView * vec4(start, 1)).xyz;vViewEnd = (modelView * vec4(end, 1)).xyz;vViewPlane = vec4(viewPlaneNormal, -dot(viewPlaneNormal, vViewStart));float xPaddingPixels = sign(dot(viewPlaneNormal, viewPos.xyz)) * (extrude.x * 2.0 - 1.0) * glowWidth;ndcPos.x += xPaddingPixels * pixelToNDC.x;uv = ndcPos * 0.5 + 0.5;gl_Position = vec4(ndcPos, 0, 1);}`),w.uniforms.add(new s("perScreenPixelRatio",((e,i)=>i.camera.perScreenPixelRatio))),w.code.add(n`float planeDistancePixels(vec4 plane, vec3 pos, vec3 start, vec3 end) {vec3 origin = mix(start, end, 0.5);vec3 basis = end - origin;vec3 posAtOrigin = pos - origin;float x = dot(normalize(basis), posAtOrigin);float y = dot(plane.xyz, posAtOrigin);float dx = max(abs(x) - length(basis), 0.0);float dy = y;float dist = length(vec2(dx, dy));float width = fwidth(y);float maxPixelDistance = length(pos) * perScreenPixelRatio * 2.0;float pixelDist = dist / min(width, maxPixelDistance);return abs(pixelDist);}void main() {vec3 pos;vec3 normal;float depthDiscontinuityAlpha;if (!laserlineReconstructFromDepth(pos, normal, depthDiscontinuityAlpha)) {discard;}float distance = planeDistancePixels(vViewPlane, pos, vViewStart, vViewEnd);vec4 color = laserlineProfile(distance);float alpha = 1.0 - smoothstep(0.995, 0.999, abs(dot(normal, vViewPlane.xyz)));gl_FragColor = laserlineOutput(color * alpha * depthDiscontinuityAlpha);}`),r}const p=r(),m=i(),w=Object.freeze(Object.defineProperty({__proto__:null,build:v},Symbol.toStringTag,{value:"Module"}));export{w as L,v as b};
 |