@kepler.gl/deckgl-layers 3.2.6 → 3.3.0-alpha.0

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.
Files changed (55) hide show
  1. package/dist/3d-building-layer/3d-building-layer.d.ts +3 -3
  2. package/dist/3d-building-layer/3d-building-layer.js +9 -12
  3. package/dist/3d-building-layer/types.d.ts +8 -8
  4. package/dist/cluster-layer/cluster-layer.d.ts +16 -26
  5. package/dist/cluster-layer/cluster-layer.js +19 -30
  6. package/dist/column-layer/enhanced-column-layer.d.ts +4 -4
  7. package/dist/column-layer/enhanced-column-layer.js +39 -35
  8. package/dist/deckgl-extensions/filter-arrow-layer.d.ts +33 -6
  9. package/dist/deckgl-extensions/filter-arrow-layer.js +4 -12
  10. package/dist/deckgl-extensions/filter-shader-module.d.ts +32 -4
  11. package/dist/deckgl-extensions/filter-shader-module.js +3 -4
  12. package/dist/grid-layer/enhanced-cpu-grid-layer.d.ts +4906 -6
  13. package/dist/grid-layer/enhanced-cpu-grid-layer.js +46 -44
  14. package/dist/hexagon-layer/enhanced-hexagon-layer.d.ts +4903 -4
  15. package/dist/hexagon-layer/enhanced-hexagon-layer.js +61 -41
  16. package/dist/layer-utils/cpu-aggregator.d.ts +74 -27
  17. package/dist/layer-utils/cpu-aggregator.js +224 -19
  18. package/dist/line-layer/line-layer.d.ts +4 -4
  19. package/dist/line-layer/line-layer.js +29 -21
  20. package/dist/raster/images.d.ts +10 -3
  21. package/dist/raster/images.js +154 -60
  22. package/dist/raster/pipeline-validation-patch.d.ts +1 -0
  23. package/dist/raster/pipeline-validation-patch.js +60 -0
  24. package/dist/raster/raster-layer/raster-layer-shaders.d.ts +56 -0
  25. package/dist/raster/raster-layer/raster-layer-shaders.js +129 -0
  26. package/dist/raster/raster-layer/raster-layer.d.ts +6 -6
  27. package/dist/raster/raster-layer/raster-layer.js +100 -79
  28. package/dist/raster/raster-mesh-layer/matrix.d.ts +3 -1
  29. package/dist/raster/raster-mesh-layer/matrix.js +3 -3
  30. package/dist/raster/raster-mesh-layer/raster-mesh-layer-shaders.d.ts +19 -0
  31. package/dist/raster/raster-mesh-layer/raster-mesh-layer-shaders.js +38 -0
  32. package/dist/raster/raster-mesh-layer/raster-mesh-layer.d.ts +7 -6
  33. package/dist/raster/raster-mesh-layer/raster-mesh-layer.js +106 -81
  34. package/dist/raster/types.d.ts +8 -8
  35. package/dist/raster/types.js +1 -1
  36. package/dist/raster/webgl/color/colormap.js +13 -7
  37. package/dist/raster/webgl/color/filter.js +22 -12
  38. package/dist/raster/webgl/color/gamma-contrast.js +9 -3
  39. package/dist/raster/webgl/color/linear-rescale.js +9 -5
  40. package/dist/raster/webgl/color/saturation.js +7 -4
  41. package/dist/raster/webgl/color/sigmoidal-contrast.js +9 -5
  42. package/dist/raster/webgl/pansharpen/pansharpen-brovey.js +7 -4
  43. package/dist/raster/webgl/texture/combine-bands.js +1 -1
  44. package/dist/raster/webgl/texture/mask.js +27 -35
  45. package/dist/raster/webgl/texture/reorder-bands.js +8 -5
  46. package/dist/raster/webgl/texture/rgba-image.js +1 -1
  47. package/dist/raster/webgl/types.d.ts +11 -6
  48. package/dist/raster/webgl/types.js +1 -1
  49. package/dist/svg-icon-layer/scatterplot-icon-layer.d.ts +2 -4
  50. package/dist/svg-icon-layer/scatterplot-icon-layer.js +19 -25
  51. package/dist/svg-icon-layer/svg-icon-layer.d.ts +4 -6
  52. package/dist/svg-icon-layer/svg-icon-layer.js +5 -3
  53. package/dist/wms/wms-layer.d.ts +3 -3
  54. package/dist/wms/wms-layer.js +7 -7
  55. package/package.json +14 -13
