Skip to content

LayerOptions

Defined in: map/geo-map.ts:12

Declarative interaction options shared by every engine’s retained layers. The machinery (hover overlay, tooltip, selection styling, hit-testing) lives entirely in BaseEngine — these options are just the per-layer surface that both BaseEngine.select’s and the hover/tooltip dispatch read. Plot.layer()/Plot.points() and GeoMap.layer() forward them into the LayerSpec via BaseEngine.interactionFields, so the contract has one home.

F = any

optional clipTo?: string

Defined in: map/geo-map.ts:15


optional fill?: string | ((f, i) => string)

Defined in: map/geo-map.ts:13


optional hideOnInteraction?: boolean

Defined in: map/geo-map.ts:28

Drop this layer from the render while interacting — a rotation drag or a zoom/pan gesture (re-projects + reappears when the gesture ends). Use for dense layers so only the cheap layers re-project per rotation frame.


optional hover?: HoverOption<F>

Defined in: map/base-engine.ts:27

Hover-highlight: true = default white outline, a HighlightStyle = redraw the hovered item with it, or a custom (datum, HighlightBuilder) draw fn. Rendered in a tiny overlay layer — O(hovered item) per change, the base layer is untouched.

InteractiveLayerOptions.hover


optional id?: (f, i) => string | number

Defined in: map/geo-map.ts:22

F

number

string | number


optional lineCap?: LineCap

Defined in: map/geo-map.ts:21

End-cap style for open strokes (“butt” default | “square” | “round”).


optional lineJoin?: LineJoin

Defined in: map/geo-map.ts:17

Stroke corner style: “bevel” (default) | “miter” | “round”. Identical across backends.


optional lineWidth?: number

Defined in: map/geo-map.ts:15


optional miterLimit?: number

Defined in: map/geo-map.ts:19

Miter length / width above which a miter falls back to a bevel (default 10).


optional passThrough?: boolean

Defined in: map/geo-map.ts:43

Render via the backend’s pass-through path: no retained Scene geometry, no hit index (not pickable). Supports all GeoJSON geometry on both Canvas and WebGL (Point/MultiPoint → analytic circles; Polygon/Line/etc. → projected paths) — features are projected/recorded and drawn directly each repaint, so features may be a callback re-invoked per repaint (you own the data). For huge / fast-changing datasets beyond the retained ceiling (~4–16M). Trade-off vs the default retained path: retained is always crisp, interactive, and pickable but capped; pass-through is uncapped + streaming but shows a slightly stale raster during pan/zoom (re-crisp on settle), isn’t pickable, and re-tessellates non-point geometry per settle. Paths are world-mode (screen-mode paths are a follow-up). NOTE: clipTo is NOT applied to pass-through layers yet — it is ignored (a follow-up); use the retained path if you need clipping.


optional pickable?: boolean

Defined in: map/geo-map.ts:31

When false, skip the CPU hit index for this layer (no hover/pick on it) — saves an Entry object per feature; use for huge, non-interactive layers (e.g. streamed points).


optional pointRadius?: number

Defined in: map/geo-map.ts:15


optional selection?: SelectionOptions

Defined in: map/base-engine.ts:23

Styles for BaseEngine.select: the selected set and its complement. Defaults: selected keeps the base style; others { opacity: 0.3 }.

InteractiveLayerOptions.selection


optional sizeMode?: "world" | "screen"

Defined in: map/geo-map.ts:24

“world” (default): radius scales with zoom. “screen”: constant pixel size.


optional stroke?: string | ((f, i) => string)

Defined in: map/geo-map.ts:14


optional tooltip?: (d, id) => string | HTMLElement | null

Defined in: map/base-engine.ts:31

Hover tooltip content for this layer (null hides). Shown in a shared engine-managed div — see tooltipClass for styling. Re-evaluated only when the hovered target changes; re-declare the layer to force a refresh.

F

string | number

string | HTMLElement | null

InteractiveLayerOptions.tooltip