UNPKG

@arcgis/core

Version:

ArcGIS Maps SDK for JavaScript: A complete 2D and 3D mapping and data visualization API

84 lines (74 loc) 6 kB
/* All material copyright ESRI, All Rights Reserved, unless otherwise specified. See https://js.arcgis.com/4.33/esri/copyright.txt for details. */ import{maxElevationOffset as o}from"../../../collections/Component/Material/shader/ComponentData.glsl.js";import{NormalAttribute as e}from"../../../core/shaderLibrary/attributes/NormalAttribute.glsl.js";import{DoublePrecision as r}from"../../../core/shaderLibrary/util/DoublePrecision.glsl.js";import{RgbaFloatEncoding as t}from"../../../core/shaderLibrary/util/RgbaFloatEncoding.glsl.js";import{Float3DrawUniform as a}from"../../../core/shaderModules/Float3DrawUniform.js";import{Float3PassUniform as l}from"../../../core/shaderModules/Float3PassUniform.js";import{glsl as n}from"../../../core/shaderModules/glsl.js";import{Matrix3DrawUniform as d}from"../../../core/shaderModules/Matrix3DrawUniform.js";import{Matrix3PassUniform as m}from"../../../core/shaderModules/Matrix3PassUniform.js";import{Matrix4BindUniform as i}from"../../../core/shaderModules/Matrix4BindUniform.js";import{Texture2DDrawUniform as s}from"../../../core/shaderModules/Texture2DDrawUniform.js";import{VertexAttribute as c}from"../../../lib/VertexAttribute.js";function f(f,v){const{vertex:u}=f;u.include(t),f.include(e,v);const{silhouette:x,legacy:p,spherical:w}=v;u.uniforms.add(new s("componentDataTex",(o=>o.componentDataTexture))),f.attributes.add(c.COMPONENTINDEX,"float");const M=0,F=1,T=2,h=3,P=8,V=128;u.constants.add("lineWidthFractionFactor","float",8),u.constants.add("extensionLengthOffset","float",128),u.code.add(n` vec2 _componentTextureCoords(float componentIndex, float fieldOffset) { float fieldIndex = ${n.float(h)} * componentIndex + fieldOffset; float texSize = float(textureSize(componentDataTex, 0).x); float colIndex = mod(fieldIndex, texSize); float rowIndex = floor(fieldIndex / texSize); return vec2(colIndex, rowIndex) + 0.5; } struct ComponentData { vec4 color; vec3 normal; vec3 normal2; float lineWidth; float extensionLength; float type; float verticalOffset; }; ComponentData readComponentData() { vec2 colorIndex = _componentTextureCoords(componentIndex, ${n.float(M)}); vec2 otherIndex = _componentTextureCoords(componentIndex, ${n.float(F)}); vec2 verticalOffsetIndex = _componentTextureCoords(float(componentIndex), ${n.float(T)} ); vec3 normal = normalModel(); vec3 normal2 = ${x?n`decompressNormal(normal2Compressed)`:n`normal`}; vec4 colorValue = texelFetch(componentDataTex, ivec2(colorIndex), 0); vec4 otherValue = texelFetch(componentDataTex, ivec2(otherIndex), 0); float verticalOffset = uninterpolatedRGBAToFloat(texelFetch(componentDataTex, ivec2(verticalOffsetIndex), 0)) * ${n.float(o)}; return ComponentData( vec4(colorValue.rgb, colorValue.a * otherValue.w), // otherValue.w stores separate opacity normal, normal2, otherValue.x * (255.0 / ${n.float(P)} ), otherValue.y * 255.0 - ${n.float(V)}, -(otherValue.z * 255.0) + 0.5, // SOLID (=0/255) needs to be > 0.0, SKETCHY (=1/255) needs to be <= 0; verticalOffset ); } `),p?u.code.add(n`vec3 _modelToWorldNormal(vec3 normal) { return (model * vec4(normal, 0.0)).xyz; } vec3 _modelToViewNormal(vec3 normal) { return (localView * model * vec4(normal, 0.0)).xyz; }`):(u.uniforms.add(new d("transformNormalGlobalFromModel",(o=>o.transformNormalGlobalFromModel))),u.code.add(n`vec3 _modelToWorldNormal(vec3 normal) { return transformNormalGlobalFromModel * normal; }`)),x?(f.attributes.add(c.NORMAL2COMPRESSED,"vec2"),u.code.add(n`vec3 worldNormal(ComponentData data) { return _modelToWorldNormal(normalize(data.normal + data.normal2)); }`)):u.code.add(n`vec3 worldNormal(ComponentData data) { return _modelToWorldNormal(data.normal); }`),p?u.code.add(n`void worldAndViewFromModelPosition(vec3 modelPos, float verticalOffset, out vec3 worldPos, out vec3 viewPos) { worldPos = (model * vec4(modelPos, 1.0)).xyz; viewPos = (localView * vec4(worldPos, 1.0)).xyz; }`):(u.include(r,v),u.uniforms.add(new m("transformViewFromCameraRelativeRS",(o=>o.transformViewFromCameraRelativeRS)),new d("transformWorldFromModelRS",(o=>o.transformWorldFromModelRS)),new a("transformWorldFromModelTL",(o=>o.transformWorldFromModelTL)),new a("transformWorldFromModelTH",(o=>o.transformWorldFromModelTH)),new l("transformWorldFromViewTL",(o=>o.transformWorldFromViewTL)),new l("transformWorldFromViewTH",(o=>o.transformWorldFromViewTH))),u.code.add(n` void worldAndViewFromModelPosition(vec3 modelPos, float verticalOffset, out vec3 worldPos, out vec3 viewPos) { vec3 rotatedModelPosition = transformWorldFromModelRS * modelPos; vec3 transformCameraRelativeFromModel = dpAdd( transformWorldFromModelTL, transformWorldFromModelTH, -transformWorldFromViewTL, -transformWorldFromViewTH ); worldPos = transformCameraRelativeFromModel + rotatedModelPosition; if (verticalOffset != 0.0) { vec3 vUp = ${w?"normalize(transformWorldFromModelTL + rotatedModelPosition);":"vec3(0.0, 0.0, 1.0);"} worldPos += verticalOffset * vUp; } viewPos = transformViewFromCameraRelativeRS * worldPos; } `)),u.uniforms.add(new i("transformProjFromView",(o=>o.camera.projectionMatrix))).code.add(n`vec4 projFromViewPosition(vec3 position) { return transformProjFromView * vec4(position, 1.0); }`),u.code.add(n`float calculateExtensionLength(float extensionLength, float lineLength) { return extensionLength / (log2(max(1.0, 256.0 / lineLength)) * 0.2 + 1.0); }`)}function v(o){return o===u.Sketch||o===u.Mixed}var u,x;!function(o){o[o.Solid=0]="Solid",o[o.Sketch=1]="Sketch",o[o.Mixed=2]="Mixed",o[o.COUNT=3]="COUNT"}(u||(u={})),function(o){o[o.REGULAR=0]="REGULAR",o[o.SILHOUETTE=1]="SILHOUETTE"}(x||(x={}));export{x as EdgeSilhouette,u as EdgeType,f as EdgeUtil,v as usesSketchLogic};