@@ -0,0 +1,60 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.patchPipelineValidation = patchPipelineValidation;
7
+ var _webgl = require("@luma.gl/webgl");
8
+ // SPDX-License-Identifier: MIT
9
+ // Copyright contributors to the kepler.gl project
10
+
11
+ /**
12
+ * Patch luma.gl 9's WEBGLRenderPipeline to tolerate mixed-sampler-type
13
+ * validation errors in _getLinkStatus().
14
+ *
15
+ * WebGL2's validateProgram checks that sampler uniforms of different types
16
+ * (sampler2D, usampler2D, isampler2D) are not assigned to the same texture
17
+ * unit. Before any draw call the default texture unit for all samplers is 0,
18
+ * so programs that mix sampler types (e.g. raster band data as usampler2D +
19
+ * colormap as sampler2D) always fail validation even though the program linked
20
+ * successfully and will work correctly once texture units are assigned at draw
21
+ * time.
22
+ *
23
+ * luma.gl calls validateProgram inside _getLinkStatus() immediately after
24
+ * linkProgram, before any texture units can be assigned. This patch keeps the
25
+ * full validateProgram call but ignores only the known false-positive about
26
+ * mixed sampler types. All other validation errors are still reported.
27
+ */
28
+
29
+ // @ts-ignore WEBGLRenderPipeline resolution depends on moduleResolution setting
30
+
31
+ var MIXED_SAMPLER_RE = /different type[s]? use the same sampler location/i;
32
+ var _patched = false;
33
+ function patchPipelineValidation() {
34
+ var _WEBGLRenderPipeline$;
35
+ if (_patched) return;
36
+ _patched = true;
37
+ if (!(_webgl.WEBGLRenderPipeline !== null && _webgl.WEBGLRenderPipeline !== void 0 && (_WEBGLRenderPipeline$ = _webgl.WEBGLRenderPipeline.prototype) !== null && _WEBGLRenderPipeline$ !== void 0 && _WEBGLRenderPipeline$._getLinkStatus)) {
38
+ return;
39
+ }
40
+ _webgl.WEBGLRenderPipeline.prototype._getLinkStatus = function () {
41
+ var gl = this.device.gl;
42
+ var linked = gl.getProgramParameter(this.handle, 0x8b82 /* LINK_STATUS */);
43
+ if (!linked) {
44
+ this.linkStatus = 'error';
45
+ return 'link-error';
46
+ }
47
+ gl.validateProgram(this.handle);
48
+ var validated = gl.getProgramParameter(this.handle, 0x8b83 /* VALIDATE_STATUS */);
49
+ if (!validated) {
50
+ var infoLog = gl.getProgramInfoLog(this.handle) || '';
51
+ if (!MIXED_SAMPLER_RE.test(infoLog)) {
52
+ this.linkStatus = 'error';
53
+ return 'validation-error';
54
+ }
55
+ }
56
+ this.linkStatus = 'success';
57
+ return 'success';
58
+ };
59
+ }
60
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfd2ViZ2wiLCJyZXF1aXJlIiwiTUlYRURfU0FNUExFUl9SRSIsIl9wYXRjaGVkIiwicGF0Y2hQaXBlbGluZVZhbGlkYXRpb24iLCJfV0VCR0xSZW5kZXJQaXBlbGluZSQiLCJXRUJHTFJlbmRlclBpcGVsaW5lIiwicHJvdG90eXBlIiwiX2dldExpbmtTdGF0dXMiLCJnbCIsImRldmljZSIsImxpbmtlZCIsImdldFByb2dyYW1QYXJhbWV0ZXIiLCJoYW5kbGUiLCJsaW5rU3RhdHVzIiwidmFsaWRhdGVQcm9ncmFtIiwidmFsaWRhdGVkIiwiaW5mb0xvZyIsImdldFByb2dyYW1JbmZvTG9nIiwidGVzdCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9yYXN0ZXIvcGlwZWxpbmUtdmFsaWRhdGlvbi1wYXRjaC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvLyBTUERYLUxpY2Vuc2UtSWRlbnRpZmllcjogTUlUXG4vLyBDb3B5cmlnaHQgY29udHJpYnV0b3JzIHRvIHRoZSBrZXBsZXIuZ2wgcHJvamVjdFxuXG4vKipcbiAqIFBhdGNoIGx1bWEuZ2wgOSdzIFdFQkdMUmVuZGVyUGlwZWxpbmUgdG8gdG9sZXJhdGUgbWl4ZWQtc2FtcGxlci10eXBlXG4gKiB2YWxpZGF0aW9uIGVycm9ycyBpbiBfZ2V0TGlua1N0YXR1cygpLlxuICpcbiAqIFdlYkdMMidzIHZhbGlkYXRlUHJvZ3JhbSBjaGVja3MgdGhhdCBzYW1wbGVyIHVuaWZvcm1zIG9mIGRpZmZlcmVudCB0eXBlc1xuICogKHNhbXBsZXIyRCwgdXNhbXBsZXIyRCwgaXNhbXBsZXIyRCkgYXJlIG5vdCBhc3NpZ25lZCB0byB0aGUgc2FtZSB0ZXh0dXJlXG4gKiB1bml0LiBCZWZvcmUgYW55IGRyYXcgY2FsbCB0aGUgZGVmYXVsdCB0ZXh0dXJlIHVuaXQgZm9yIGFsbCBzYW1wbGVycyBpcyAwLFxuICogc28gcHJvZ3JhbXMgdGhhdCBtaXggc2FtcGxlciB0eXBlcyAoZS5nLiByYXN0ZXIgYmFuZCBkYXRhIGFzIHVzYW1wbGVyMkQgK1xuICogY29sb3JtYXAgYXMgc2FtcGxlcjJEKSBhbHdheXMgZmFpbCB2YWxpZGF0aW9uIGV2ZW4gdGhvdWdoIHRoZSBwcm9ncmFtIGxpbmtlZFxuICogc3VjY2Vzc2Z1bGx5IGFuZCB3aWxsIHdvcmsgY29ycmVjdGx5IG9uY2UgdGV4dHVyZSB1bml0cyBhcmUgYXNzaWduZWQgYXQgZHJhd1xuICogdGltZS5cbiAqXG4gKiBsdW1hLmdsIGNhbGxzIHZhbGlkYXRlUHJvZ3JhbSBpbnNpZGUgX2dldExpbmtTdGF0dXMoKSBpbW1lZGlhdGVseSBhZnRlclxuICogbGlua1Byb2dyYW0sIGJlZm9yZSBhbnkgdGV4dHVyZSB1bml0cyBjYW4gYmUgYXNzaWduZWQuIFRoaXMgcGF0Y2gga2VlcHMgdGhlXG4gKiBmdWxsIHZhbGlkYXRlUHJvZ3JhbSBjYWxsIGJ1dCBpZ25vcmVzIG9ubHkgdGhlIGtub3duIGZhbHNlLXBvc2l0aXZlIGFib3V0XG4gKiBtaXhlZCBzYW1wbGVyIHR5cGVzLiBBbGwgb3RoZXIgdmFsaWRhdGlvbiBlcnJvcnMgYXJlIHN0aWxsIHJlcG9ydGVkLlxuICovXG5cbi8vIEB0cy1pZ25vcmUgV0VCR0xSZW5kZXJQaXBlbGluZSByZXNvbHV0aW9uIGRlcGVuZHMgb24gbW9kdWxlUmVzb2x1dGlvbiBzZXR0aW5nXG5pbXBvcnQge1dFQkdMUmVuZGVyUGlwZWxpbmV9IGZyb20gJ0BsdW1hLmdsL3dlYmdsJztcblxuY29uc3QgTUlYRURfU0FNUExFUl9SRSA9IC9kaWZmZXJlbnQgdHlwZVtzXT8gdXNlIHRoZSBzYW1lIHNhbXBsZXIgbG9jYXRpb24vaTtcblxubGV0IF9wYXRjaGVkID0gZmFsc2U7XG5cbmV4cG9ydCBmdW5jdGlvbiBwYXRjaFBpcGVsaW5lVmFsaWRhdGlvbigpOiB2b2lkIHtcbiAgaWYgKF9wYXRjaGVkKSByZXR1cm47XG4gIF9wYXRjaGVkID0gdHJ1ZTtcblxuICBpZiAoIVdFQkdMUmVuZGVyUGlwZWxpbmU/LnByb3RvdHlwZT8uX2dldExpbmtTdGF0dXMpIHtcbiAgICByZXR1cm47XG4gIH1cblxuICBXRUJHTFJlbmRlclBpcGVsaW5lLnByb3RvdHlwZS5fZ2V0TGlua1N0YXR1cyA9IGZ1bmN0aW9uIChcbiAgICB0aGlzOiBXRUJHTFJlbmRlclBpcGVsaW5lICYge2xpbmtTdGF0dXM6IHN0cmluZ31cbiAgKSB7XG4gICAgY29uc3Qge2dsfSA9IHRoaXMuZGV2aWNlO1xuICAgIGNvbnN0IGxpbmtlZCA9IGdsLmdldFByb2dyYW1QYXJhbWV0ZXIodGhpcy5oYW5kbGUsIDB4OGI4MiAvKiBMSU5LX1NUQVRVUyAqLyk7XG4gICAgaWYgKCFsaW5rZWQpIHtcbiAgICAgIHRoaXMubGlua1N0YXR1cyA9ICdlcnJvcic7XG4gICAgICByZXR1cm4gJ2xpbmstZXJyb3InO1xuICAgIH1cblxuICAgIGdsLnZhbGlkYXRlUHJvZ3JhbSh0aGlzLmhhbmRsZSk7XG4gICAgY29uc3QgdmFsaWRhdGVkID0gZ2wuZ2V0UHJvZ3JhbVBhcmFtZXRlcih0aGlzLmhhbmRsZSwgMHg4YjgzIC8qIFZBTElEQVRFX1NUQVRVUyAqLyk7XG4gICAgaWYgKCF2YWxpZGF0ZWQpIHtcbiAgICAgIGNvbnN0IGluZm9Mb2cgPSBnbC5nZXRQcm9ncmFtSW5mb0xvZyh0aGlzLmhhbmRsZSkgfHwgJyc7XG4gICAgICBpZiAoIU1JWEVEX1NBTVBMRVJfUkUudGVzdChpbmZvTG9nKSkge1xuICAgICAgICB0aGlzLmxpbmtTdGF0dXMgPSAnZXJyb3InO1xuICAgICAgICByZXR1cm4gJ3ZhbGlkYXRpb24tZXJyb3InO1xuICAgICAgfVxuICAgIH1cblxuICAgIHRoaXMubGlua1N0YXR1cyA9ICdzdWNjZXNzJztcbiAgICByZXR1cm4gJ3N1Y2Nlc3MnO1xuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFzQkEsSUFBQUEsTUFBQSxHQUFBQyxPQUFBO0FBdEJBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFHQSxJQUFNQyxnQkFBZ0IsR0FBRyxtREFBbUQ7QUFFNUUsSUFBSUMsUUFBUSxHQUFHLEtBQUs7QUFFYixTQUFTQyx1QkFBdUJBLENBQUEsRUFBUztFQUFBLElBQUFDLHFCQUFBO0VBQzlDLElBQUlGLFFBQVEsRUFBRTtFQUNkQSxRQUFRLEdBQUcsSUFBSTtFQUVmLElBQUksRUFBQ0csMEJBQW1CLGFBQW5CQSwwQkFBbUIsZ0JBQUFELHFCQUFBLEdBQW5CQywwQkFBbUIsQ0FBRUMsU0FBUyxjQUFBRixxQkFBQSxlQUE5QkEscUJBQUEsQ0FBZ0NHLGNBQWMsR0FBRTtJQUNuRDtFQUNGO0VBRUFGLDBCQUFtQixDQUFDQyxTQUFTLENBQUNDLGNBQWMsR0FBRyxZQUU3QztJQUNBLElBQU9DLEVBQUUsR0FBSSxJQUFJLENBQUNDLE1BQU0sQ0FBakJELEVBQUU7SUFDVCxJQUFNRSxNQUFNLEdBQUdGLEVBQUUsQ0FBQ0csbUJBQW1CLENBQUMsSUFBSSxDQUFDQyxNQUFNLEVBQUUsTUFBTSxDQUFDLGlCQUFpQixDQUFDO0lBQzVFLElBQUksQ0FBQ0YsTUFBTSxFQUFFO01BQ1gsSUFBSSxDQUFDRyxVQUFVLEdBQUcsT0FBTztNQUN6QixPQUFPLFlBQVk7SUFDckI7SUFFQUwsRUFBRSxDQUFDTSxlQUFlLENBQUMsSUFBSSxDQUFDRixNQUFNLENBQUM7SUFDL0IsSUFBTUcsU0FBUyxHQUFHUCxFQUFFLENBQUNHLG1CQUFtQixDQUFDLElBQUksQ0FBQ0MsTUFBTSxFQUFFLE1BQU0sQ0FBQyxxQkFBcUIsQ0FBQztJQUNuRixJQUFJLENBQUNHLFNBQVMsRUFBRTtNQUNkLElBQU1DLE9BQU8sR0FBR1IsRUFBRSxDQUFDUyxpQkFBaUIsQ0FBQyxJQUFJLENBQUNMLE1BQU0sQ0FBQyxJQUFJLEVBQUU7TUFDdkQsSUFBSSxDQUFDWCxnQkFBZ0IsQ0FBQ2lCLElBQUksQ0FBQ0YsT0FBTyxDQUFDLEVBQUU7UUFDbkMsSUFBSSxDQUFDSCxVQUFVLEdBQUcsT0FBTztRQUN6QixPQUFPLGtCQUFrQjtNQUMzQjtJQUNGO0lBRUEsSUFBSSxDQUFDQSxVQUFVLEdBQUcsU0FBUztJQUMzQixPQUFPLFNBQVM7RUFDbEIsQ0FBQztBQUNIIiwiaWdub3JlTGlzdCI6W119
@@ -0,0 +1,56 @@
1
+ import type { ShaderModule as LumaShaderModule } from '../webgl/types';
2
+ export declare const rasterUniforms: {
3
+ name: string;
4
+ vs: string;
5
+ fs: string;
6
+ uniformTypes: {
7
+ bounds: string;
8
+ coordinateConversion: string;
9
+ desaturate: string;
10
+ opacity: string;
11
+ tintColor: string;
12
+ transparentColor: string;
13
+ };
14
+ };
15
+ /**
16
+ * Register custom DECKGL_CREATE_COLOR and DECKGL_MUTATE_COLOR shader hooks
17
+ * with the default ShaderAssembler. These hooks are used by the raster layer's
18
+ * custom shader modules (rgbaImage, combineBands, colormap, etc.).
19
+ *
20
+ * In luma.gl 8.x these were registered via ProgramManager; in luma.gl 9.x
21
+ * we register them with the ShaderAssembler singleton.
22
+ *
23
+ * NOTE: We must check the assembler's hook list every time rather than using
24
+ * a module-level boolean guard, because deck.gl's getShaderAssembler() clears
25
+ * _hookFunctions when a new Deck instance is created (e.g. during image export).
26
+ */
27
+ export declare function ensureRasterHooksRegistered(): void;
28
+ /**
29
+ * Convert kepler.gl's custom raster shader modules into luma.gl 9 compatible
30
+ * format. Ensures fs2 (WebGL2) shaders are used and texture2D -> texture.
31
+ */
32
+ interface LumaModuleOutput {
33
+ name: string;
34
+ fs: string;
35
+ vs?: string;
36
+ defines?: Record<string, string>;
37
+ getUniforms?: (opts: object) => Record<string, unknown> | null;
38
+ uniforms?: Record<string, unknown>;
39
+ uniformTypes?: Record<string, string>;
40
+ inject?: Record<string, string>;
41
+ dependencies?: unknown[];
42
+ deprecations?: unknown[];
43
+ }
44
+ export declare function prepareLumaModules(modules: LumaShaderModule[]): LumaModuleOutput[];
45
+ /**
46
+ * Build the vertex shader for the raster layer.
47
+ * References raster.coordinateConversion from the UBO.
48
+ */
49
+ export declare function buildRasterVertexShader(): string;
50
+ /**
51
+ * Build the fragment shader for the raster layer.
52
+ * Uses DECKGL_CREATE_COLOR and DECKGL_MUTATE_COLOR hooks which are now
53
+ * registered with the ShaderAssembler and populated by module injections.
54
+ */
55
+ export declare function buildRasterFragmentShader(): string;
56
+ export {};
@@ -0,0 +1,129 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.buildRasterFragmentShader = buildRasterFragmentShader;
8
+ exports.buildRasterVertexShader = buildRasterVertexShader;
9
+ exports.ensureRasterHooksRegistered = ensureRasterHooksRegistered;
10
+ exports.prepareLumaModules = prepareLumaModules;
11
+ exports.rasterUniforms = void 0;
12
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
13
+ var _shadertools = require("@luma.gl/shadertools");
14
+ // SPDX-License-Identifier: MIT
15
+ // Copyright contributors to the kepler.gl project
16
+
17
+ /**
18
+ * UBO-based shader module for raster layer uniforms.
19
+ * Replaces the old standalone `uniform float desaturate` etc.
20
+ */
21
+ var rasterUniformBlock = "uniform rasterUniforms {\n vec4 bounds;\n float coordinateConversion;\n float desaturate;\n float opacity;\n vec3 tintColor;\n vec4 transparentColor;\n} raster;\n";
22
+ var rasterUniforms = exports.rasterUniforms = {
23
+ name: 'raster',
24
+ vs: rasterUniformBlock,
25
+ fs: rasterUniformBlock,
26
+ uniformTypes: {
27
+ bounds: 'vec4<f32>',
28
+ coordinateConversion: 'f32',
29
+ desaturate: 'f32',
30
+ opacity: 'f32',
31
+ tintColor: 'vec3<f32>',
32
+ transparentColor: 'vec4<f32>'
33
+ }
34
+ };
35
+
36
+ /**
37
+ * Register custom DECKGL_CREATE_COLOR and DECKGL_MUTATE_COLOR shader hooks
38
+ * with the default ShaderAssembler. These hooks are used by the raster layer's
39
+ * custom shader modules (rgbaImage, combineBands, colormap, etc.).
40
+ *
41
+ * In luma.gl 8.x these were registered via ProgramManager; in luma.gl 9.x
42
+ * we register them with the ShaderAssembler singleton.
43
+ *
44
+ * NOTE: We must check the assembler's hook list every time rather than using
45
+ * a module-level boolean guard, because deck.gl's getShaderAssembler() clears
46
+ * _hookFunctions when a new Deck instance is created (e.g. during image export).
47
+ */
48
+ function ensureRasterHooksRegistered() {
49
+ var assembler = _shadertools.ShaderAssembler.getDefaultShaderAssembler();
50
+ // @ts-expect-error _hookFunctions is private in ShaderAssembler
51
+ var existingHooks = assembler._hookFunctions || [];
52
+ var hookNames = existingHooks.map(function (h) {
53
+ return typeof h === 'string' ? h : h.hook;
54
+ });
55
+ if (!hookNames.some(function (h) {
56
+ return h === null || h === void 0 ? void 0 : h.includes('DECKGL_CREATE_COLOR');
57
+ })) {
58
+ assembler.addShaderHook('fs:DECKGL_CREATE_COLOR(inout vec4 image, vec2 coord)');
59
+ }
60
+ if (!hookNames.some(function (h) {
61
+ return h === null || h === void 0 ? void 0 : h.includes('DECKGL_MUTATE_COLOR');
62
+ })) {
63
+ assembler.addShaderHook('fs:DECKGL_MUTATE_COLOR(inout vec4 image, vec2 coord)');
64
+ }
65
+ }
66
+
67
+ /**
68
+ * Convert kepler.gl's custom raster shader modules into luma.gl 9 compatible
69
+ * format. Ensures fs2 (WebGL2) shaders are used and texture2D -> texture.
70
+ */
71
+
72
+ function prepareLumaModules(modules) {
73
+ return modules.map(function (mod) {
74
+ var fs = mod.fs2 || mod.fs || '';
75
+ var result = {
76
+ name: mod.name,
77
+ // Replace texture2D with texture for GLSL 300 es
78
+ fs: fs.replace(/texture2D\(/g, 'texture('),
79
+ dependencies: mod.dependencies,
80
+ deprecations: mod.deprecations
81
+ };
82
+ if (mod.vs) {
83
+ result.vs = mod.vs.replace(/texture2D\(/g, 'texture(');
84
+ }
85
+ if (mod.defines) {
86
+ result.defines = mod.defines;
87
+ }
88
+ if (mod.getUniforms) {
89
+ result.getUniforms = mod.getUniforms;
90
+ }
91
+ if (mod.uniforms) {
92
+ result.uniforms = mod.uniforms;
93
+ }
94
+ if (mod.uniformTypes) {
95
+ result.uniformTypes = mod.uniformTypes;
96
+ }
97
+
98
+ // Convert inject code, replacing texture2D -> texture
99
+ if (mod.inject) {
100
+ result.inject = {};
101
+ for (var _i = 0, _Object$entries = Object.entries(mod.inject); _i < _Object$entries.length; _i++) {
102
+ var _Object$entries$_i = (0, _slicedToArray2["default"])(_Object$entries[_i], 2),
103
+ hook = _Object$entries$_i[0],
104
+ code = _Object$entries$_i[1];
105
+ var codeStr = typeof code === 'string' ? code : code.injection || '';
106
+ result.inject[hook] = codeStr.replace(/texture2D\(/g, 'texture(');
107
+ }
108
+ }
109
+ return result;
110
+ });
111
+ }
112
+
113
+ /**
114
+ * Build the vertex shader for the raster layer.
115
+ * References raster.coordinateConversion from the UBO.
116
+ */
117
+ function buildRasterVertexShader() {
118
+ return "#version 300 es\n#define SHADER_NAME raster-layer-vertex-shader\n\nprecision mediump float;\n\nin vec2 texCoords;\nin vec3 positions;\nin vec3 positions64Low;\n\nout vec2 vTexCoord;\nout vec2 vTexPos;\n\nconst vec3 pickingColor = vec3(1.0, 0.0, 0.0);\n\nvoid main(void) {\n geometry.worldPosition = positions;\n geometry.uv = texCoords;\n geometry.pickingColor = pickingColor;\n\n gl_Position = project_position_to_clipspace(positions, positions64Low, vec3(0.0), geometry.position);\n DECKGL_FILTER_GL_POSITION(gl_Position, geometry);\n\n vTexCoord = texCoords;\n\n if (raster.coordinateConversion < -0.5) {\n vTexPos = geometry.position.xy + project.commonOrigin.xy;\n } else if (raster.coordinateConversion > 0.5) {\n vTexPos = geometry.worldPosition.xy;\n }\n\n vec4 color = vec4(0.0);\n DECKGL_FILTER_COLOR(color, geometry);\n}\n";
119
+ }
120
+
121
+ /**
122
+ * Build the fragment shader for the raster layer.
123
+ * Uses DECKGL_CREATE_COLOR and DECKGL_MUTATE_COLOR hooks which are now
124
+ * registered with the ShaderAssembler and populated by module injections.
125
+ */
126
+ function buildRasterFragmentShader() {
127
+ return "#version 300 es\n#define SHADER_NAME raster-layer-fragment-shader\n\nprecision mediump float;\nprecision mediump int;\nprecision mediump usampler2D;\n\nin vec2 vTexCoord;\nin vec2 vTexPos;\n\nout vec4 fragColor;\n\n/* projection utils */\nconst float TILE_SIZE = 512.0;\nconst float PI = 3.1415926536;\nconst float WORLD_SCALE = TILE_SIZE / PI / 2.0;\n\nvec2 lnglat_to_mercator(vec2 lnglat) {\n float x = lnglat.x;\n float y = clamp(lnglat.y, -89.9, 89.9);\n return vec2(\n radians(x) + PI,\n PI + log(tan(PI * 0.25 + radians(y) * 0.5))\n ) * WORLD_SCALE;\n}\n\nvec2 mercator_to_lnglat(vec2 xy) {\n xy /= WORLD_SCALE;\n return degrees(vec2(\n xy.x - PI,\n atan(exp(xy.y - PI)) * 2.0 - PI * 0.5\n ));\n}\n\nvec3 color_desaturate(vec3 color) {\n float luminance = (color.r + color.g + color.b) * 0.333333333;\n return mix(color, vec3(luminance), raster.desaturate);\n}\n\nvec3 color_tint(vec3 color) {\n return color * raster.tintColor;\n}\n\nvec4 apply_opacity(vec3 color, float alpha) {\n if (raster.transparentColor.a == 0.0) {\n return vec4(color, alpha);\n }\n float blendedAlpha = alpha + raster.transparentColor.a * (1.0 - alpha);\n float highLightRatio = alpha / blendedAlpha;\n vec3 blendedRGB = mix(raster.transparentColor.rgb, color, highLightRatio);\n return vec4(blendedRGB, blendedAlpha);\n}\n\nvec2 getUV(vec2 pos) {\n return vec2(\n (pos.x - raster.bounds[0]) / (raster.bounds[2] - raster.bounds[0]),\n (pos.y - raster.bounds[3]) / (raster.bounds[1] - raster.bounds[3])\n );\n}\n\nvoid main(void) {\n vec2 uv = vTexCoord;\n if (raster.coordinateConversion < -0.5) {\n vec2 lnglat = mercator_to_lnglat(vTexPos);\n uv = getUV(lnglat);\n } else if (raster.coordinateConversion > 0.5) {\n vec2 commonPos = lnglat_to_mercator(vTexPos);\n uv = getUV(commonPos);\n }\n\n vec4 image = vec4(0.0);\n DECKGL_CREATE_COLOR(image, uv);\n\n DECKGL_MUTATE_COLOR(image, uv);\n\n fragColor = apply_opacity(color_tint(color_desaturate(image.rgb)), raster.opacity);\n\n geometry.uv = uv;\n DECKGL_FILTER_COLOR(fragColor, geometry);\n}\n";
128
+ }
129
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_shadertools","require","rasterUniformBlock","rasterUniforms","exports","name","vs","fs","uniformTypes","bounds","coordinateConversion","desaturate","opacity","tintColor","transparentColor","ensureRasterHooksRegistered","assembler","ShaderAssembler","getDefaultShaderAssembler","existingHooks","_hookFunctions","hookNames","map","h","hook","some","includes","addShaderHook","prepareLumaModules","modules","mod","fs2","result","replace","dependencies","deprecations","defines","getUniforms","uniforms","inject","_i","_Object$entries","Object","entries","length","_Object$entries$_i","_slicedToArray2","code","codeStr","injection","buildRasterVertexShader","buildRasterFragmentShader"],"sources":["../../../src/raster/raster-layer/raster-layer-shaders.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {ShaderAssembler} from '@luma.gl/shadertools';\nimport type {ShaderModule as LumaShaderModule} from '../webgl/types';\n\n/**\n * UBO-based shader module for raster layer uniforms.\n * Replaces the old standalone `uniform float desaturate` etc.\n */\nconst rasterUniformBlock = `\\\nuniform rasterUniforms {\n  vec4 bounds;\n  float coordinateConversion;\n  float desaturate;\n  float opacity;\n  vec3 tintColor;\n  vec4 transparentColor;\n} raster;\n`;\n\nexport const rasterUniforms = {\n  name: 'raster',\n  vs: rasterUniformBlock,\n  fs: rasterUniformBlock,\n  uniformTypes: {\n    bounds: 'vec4<f32>',\n    coordinateConversion: 'f32',\n    desaturate: 'f32',\n    opacity: 'f32',\n    tintColor: 'vec3<f32>',\n    transparentColor: 'vec4<f32>'\n  }\n};\n\n/**\n * Register custom DECKGL_CREATE_COLOR and DECKGL_MUTATE_COLOR shader hooks\n * with the default ShaderAssembler. These hooks are used by the raster layer's\n * custom shader modules (rgbaImage, combineBands, colormap, etc.).\n *\n * In luma.gl 8.x these were registered via ProgramManager; in luma.gl 9.x\n * we register them with the ShaderAssembler singleton.\n *\n * NOTE: We must check the assembler's hook list every time rather than using\n * a module-level boolean guard, because deck.gl's getShaderAssembler() clears\n * _hookFunctions when a new Deck instance is created (e.g. during image export).\n */\nexport function ensureRasterHooksRegistered(): void {\n  const assembler = ShaderAssembler.getDefaultShaderAssembler();\n  // @ts-expect-error _hookFunctions is private in ShaderAssembler\n  const existingHooks = assembler._hookFunctions || [];\n  const hookNames = existingHooks.map(h => (typeof h === 'string' ? h : h.hook));\n\n  if (!hookNames.some(h => h?.includes('DECKGL_CREATE_COLOR'))) {\n    assembler.addShaderHook('fs:DECKGL_CREATE_COLOR(inout vec4 image, vec2 coord)');\n  }\n  if (!hookNames.some(h => h?.includes('DECKGL_MUTATE_COLOR'))) {\n    assembler.addShaderHook('fs:DECKGL_MUTATE_COLOR(inout vec4 image, vec2 coord)');\n  }\n}\n\n/**\n * Convert kepler.gl's custom raster shader modules into luma.gl 9 compatible\n * format. Ensures fs2 (WebGL2) shaders are used and texture2D -> texture.\n */\ninterface LumaModuleOutput {\n  name: string;\n  fs: string;\n  vs?: string;\n  defines?: Record<string, string>;\n  getUniforms?: (opts: object) => Record<string, unknown> | null;\n  uniforms?: Record<string, unknown>;\n  uniformTypes?: Record<string, string>;\n  inject?: Record<string, string>;\n  dependencies?: unknown[];\n  deprecations?: unknown[];\n}\n\nexport function prepareLumaModules(modules: LumaShaderModule[]): LumaModuleOutput[] {\n  return modules.map(mod => {\n    const fs = mod.fs2 || mod.fs || '';\n    const result: LumaModuleOutput = {\n      name: mod.name,\n      // Replace texture2D with texture for GLSL 300 es\n      fs: fs.replace(/texture2D\\(/g, 'texture('),\n      dependencies: mod.dependencies,\n      deprecations: mod.deprecations\n    };\n\n    if (mod.vs) {\n      result.vs = mod.vs.replace(/texture2D\\(/g, 'texture(');\n    }\n\n    if (mod.defines) {\n      result.defines = mod.defines;\n    }\n\n    if (mod.getUniforms) {\n      result.getUniforms = mod.getUniforms;\n    }\n\n    if (mod.uniforms) {\n      result.uniforms = mod.uniforms;\n    }\n\n    if (mod.uniformTypes) {\n      result.uniformTypes = mod.uniformTypes;\n    }\n\n    // Convert inject code, replacing texture2D -> texture\n    if (mod.inject) {\n      result.inject = {};\n      for (const [hook, code] of Object.entries(mod.inject)) {\n        const codeStr =\n          typeof code === 'string' ? code : (code as {injection?: string}).injection || '';\n        result.inject[hook] = codeStr.replace(/texture2D\\(/g, 'texture(');\n      }\n    }\n\n    return result;\n  });\n}\n\n/**\n * Build the vertex shader for the raster layer.\n * References raster.coordinateConversion from the UBO.\n */\nexport function buildRasterVertexShader(): string {\n  return `\\\n#version 300 es\n#define SHADER_NAME raster-layer-vertex-shader\n\nprecision mediump float;\n\nin vec2 texCoords;\nin vec3 positions;\nin vec3 positions64Low;\n\nout vec2 vTexCoord;\nout vec2 vTexPos;\n\nconst vec3 pickingColor = vec3(1.0, 0.0, 0.0);\n\nvoid main(void) {\n  geometry.worldPosition = positions;\n  geometry.uv = texCoords;\n  geometry.pickingColor = pickingColor;\n\n  gl_Position = project_position_to_clipspace(positions, positions64Low, vec3(0.0), geometry.position);\n  DECKGL_FILTER_GL_POSITION(gl_Position, geometry);\n\n  vTexCoord = texCoords;\n\n  if (raster.coordinateConversion < -0.5) {\n    vTexPos = geometry.position.xy + project.commonOrigin.xy;\n  } else if (raster.coordinateConversion > 0.5) {\n    vTexPos = geometry.worldPosition.xy;\n  }\n\n  vec4 color = vec4(0.0);\n  DECKGL_FILTER_COLOR(color, geometry);\n}\n`;\n}\n\n/**\n * Build the fragment shader for the raster layer.\n * Uses DECKGL_CREATE_COLOR and DECKGL_MUTATE_COLOR hooks which are now\n * registered with the ShaderAssembler and populated by module injections.\n */\nexport function buildRasterFragmentShader(): string {\n  return `\\\n#version 300 es\n#define SHADER_NAME raster-layer-fragment-shader\n\nprecision mediump float;\nprecision mediump int;\nprecision mediump usampler2D;\n\nin vec2 vTexCoord;\nin vec2 vTexPos;\n\nout vec4 fragColor;\n\n/* projection utils */\nconst float TILE_SIZE = 512.0;\nconst float PI = 3.1415926536;\nconst float WORLD_SCALE = TILE_SIZE / PI / 2.0;\n\nvec2 lnglat_to_mercator(vec2 lnglat) {\n  float x = lnglat.x;\n  float y = clamp(lnglat.y, -89.9, 89.9);\n  return vec2(\n    radians(x) + PI,\n    PI + log(tan(PI * 0.25 + radians(y) * 0.5))\n  ) * WORLD_SCALE;\n}\n\nvec2 mercator_to_lnglat(vec2 xy) {\n  xy /= WORLD_SCALE;\n  return degrees(vec2(\n    xy.x - PI,\n    atan(exp(xy.y - PI)) * 2.0 - PI * 0.5\n  ));\n}\n\nvec3 color_desaturate(vec3 color) {\n  float luminance = (color.r + color.g + color.b) * 0.333333333;\n  return mix(color, vec3(luminance), raster.desaturate);\n}\n\nvec3 color_tint(vec3 color) {\n  return color * raster.tintColor;\n}\n\nvec4 apply_opacity(vec3 color, float alpha) {\n  if (raster.transparentColor.a == 0.0) {\n    return vec4(color, alpha);\n  }\n  float blendedAlpha = alpha + raster.transparentColor.a * (1.0 - alpha);\n  float highLightRatio = alpha / blendedAlpha;\n  vec3 blendedRGB = mix(raster.transparentColor.rgb, color, highLightRatio);\n  return vec4(blendedRGB, blendedAlpha);\n}\n\nvec2 getUV(vec2 pos) {\n  return vec2(\n    (pos.x - raster.bounds[0]) / (raster.bounds[2] - raster.bounds[0]),\n    (pos.y - raster.bounds[3]) / (raster.bounds[1] - raster.bounds[3])\n  );\n}\n\nvoid main(void) {\n  vec2 uv = vTexCoord;\n  if (raster.coordinateConversion < -0.5) {\n    vec2 lnglat = mercator_to_lnglat(vTexPos);\n    uv = getUV(lnglat);\n  } else if (raster.coordinateConversion > 0.5) {\n    vec2 commonPos = lnglat_to_mercator(vTexPos);\n    uv = getUV(commonPos);\n  }\n\n  vec4 image = vec4(0.0);\n  DECKGL_CREATE_COLOR(image, uv);\n\n  DECKGL_MUTATE_COLOR(image, uv);\n\n  fragColor = apply_opacity(color_tint(color_desaturate(image.rgb)), raster.opacity);\n\n  geometry.uv = uv;\n  DECKGL_FILTER_COLOR(fragColor, geometry);\n}\n`;\n}\n"],"mappings":"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","ignoreList":[]}
@@ -1,16 +1,16 @@
1
- import { UpdateParameters } from '@deck.gl/core/typed';
2
- import { BitmapLayer } from '@deck.gl/layers/typed';
1
+ import { UpdateParameters } from '@deck.gl/core';
2
+ import { BitmapLayer } from '@deck.gl/layers';
3
3
  import type { RasterLayerAddedProps, ImageState } from '../types';
4
4
  export default class RasterLayer extends BitmapLayer<RasterLayerAddedProps> {
5
5
  state: BitmapLayer<RasterLayerAddedProps>['state'] & {
6
6
  images: ImageState;
7
7
  };
8
+ _redrawScheduled: boolean;
8
9
  initializeState(): void;
9
- draw({ uniforms }: {
10
- uniforms: {
11
- [key: string]: any;
12
- };
10
+ draw(_opts: {
11
+ shaderModuleProps: Record<string, unknown>;
13
12
  }): void;
13
+ _scheduleRedraw(): void;
14
14
  getShaders(): any;
15
15
  updateState(params: UpdateParameters<BitmapLayer<RasterLayerAddedProps>>): void;
16
16
  updateImages({ props, oldProps }: {