@deck.gl-community/editable-layers 9.0.0-alpha.1 → 9.0.2
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.
- package/LICENSE +19 -0
- package/README.md +2 -81
- package/dist/constants.js +4 -1
- package/dist/edit-modes/composite-mode.d.ts +1 -1
- package/dist/edit-modes/composite-mode.js +4 -1
- package/dist/edit-modes/draw-90degree-polygon-mode.d.ts +1 -1
- package/dist/edit-modes/draw-90degree-polygon-mode.js +29 -24
- package/dist/edit-modes/draw-circle-by-diameter-mode.d.ts +1 -1
- package/dist/edit-modes/draw-circle-by-diameter-mode.js +7 -4
- package/dist/edit-modes/draw-circle-from-center-mode.d.ts +1 -1
- package/dist/edit-modes/draw-circle-from-center-mode.js +7 -4
- package/dist/edit-modes/draw-ellipse-by-bounding-box-mode.d.ts +1 -1
- package/dist/edit-modes/draw-ellipse-by-bounding-box-mode.js +3 -0
- package/dist/edit-modes/draw-ellipse-using-three-points-mode.d.ts +1 -1
- package/dist/edit-modes/draw-ellipse-using-three-points-mode.js +3 -0
- package/dist/edit-modes/draw-line-string-mode.d.ts +1 -1
- package/dist/edit-modes/draw-line-string-mode.js +19 -16
- package/dist/edit-modes/draw-point-mode.d.ts +1 -1
- package/dist/edit-modes/draw-point-mode.js +7 -4
- package/dist/edit-modes/draw-polygon-by-dragging-mode.d.ts +1 -1
- package/dist/edit-modes/draw-polygon-by-dragging-mode.js +10 -5
- package/dist/edit-modes/draw-polygon-mode.d.ts +1 -1
- package/dist/edit-modes/draw-polygon-mode.js +20 -16
- package/dist/edit-modes/draw-rectangle-from-center-mode.d.ts +1 -1
- package/dist/edit-modes/draw-rectangle-from-center-mode.js +3 -0
- package/dist/edit-modes/draw-rectangle-mode.d.ts +1 -1
- package/dist/edit-modes/draw-rectangle-mode.js +3 -0
- package/dist/edit-modes/draw-rectangle-using-three-points-mode.d.ts +1 -1
- package/dist/edit-modes/draw-rectangle-using-three-points-mode.js +8 -5
- package/dist/edit-modes/draw-square-from-center-mode.d.ts +1 -1
- package/dist/edit-modes/draw-square-from-center-mode.js +3 -0
- package/dist/edit-modes/draw-square-mode.d.ts +1 -1
- package/dist/edit-modes/draw-square-mode.js +3 -0
- package/dist/edit-modes/duplicate-mode.d.ts +1 -1
- package/dist/edit-modes/duplicate-mode.js +3 -0
- package/dist/edit-modes/edit-mode.js +3 -1
- package/dist/edit-modes/elevation-mode.d.ts +2 -2
- package/dist/edit-modes/elevation-mode.js +8 -5
- package/dist/edit-modes/extend-line-string-mode.d.ts +1 -1
- package/dist/edit-modes/extend-line-string-mode.js +9 -6
- package/dist/edit-modes/extrude-mode.d.ts +1 -1
- package/dist/edit-modes/extrude-mode.js +10 -7
- package/dist/edit-modes/geojson-edit-mode.d.ts +1 -1
- package/dist/edit-modes/geojson-edit-mode.js +18 -15
- package/dist/edit-modes/immutable-feature-collection.d.ts +2 -1
- package/dist/edit-modes/immutable-feature-collection.js +25 -20
- package/dist/edit-modes/measure-angle-mode.d.ts +1 -1
- package/dist/edit-modes/measure-angle-mode.js +8 -8
- package/dist/edit-modes/measure-area-mode.d.ts +1 -1
- package/dist/edit-modes/measure-area-mode.js +7 -5
- package/dist/edit-modes/measure-distance-mode.d.ts +1 -1
- package/dist/edit-modes/measure-distance-mode.js +17 -14
- package/dist/edit-modes/modify-mode.d.ts +1 -1
- package/dist/edit-modes/modify-mode.js +17 -14
- package/dist/edit-modes/resize-circle-mode.d.ts +2 -2
- package/dist/edit-modes/resize-circle-mode.js +3 -1
- package/dist/edit-modes/rotate-mode.d.ts +1 -1
- package/dist/edit-modes/rotate-mode.js +8 -5
- package/dist/edit-modes/scale-mode.d.ts +1 -1
- package/dist/edit-modes/scale-mode.js +8 -5
- package/dist/edit-modes/snappable-mode.d.ts +1 -1
- package/dist/edit-modes/snappable-mode.js +8 -5
- package/dist/edit-modes/split-polygon-mode.d.ts +1 -1
- package/dist/edit-modes/split-polygon-mode.js +12 -9
- package/dist/edit-modes/three-click-polygon-mode.d.ts +1 -1
- package/dist/edit-modes/three-click-polygon-mode.js +9 -6
- package/dist/edit-modes/transform-mode.d.ts +1 -1
- package/dist/edit-modes/transform-mode.js +4 -1
- package/dist/edit-modes/translate-mode.d.ts +1 -1
- package/dist/edit-modes/translate-mode.js +7 -4
- package/dist/edit-modes/two-click-polygon-mode.d.ts +1 -1
- package/dist/edit-modes/two-click-polygon-mode.js +9 -6
- package/dist/edit-modes/types.d.ts +1 -1
- package/dist/edit-modes/types.js +3 -0
- package/dist/edit-modes/utils.d.ts +1 -1
- package/dist/edit-modes/utils.js +21 -19
- package/dist/edit-modes/view-mode.js +3 -0
- package/dist/editable-layers/editable-geojson-layer.d.ts +4 -4
- package/dist/editable-layers/editable-geojson-layer.js +27 -26
- package/dist/editable-layers/editable-h3-cluster-layer.d.ts +2 -2
- package/dist/editable-layers/editable-h3-cluster-layer.js +6 -3
- package/dist/editable-layers/editable-layer.d.ts +5 -5
- package/dist/editable-layers/editable-layer.js +18 -15
- package/dist/editable-layers/editable-path-layer.d.ts +1 -1
- package/dist/editable-layers/editable-path-layer.js +10 -7
- package/dist/editable-layers/elevated-edit-handle-layer.d.ts +1 -1
- package/dist/editable-layers/elevated-edit-handle-layer.js +6 -3
- package/dist/editable-layers/junction-scatterplot-layer.d.ts +2 -2
- package/dist/editable-layers/junction-scatterplot-layer.js +10 -7
- package/dist/editable-layers/selection-layer.d.ts +1 -1
- package/dist/editable-layers/selection-layer.js +5 -2
- package/dist/index.cjs +65 -537
- package/dist/index.cjs.map +4 -4
- package/dist/index.d.ts +19 -20
- package/dist/index.js +20 -18
- package/dist/lib/constants.js +3 -0
- package/dist/lib/deck-renderer/deck-cache.d.ts +1 -1
- package/dist/lib/deck-renderer/deck-cache.js +1 -1
- package/dist/lib/deck-renderer/deck-drawer.d.ts +2 -3
- package/dist/lib/deck-renderer/deck-drawer.js +12 -12
- package/dist/lib/feature.d.ts +4 -4
- package/dist/lib/feature.js +4 -1
- package/dist/lib/layer-mouse-event.d.ts +2 -2
- package/dist/lib/layer-mouse-event.js +4 -1
- package/dist/lib/layers/junctions-layer.d.ts +4 -4
- package/dist/lib/layers/junctions-layer.js +10 -7
- package/dist/lib/layers/segments-layer.d.ts +4 -4
- package/dist/lib/layers/segments-layer.js +11 -8
- package/dist/lib/layers/texts-layer.d.ts +3 -3
- package/dist/lib/layers/texts-layer.js +8 -5
- package/dist/lib/math.d.ts +1 -1
- package/dist/lib/math.js +3 -0
- package/dist/lib/{nebula.d.ts → nebula-core.d.ts} +2 -2
- package/dist/lib/{nebula.js → nebula-core.js} +7 -4
- package/dist/lib/nebula-layer.d.ts +2 -2
- package/dist/lib/nebula-layer.js +4 -1
- package/dist/lib/style.js +5 -2
- package/dist/mode-handlers/composite-mode-handler.d.ts +1 -1
- package/dist/mode-handlers/draw-90degree-polygon-handler.d.ts +1 -1
- package/dist/mode-handlers/draw-90degree-polygon-handler.js +13 -10
- package/dist/mode-handlers/draw-circle-by-bounding-box-handler.js +3 -0
- package/dist/mode-handlers/draw-circle-from-center-handler.js +3 -0
- package/dist/mode-handlers/draw-ellipse-by-bounding-box-handler.js +3 -0
- package/dist/mode-handlers/draw-ellipse-using-three-points-handler.js +5 -2
- package/dist/mode-handlers/draw-line-string-handler.js +7 -4
- package/dist/mode-handlers/draw-point-handler.js +4 -1
- package/dist/mode-handlers/draw-polygon-handler.d.ts +1 -1
- package/dist/mode-handlers/draw-polygon-handler.js +10 -7
- package/dist/mode-handlers/draw-rectangle-handler.js +3 -0
- package/dist/mode-handlers/draw-rectangle-using-three-points-handler.js +11 -8
- package/dist/mode-handlers/duplicate-handler.js +3 -0
- package/dist/mode-handlers/elevation-handler.d.ts +2 -2
- package/dist/mode-handlers/elevation-handler.js +8 -5
- package/dist/mode-handlers/extrude-handler.js +10 -7
- package/dist/mode-handlers/mode-handler.d.ts +1 -1
- package/dist/mode-handlers/mode-handler.js +17 -14
- package/dist/mode-handlers/modify-handler.d.ts +2 -2
- package/dist/mode-handlers/modify-handler.js +18 -15
- package/dist/mode-handlers/rotate-handler.d.ts +1 -1
- package/dist/mode-handlers/rotate-handler.js +4 -1
- package/dist/mode-handlers/scale-handler.d.ts +1 -1
- package/dist/mode-handlers/scale-handler.js +5 -2
- package/dist/mode-handlers/snappable-handler.d.ts +1 -1
- package/dist/mode-handlers/snappable-handler.js +6 -3
- package/dist/mode-handlers/split-polygon-handler.js +11 -8
- package/dist/mode-handlers/three-click-polygon-handler.js +3 -0
- package/dist/mode-handlers/translate-handler.d.ts +1 -1
- package/dist/mode-handlers/translate-handler.js +4 -1
- package/dist/mode-handlers/two-click-polygon-handler.js +3 -0
- package/dist/mode-handlers/view-handler.d.ts +1 -1
- package/dist/mode-handlers/view-handler.js +3 -0
- package/dist/shaderlib/color/color.d.ts +7 -6
- package/dist/shaderlib/color/color.js +7 -4
- package/dist/shaderlib/utils/utils.d.ts +2 -2
- package/dist/shaderlib/utils/utils.js +5 -2
- package/dist/{curve-utils.js → utils/curve-utils.js} +7 -4
- package/dist/{geojson-types.d.ts → utils/geojson-types.d.ts} +2 -25
- package/dist/utils/geojson-types.js +4 -0
- package/dist/{memoize.d.ts → utils/memoize.d.ts} +1 -1
- package/dist/{memoize.js → utils/memoize.js} +4 -1
- package/dist/{translateFromCenter.js → utils/translate-from-center.js} +4 -1
- package/dist/utils/types.js +4 -0
- package/dist/{utils.js → utils/utils.js} +8 -6
- package/package.json +10 -10
- package/src/constants.ts +5 -1
- package/src/edit-modes/composite-mode.ts +9 -5
- package/src/edit-modes/draw-90degree-polygon-mode.ts +38 -34
- package/src/edit-modes/draw-circle-by-diameter-mode.ts +16 -12
- package/src/edit-modes/draw-circle-from-center-mode.ts +15 -11
- package/src/edit-modes/draw-ellipse-by-bounding-box-mode.ts +8 -4
- package/src/edit-modes/draw-ellipse-using-three-points-mode.ts +9 -5
- package/src/edit-modes/draw-line-string-mode.ts +29 -25
- package/src/edit-modes/draw-point-mode.ts +13 -9
- package/src/edit-modes/draw-polygon-by-dragging-mode.ts +16 -16
- package/src/edit-modes/draw-polygon-mode.ts +28 -23
- package/src/edit-modes/draw-rectangle-from-center-mode.ts +6 -2
- package/src/edit-modes/draw-rectangle-mode.ts +6 -2
- package/src/edit-modes/draw-rectangle-using-three-points-mode.ts +12 -8
- package/src/edit-modes/draw-square-from-center-mode.ts +7 -3
- package/src/edit-modes/draw-square-mode.ts +7 -3
- package/src/edit-modes/duplicate-mode.ts +7 -3
- package/src/edit-modes/edit-mode.ts +5 -1
- package/src/edit-modes/elevation-mode.ts +13 -9
- package/src/edit-modes/extend-line-string-mode.ts +16 -12
- package/src/edit-modes/extrude-mode.ts +22 -18
- package/src/edit-modes/geojson-edit-mode.ts +37 -33
- package/src/edit-modes/immutable-feature-collection.ts +28 -22
- package/src/edit-modes/measure-angle-mode.ts +66 -59
- package/src/edit-modes/measure-area-mode.ts +13 -10
- package/src/edit-modes/measure-distance-mode.ts +37 -33
- package/src/edit-modes/modify-mode.ts +36 -32
- package/src/edit-modes/resize-circle-mode.ts +8 -5
- package/src/edit-modes/rotate-mode.ts +22 -18
- package/src/edit-modes/scale-mode.ts +29 -23
- package/src/edit-modes/snappable-mode.ts +19 -15
- package/src/edit-modes/split-polygon-mode.ts +25 -21
- package/src/edit-modes/three-click-polygon-mode.ts +15 -11
- package/src/edit-modes/transform-mode.ts +15 -11
- package/src/edit-modes/translate-mode.ts +15 -11
- package/src/edit-modes/two-click-polygon-mode.ts +15 -11
- package/src/edit-modes/types.ts +5 -1
- package/src/edit-modes/utils.ts +33 -30
- package/src/edit-modes/view-mode.ts +5 -1
- package/src/editable-layers/editable-geojson-layer.ts +44 -41
- package/src/editable-layers/editable-h3-cluster-layer.ts +17 -14
- package/src/editable-layers/editable-layer.ts +42 -32
- package/src/editable-layers/editable-path-layer.ts +12 -8
- package/src/editable-layers/elevated-edit-handle-layer.ts +11 -7
- package/src/editable-layers/junction-scatterplot-layer.ts +15 -11
- package/src/editable-layers/selection-layer.ts +11 -7
- package/src/index.ts +68 -65
- package/src/lib/constants.ts +4 -0
- package/src/lib/deck-renderer/deck-cache.ts +1 -1
- package/src/lib/deck-renderer/deck-drawer.ts +28 -28
- package/src/lib/feature.ts +7 -3
- package/src/lib/layer-mouse-event.ts +7 -6
- package/src/lib/layers/junctions-layer.ts +14 -10
- package/src/lib/layers/segments-layer.ts +24 -20
- package/src/lib/layers/texts-layer.ts +18 -14
- package/src/lib/math.ts +5 -1
- package/src/lib/{nebula.ts → nebula-core.ts} +8 -4
- package/src/lib/nebula-layer.ts +9 -5
- package/src/lib/style.ts +6 -2
- package/src/mode-handlers/composite-mode-handler.ts +6 -6
- package/src/mode-handlers/draw-90degree-polygon-handler.ts +22 -18
- package/src/mode-handlers/draw-circle-by-bounding-box-handler.ts +10 -6
- package/src/mode-handlers/draw-circle-from-center-handler.ts +10 -6
- package/src/mode-handlers/draw-ellipse-by-bounding-box-handler.ts +9 -5
- package/src/mode-handlers/draw-ellipse-using-three-points-handler.ts +12 -8
- package/src/mode-handlers/draw-line-string-handler.ts +12 -8
- package/src/mode-handlers/draw-point-handler.ts +9 -5
- package/src/mode-handlers/draw-polygon-handler.ts +16 -12
- package/src/mode-handlers/draw-rectangle-handler.ts +8 -4
- package/src/mode-handlers/draw-rectangle-using-three-points-handler.ts +17 -13
- package/src/mode-handlers/duplicate-handler.ts +8 -4
- package/src/mode-handlers/elevation-handler.ts +14 -10
- package/src/mode-handlers/extrude-handler.ts +15 -11
- package/src/mode-handlers/mode-handler.ts +26 -28
- package/src/mode-handlers/modify-handler.ts +29 -25
- package/src/mode-handlers/rotate-handler.ts +13 -17
- package/src/mode-handlers/scale-handler.ts +13 -13
- package/src/mode-handlers/snappable-handler.ts +28 -24
- package/src/mode-handlers/split-polygon-handler.ts +22 -18
- package/src/mode-handlers/three-click-polygon-handler.ts +6 -2
- package/src/mode-handlers/translate-handler.ts +12 -8
- package/src/mode-handlers/two-click-polygon-handler.ts +6 -2
- package/src/mode-handlers/view-handler.ts +7 -3
- package/src/shaderlib/color/color.ts +10 -5
- package/src/shaderlib/utils/utils.ts +6 -2
- package/src/{curve-utils.ts → utils/curve-utils.ts} +11 -7
- package/src/{geojson-types.ts → utils/geojson-types.ts} +16 -31
- package/src/{memoize.ts → utils/memoize.ts} +5 -1
- package/src/{translateFromCenter.ts → utils/translate-from-center.ts} +8 -4
- package/src/{types.ts → utils/types.ts} +4 -0
- package/src/{utils.ts → utils/utils.ts} +14 -11
- package/dist/editable-layers/path-marker-layer/arrow-2d-geometry.d.ts +0 -4
- package/dist/editable-layers/path-marker-layer/arrow-2d-geometry.js +0 -55
- package/dist/editable-layers/path-marker-layer/create-path-markers.d.ts +0 -16
- package/dist/editable-layers/path-marker-layer/create-path-markers.js +0 -75
- package/dist/editable-layers/path-marker-layer/path-marker-layer.d.ts +0 -40
- package/dist/editable-layers/path-marker-layer/path-marker-layer.js +0 -121
- package/dist/editable-layers/path-marker-layer/polyline.d.ts +0 -18
- package/dist/editable-layers/path-marker-layer/polyline.js +0 -37
- package/dist/editable-layers/path-outline-layer/path-outline-layer.d.ts +0 -26
- package/dist/editable-layers/path-outline-layer/path-outline-layer.js +0 -106
- package/dist/geojson-types.js +0 -2
- package/dist/shaderlib/outline/outline.d.ts +0 -8
- package/dist/shaderlib/outline/outline.js +0 -97
- package/dist/types.js +0 -1
- package/src/editable-layers/path-marker-layer/arrow-2d-geometry.ts +0 -61
- package/src/editable-layers/path-marker-layer/create-path-markers.ts +0 -107
- package/src/editable-layers/path-marker-layer/path-marker-layer.ts +0 -179
- package/src/editable-layers/path-marker-layer/polyline.ts +0 -40
- package/src/editable-layers/path-outline-layer/path-outline-layer.ts +0 -147
- package/src/shaderlib/outline/outline.ts +0 -101
- /package/dist/{curve-utils.d.ts → utils/curve-utils.d.ts} +0 -0
- /package/dist/{translateFromCenter.d.ts → utils/translate-from-center.d.ts} +0 -0
- /package/dist/{types.d.ts → utils/types.d.ts} +0 -0
- /package/dist/{utils.d.ts → utils/utils.d.ts} +0 -0
|
@@ -1,179 +0,0 @@
|
|
|
1
|
-
import {CompositeLayer, COORDINATE_SYSTEM, DefaultProps} from '@deck.gl/core';
|
|
2
|
-
import {ScatterplotLayer} from '@deck.gl/layers';
|
|
3
|
-
import {SimpleMeshLayer} from '@deck.gl/mesh-layers';
|
|
4
|
-
import PathOutlineLayer, {PathOutlineLayerProps} from '../path-outline-layer/path-outline-layer';
|
|
5
|
-
import Arrow2DGeometry from './arrow-2d-geometry';
|
|
6
|
-
|
|
7
|
-
import createPathMarkers from './create-path-markers';
|
|
8
|
-
import {getClosestPointOnPolyline} from './polyline';
|
|
9
|
-
import {Vector3} from '@math.gl/core';
|
|
10
|
-
|
|
11
|
-
const DISTANCE_FOR_MULTI_ARROWS = 0.1;
|
|
12
|
-
const ARROW_HEAD_SIZE = 0.2;
|
|
13
|
-
const ARROW_TAIL_WIDTH = 0.05;
|
|
14
|
-
// const ARROW_CENTER_ADJUST = -0.8;
|
|
15
|
-
|
|
16
|
-
const DEFAULT_MARKER_LAYER = SimpleMeshLayer;
|
|
17
|
-
|
|
18
|
-
export type PathMarkerLayerProps<DataT> = PathOutlineLayerProps<DataT> & {
|
|
19
|
-
getDirection?: (x) => any;
|
|
20
|
-
getMarkerColor?: (x) => number[];
|
|
21
|
-
getMarkerPercentages?: (x: any, info: any) => number[];
|
|
22
|
-
highlightPoint?: any;
|
|
23
|
-
highlightIndex?: number;
|
|
24
|
-
MarkerLayer?: any;
|
|
25
|
-
markerLayerProps?: any;
|
|
26
|
-
sizeScale?: number;
|
|
27
|
-
fp64?: boolean;
|
|
28
|
-
nebulaLayer?: any;
|
|
29
|
-
};
|
|
30
|
-
|
|
31
|
-
const DEFAULT_MARKER_LAYER_PROPS = {
|
|
32
|
-
mesh: new Arrow2DGeometry({headSize: ARROW_HEAD_SIZE, tailWidth: ARROW_TAIL_WIDTH})
|
|
33
|
-
};
|
|
34
|
-
|
|
35
|
-
const defaultProps: DefaultProps<PathMarkerLayerProps<any>> = Object.assign(
|
|
36
|
-
{},
|
|
37
|
-
PathOutlineLayer.defaultProps,
|
|
38
|
-
{
|
|
39
|
-
MarkerLayer: DEFAULT_MARKER_LAYER,
|
|
40
|
-
markerLayerProps: DEFAULT_MARKER_LAYER_PROPS,
|
|
41
|
-
|
|
42
|
-
sizeScale: 100,
|
|
43
|
-
fp64: false,
|
|
44
|
-
|
|
45
|
-
highlightIndex: -1,
|
|
46
|
-
highlightPoint: null,
|
|
47
|
-
|
|
48
|
-
getPath: (x) => x.path,
|
|
49
|
-
getColor: (x) => x.color,
|
|
50
|
-
getMarkerColor: (x) => [0, 0, 0, 255],
|
|
51
|
-
getDirection: (x) => x.direction,
|
|
52
|
-
getMarkerPercentages: (object, {lineLength}) =>
|
|
53
|
-
lineLength > DISTANCE_FOR_MULTI_ARROWS ? [0.25, 0.5, 0.75] : [0.5]
|
|
54
|
-
}
|
|
55
|
-
);
|
|
56
|
-
|
|
57
|
-
export default class PathMarkerLayer<
|
|
58
|
-
DataT = any,
|
|
59
|
-
ExtraPropsT = Record<string, unknown>
|
|
60
|
-
> extends CompositeLayer<ExtraPropsT & Required<PathMarkerLayerProps<DataT>>> {
|
|
61
|
-
static layerName = 'PathMarkerLayer';
|
|
62
|
-
static defaultProps = defaultProps;
|
|
63
|
-
|
|
64
|
-
state: {
|
|
65
|
-
closestPoint: Vector3 | null;
|
|
66
|
-
closestPoints?: {position: Vector3}[];
|
|
67
|
-
markers: any[];
|
|
68
|
-
mesh: Arrow2DGeometry;
|
|
69
|
-
} = undefined!;
|
|
70
|
-
|
|
71
|
-
initializeState() {
|
|
72
|
-
this.state = {
|
|
73
|
-
markers: [],
|
|
74
|
-
mesh: new Arrow2DGeometry({headSize: ARROW_HEAD_SIZE, tailWidth: ARROW_TAIL_WIDTH}),
|
|
75
|
-
closestPoint: null,
|
|
76
|
-
closestPoints: []
|
|
77
|
-
};
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
projectFlat(xyz, viewport, coordinateSystem, coordinateOrigin) {
|
|
81
|
-
if (coordinateSystem === COORDINATE_SYSTEM.METER_OFFSETS) {
|
|
82
|
-
const [dx, dy] = viewport.metersToLngLatDelta(xyz);
|
|
83
|
-
const [x, y] = coordinateOrigin;
|
|
84
|
-
return viewport.projectFlat([x + dx, dy + y]);
|
|
85
|
-
} else if (coordinateSystem === COORDINATE_SYSTEM.LNGLAT_OFFSETS) {
|
|
86
|
-
const [dx, dy] = xyz;
|
|
87
|
-
const [x, y] = coordinateOrigin;
|
|
88
|
-
return viewport.projectFlat([x + dx, dy + y]);
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
return viewport.projectFlat(xyz);
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
updateState({props, oldProps, changeFlags}) {
|
|
95
|
-
if (changeFlags.dataChanged || changeFlags.updateTriggersChanged) {
|
|
96
|
-
const {
|
|
97
|
-
data,
|
|
98
|
-
getPath,
|
|
99
|
-
getDirection,
|
|
100
|
-
getMarkerColor,
|
|
101
|
-
getMarkerPercentages,
|
|
102
|
-
coordinateSystem,
|
|
103
|
-
coordinateOrigin
|
|
104
|
-
} = this.props;
|
|
105
|
-
|
|
106
|
-
const {viewport} = this.context;
|
|
107
|
-
const projectFlat = (o) => this.projectFlat(o, viewport, coordinateSystem, coordinateOrigin);
|
|
108
|
-
this.state.markers = createPathMarkers({
|
|
109
|
-
data,
|
|
110
|
-
getPath,
|
|
111
|
-
getDirection,
|
|
112
|
-
getColor: getMarkerColor,
|
|
113
|
-
getMarkerPercentages,
|
|
114
|
-
projectFlat
|
|
115
|
-
});
|
|
116
|
-
this._recalculateClosestPoint();
|
|
117
|
-
}
|
|
118
|
-
if (changeFlags.propsChanged) {
|
|
119
|
-
if (props.point !== oldProps.point) {
|
|
120
|
-
this._recalculateClosestPoint();
|
|
121
|
-
}
|
|
122
|
-
}
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
_recalculateClosestPoint() {
|
|
126
|
-
const {highlightPoint, highlightIndex} = this.props;
|
|
127
|
-
if (highlightPoint && highlightIndex >= 0) {
|
|
128
|
-
const object = this.props.data![highlightIndex];
|
|
129
|
-
const points = this.props.getPath(object, null as any);
|
|
130
|
-
const {point} = getClosestPointOnPolyline({points, p: highlightPoint});
|
|
131
|
-
this.state.closestPoints = [{position: point}];
|
|
132
|
-
} else {
|
|
133
|
-
this.state.closestPoints = [];
|
|
134
|
-
}
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
getPickingInfo({info}) {
|
|
138
|
-
return Object.assign(info, {
|
|
139
|
-
// override object with picked feature
|
|
140
|
-
object: (info.object && info.object.path) || info.object
|
|
141
|
-
});
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
renderLayers() {
|
|
145
|
-
return [
|
|
146
|
-
new PathOutlineLayer(
|
|
147
|
-
this.props,
|
|
148
|
-
this.getSubLayerProps({
|
|
149
|
-
id: 'paths',
|
|
150
|
-
// Note: data has to be passed explicitly like this to avoid being empty
|
|
151
|
-
data: this.props.data
|
|
152
|
-
})
|
|
153
|
-
),
|
|
154
|
-
new this.props.MarkerLayer(
|
|
155
|
-
this.getSubLayerProps(
|
|
156
|
-
Object.assign({}, this.props.markerLayerProps, {
|
|
157
|
-
id: 'markers',
|
|
158
|
-
data: this.state.markers,
|
|
159
|
-
getOrientation: (x) => [0, -x.angle, 0],
|
|
160
|
-
getColor: (x) => x.color,
|
|
161
|
-
sizeScale: this.props.sizeScale,
|
|
162
|
-
fp64: this.props.fp64,
|
|
163
|
-
pickable: false,
|
|
164
|
-
parameters: {
|
|
165
|
-
blend: false,
|
|
166
|
-
depthTest: false
|
|
167
|
-
}
|
|
168
|
-
})
|
|
169
|
-
)
|
|
170
|
-
),
|
|
171
|
-
this.state.closestPoints &&
|
|
172
|
-
new ScatterplotLayer({
|
|
173
|
-
id: `${this.props.id}-highlight`,
|
|
174
|
-
data: this.state.closestPoints,
|
|
175
|
-
fp64: this.props.fp64
|
|
176
|
-
})
|
|
177
|
-
];
|
|
178
|
-
}
|
|
179
|
-
}
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
import { Vector3, clamp } from '@math.gl/core';
|
|
2
|
-
|
|
3
|
-
// Return the closest point on a line segment
|
|
4
|
-
export function getClosestPointOnLine({ p, p1, p2, clampToLine = true }) {
|
|
5
|
-
const lineVector = new Vector3(p2).subtract(p1);
|
|
6
|
-
const pointVector = new Vector3(p).subtract(p1);
|
|
7
|
-
let dotProduct = lineVector.dot(pointVector);
|
|
8
|
-
if (clampToLine) {
|
|
9
|
-
dotProduct = clamp(dotProduct, 0, 1);
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
return lineVector.lerp(p1, p2, dotProduct);
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
// Return the closest point on a line segment
|
|
16
|
-
export function getClosestPointOnPolyline({ p, points }) {
|
|
17
|
-
p = new Vector3(p);
|
|
18
|
-
let pClosest: Vector3 | null = null;
|
|
19
|
-
let distanceSquared = Infinity;
|
|
20
|
-
let index = -1;
|
|
21
|
-
for (let i = 0; i < points.length - 1; ++i) {
|
|
22
|
-
const p1 = points[i];
|
|
23
|
-
const p2 = points[i + 1];
|
|
24
|
-
const pClosestOnLine = getClosestPointOnLine({ p, p1, p2 });
|
|
25
|
-
const distanceToLineSquared = p.distanceSquared(pClosestOnLine);
|
|
26
|
-
if (distanceToLineSquared < distanceSquared) {
|
|
27
|
-
distanceSquared = distanceToLineSquared;
|
|
28
|
-
pClosest = pClosestOnLine;
|
|
29
|
-
index = i;
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
return {
|
|
33
|
-
point: pClosest as Vector3,
|
|
34
|
-
index,
|
|
35
|
-
p1: points[index],
|
|
36
|
-
p2: points[index + 1],
|
|
37
|
-
distanceSquared,
|
|
38
|
-
distance: Math.sqrt(distanceSquared),
|
|
39
|
-
};
|
|
40
|
-
}
|
|
@@ -1,147 +0,0 @@
|
|
|
1
|
-
import { PathLayer, PathLayerProps } from '@deck.gl/layers';
|
|
2
|
-
import type { DefaultProps, LayerContext } from '@deck.gl/core';
|
|
3
|
-
import {GL} from '@luma.gl/constants';
|
|
4
|
-
import { Framebuffer, Texture } from '@luma.gl/core';
|
|
5
|
-
import outline from '../../shaderlib/outline/outline';
|
|
6
|
-
import { UNIT } from '../../constants';
|
|
7
|
-
|
|
8
|
-
// TODO - this should be built into assembleShaders
|
|
9
|
-
function injectShaderCode({ source, code = '' }) {
|
|
10
|
-
const INJECT_CODE = /}[^{}]*$/;
|
|
11
|
-
return source.replace(INJECT_CODE, code.concat('\n}\n'));
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
const VS_CODE = `\
|
|
15
|
-
outline_setUV(gl_Position);
|
|
16
|
-
outline_setZLevel(instanceZLevel);
|
|
17
|
-
`;
|
|
18
|
-
|
|
19
|
-
const FS_CODE = `\
|
|
20
|
-
fragColor = outline_filterColor(fragColor);
|
|
21
|
-
`;
|
|
22
|
-
|
|
23
|
-
export type PathOutlineLayerProps<DataT> = PathLayerProps<DataT> & {
|
|
24
|
-
dashJustified?: boolean;
|
|
25
|
-
getDashArray?: [number, number] | ((d: DataT) => [number, number] | null);
|
|
26
|
-
getZLevel?: (d: DataT, index: number) => number;
|
|
27
|
-
};
|
|
28
|
-
|
|
29
|
-
const defaultProps: DefaultProps<PathOutlineLayerProps<any>> = {
|
|
30
|
-
getZLevel: () => 0,
|
|
31
|
-
};
|
|
32
|
-
|
|
33
|
-
export default class PathOutlineLayer<
|
|
34
|
-
DataT = any,
|
|
35
|
-
ExtraPropsT = Record<string, unknown>
|
|
36
|
-
> extends PathLayer<DataT, ExtraPropsT & Required<PathOutlineLayerProps<DataT>>> {
|
|
37
|
-
static layerName = 'PathOutlineLayer';
|
|
38
|
-
static defaultProps = defaultProps;
|
|
39
|
-
|
|
40
|
-
state: {
|
|
41
|
-
model?: any;
|
|
42
|
-
pathTesselator: any;
|
|
43
|
-
outlineFramebuffer: Framebuffer;
|
|
44
|
-
dummyTexture: Texture;
|
|
45
|
-
} = undefined!;
|
|
46
|
-
|
|
47
|
-
// Override getShaders to inject the outline module
|
|
48
|
-
getShaders() {
|
|
49
|
-
const shaders = super.getShaders();
|
|
50
|
-
return Object.assign({}, shaders, {
|
|
51
|
-
modules: shaders.modules.concat([outline]),
|
|
52
|
-
vs: injectShaderCode({ source: shaders.vs, code: VS_CODE }),
|
|
53
|
-
fs: injectShaderCode({ source: shaders.fs, code: FS_CODE }),
|
|
54
|
-
});
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
// @ts-expect-error PathLayer is missing LayerContext arg
|
|
58
|
-
initializeState(context: LayerContext) {
|
|
59
|
-
super.initializeState();
|
|
60
|
-
|
|
61
|
-
// Create an outline "shadow" map
|
|
62
|
-
// TODO - we should create a single outlineMap for all layers
|
|
63
|
-
this.setState({
|
|
64
|
-
outlineFramebuffer: context.device.createFramebuffer({}),
|
|
65
|
-
dummyTexture: context.device.createTexture({}),
|
|
66
|
-
});
|
|
67
|
-
|
|
68
|
-
// Create an attribute manager
|
|
69
|
-
// @ts-expect-error check whether this.getAttributeManager works here
|
|
70
|
-
this.state.attributeManager.addInstanced({
|
|
71
|
-
instanceZLevel: {
|
|
72
|
-
size: 1,
|
|
73
|
-
type: GL.UNSIGNED_BYTE,
|
|
74
|
-
accessor: 'getZLevel',
|
|
75
|
-
},
|
|
76
|
-
});
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
// Override draw to add render module
|
|
80
|
-
draw({ moduleParameters = {}, parameters, uniforms, context }) {
|
|
81
|
-
// Need to calculate same uniforms as base layer
|
|
82
|
-
const {
|
|
83
|
-
jointRounded,
|
|
84
|
-
capRounded,
|
|
85
|
-
billboard,
|
|
86
|
-
miterLimit,
|
|
87
|
-
widthUnits,
|
|
88
|
-
widthScale,
|
|
89
|
-
widthMinPixels,
|
|
90
|
-
widthMaxPixels,
|
|
91
|
-
} = this.props;
|
|
92
|
-
|
|
93
|
-
uniforms = Object.assign({}, uniforms, {
|
|
94
|
-
jointType: Number(jointRounded),
|
|
95
|
-
capType: Number(capRounded),
|
|
96
|
-
billboard,
|
|
97
|
-
widthUnits: UNIT[widthUnits],
|
|
98
|
-
widthScale,
|
|
99
|
-
miterLimit,
|
|
100
|
-
widthMinPixels,
|
|
101
|
-
widthMaxPixels,
|
|
102
|
-
});
|
|
103
|
-
|
|
104
|
-
// Render the outline shadowmap (based on segment z orders)
|
|
105
|
-
const { outlineFramebuffer, dummyTexture } = this.state;
|
|
106
|
-
// TODO(v9): resize, see 'sf' example.
|
|
107
|
-
// outlineFramebuffer.resize();
|
|
108
|
-
// TODO(v9) clear FBO
|
|
109
|
-
// outlineFramebuffer.clear({ color: true, depth: true, stencil: true });
|
|
110
|
-
|
|
111
|
-
this.state.model.updateModuleSettings({
|
|
112
|
-
outlineEnabled: true,
|
|
113
|
-
outlineRenderShadowmap: true,
|
|
114
|
-
outlineShadowmap: dummyTexture,
|
|
115
|
-
});
|
|
116
|
-
|
|
117
|
-
this.state.model.draw({
|
|
118
|
-
uniforms: Object.assign({}, uniforms, {
|
|
119
|
-
jointType: 0,
|
|
120
|
-
widthScale: this.props.widthScale * 1.3,
|
|
121
|
-
}),
|
|
122
|
-
parameters: {
|
|
123
|
-
depthTest: false,
|
|
124
|
-
// Biggest value needs to go into buffer
|
|
125
|
-
blendEquation: GL.MAX,
|
|
126
|
-
},
|
|
127
|
-
framebuffer: outlineFramebuffer,
|
|
128
|
-
});
|
|
129
|
-
|
|
130
|
-
// Now use the outline shadowmap to render the lines (with outlines)
|
|
131
|
-
this.state.model.updateModuleSettings({
|
|
132
|
-
outlineEnabled: true,
|
|
133
|
-
outlineRenderShadowmap: false,
|
|
134
|
-
outlineShadowmap: outlineFramebuffer,
|
|
135
|
-
});
|
|
136
|
-
this.state.model.draw({
|
|
137
|
-
uniforms: Object.assign({}, uniforms, {
|
|
138
|
-
jointType: Number(jointRounded),
|
|
139
|
-
capType: Number(capRounded),
|
|
140
|
-
widthScale: this.props.widthScale,
|
|
141
|
-
}),
|
|
142
|
-
parameters: {
|
|
143
|
-
depthTest: false,
|
|
144
|
-
},
|
|
145
|
-
});
|
|
146
|
-
}
|
|
147
|
-
}
|
|
@@ -1,101 +0,0 @@
|
|
|
1
|
-
/* eslint-disable camelcase */
|
|
2
|
-
const INITIAL_STATE: Record<string, any> = {
|
|
3
|
-
outlineEnabled: false,
|
|
4
|
-
outlineRenderShadowmap: false,
|
|
5
|
-
outlineShadowmap: null,
|
|
6
|
-
};
|
|
7
|
-
|
|
8
|
-
function getUniforms({ outlineEnabled, outlineRenderShadowmap, outlineShadowmap } = INITIAL_STATE) {
|
|
9
|
-
const uniforms: Record<string, any> = {};
|
|
10
|
-
if (outlineEnabled !== undefined) {
|
|
11
|
-
// ? 1.0 : 0.0;
|
|
12
|
-
uniforms.outline_uEnabled = outlineEnabled;
|
|
13
|
-
}
|
|
14
|
-
if (outlineRenderShadowmap !== undefined) {
|
|
15
|
-
// ? 1.0 : 0.0;
|
|
16
|
-
uniforms.outline_uRenderOutlines = outlineRenderShadowmap;
|
|
17
|
-
}
|
|
18
|
-
if (outlineShadowmap !== undefined) {
|
|
19
|
-
uniforms.outline_uShadowmap = outlineShadowmap;
|
|
20
|
-
}
|
|
21
|
-
return uniforms;
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
const vs = `\
|
|
25
|
-
#version 300 es
|
|
26
|
-
in float instanceZLevel;
|
|
27
|
-
out float outline_vzLevel;
|
|
28
|
-
out vec4 outline_vPosition;
|
|
29
|
-
|
|
30
|
-
// Set the z level for the outline shadowmap rendering
|
|
31
|
-
void outline_setZLevel(float zLevel) {
|
|
32
|
-
outline_vzLevel = zLevel;
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
// Store an adjusted position for texture2DProj
|
|
36
|
-
void outline_setUV(vec4 position) {
|
|
37
|
-
// mat4(
|
|
38
|
-
// 0.5, 0.0, 0.0, 0.0,
|
|
39
|
-
// 0.0, 0.5, 0.0, 0.0,
|
|
40
|
-
// 0.0, 0.0, 0.5, 0.0,
|
|
41
|
-
// 0.5, 0.5, 0.5, 1.0
|
|
42
|
-
// ) * position;
|
|
43
|
-
outline_vPosition = vec4(position.xyz * 0.5 + position.w * 0.5, position.w);
|
|
44
|
-
}
|
|
45
|
-
`;
|
|
46
|
-
|
|
47
|
-
const fs = `\
|
|
48
|
-
uniform bool outline_uEnabled;
|
|
49
|
-
uniform bool outline_uRenderOutlines;
|
|
50
|
-
uniform sampler2D outline_uShadowmap;
|
|
51
|
-
|
|
52
|
-
in float outline_vzLevel;
|
|
53
|
-
// in vec2 outline_vUV;
|
|
54
|
-
in vec4 outline_vPosition;
|
|
55
|
-
|
|
56
|
-
out vec4 fragColor;
|
|
57
|
-
|
|
58
|
-
const float OUTLINE_Z_LEVEL_ERROR = 0.01;
|
|
59
|
-
|
|
60
|
-
// Return a darker color in shadowmap
|
|
61
|
-
vec4 outline_filterShadowColor(vec4 color) {
|
|
62
|
-
return vec4(outline_vzLevel / 255., outline_vzLevel / 255., outline_vzLevel / 255., 1.);
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
// Return a darker color if in shadowmap
|
|
66
|
-
vec4 outline_filterDarkenColor(vec4 color) {
|
|
67
|
-
if (outline_uEnabled) {
|
|
68
|
-
float maxZLevel;
|
|
69
|
-
if (outline_vPosition.q > 0.0) {
|
|
70
|
-
maxZLevel = texture2DProj(outline_uShadowmap, outline_vPosition).r * 255.;
|
|
71
|
-
} else {
|
|
72
|
-
discard;
|
|
73
|
-
}
|
|
74
|
-
if (maxZLevel < outline_vzLevel + OUTLINE_Z_LEVEL_ERROR) {
|
|
75
|
-
vec4(color.rgb * 0.5, color.a);
|
|
76
|
-
} else {
|
|
77
|
-
discard;
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
return color;
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
// if enabled and rendering outlines - Render depth to shadowmap
|
|
84
|
-
// if enabled and rendering colors - Return a darker color if in shadowmap
|
|
85
|
-
// if disabled, just return color
|
|
86
|
-
vec4 outline_filterColor(vec4 color) {
|
|
87
|
-
if (outline_uEnabled) {
|
|
88
|
-
return outline_uRenderOutlines ?
|
|
89
|
-
outline_filterShadowColor(color) :
|
|
90
|
-
outline_filterDarkenColor(color);
|
|
91
|
-
}
|
|
92
|
-
return color;
|
|
93
|
-
}
|
|
94
|
-
`;
|
|
95
|
-
|
|
96
|
-
export default {
|
|
97
|
-
name: 'outline',
|
|
98
|
-
vs,
|
|
99
|
-
fs,
|
|
100
|
-
getUniforms,
|
|
101
|
-
};
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|