@bokeh/bokehjs
Version:
Interactive, novel data visualization
104 lines • 3.64 kB
TypeScript
import { Annotation, AnnotationView } from "./annotation";
import type { AutoRanged } from "../ranges/data_range1d";
import { auto_ranged } from "../ranges/data_range1d";
import * as mixins from "../../core/property_mixins";
import type * as visuals from "../../core/visuals";
import { CoordinateUnits } from "../../core/enums";
import type { Arrayable, Rect } from "../../core/types";
import { Signal } from "../../core/signaling";
import type { PanEvent, Pannable, MoveEvent, Moveable, KeyModifiers } from "../../core/ui_events";
import type { CoordinateMapper } from "../../core/util/bbox";
import { BBox } from "../../core/util/bbox";
import type { Context2d } from "../../core/util/canvas";
import type * as p from "../../core/properties";
export type Node = {
type: "node";
i: number;
};
export type Edge = {
type: "edge";
i: number;
};
export type Area = {
type: "area";
};
export type HitTarget = Node | Edge | Area;
type Point = {
x: number;
y: number;
};
declare class Polygon {
readonly xs: Arrayable<number>;
readonly ys: Arrayable<number>;
constructor(xs?: Arrayable<number>, ys?: Arrayable<number>);
clone(): Polygon;
[Symbol.iterator](): Iterator<[number, number, number]>;
nodes(): IterableIterator<[number, number, number]>;
edges(): IterableIterator<[Point, Point, number]>;
contains(x: number, y: number): boolean;
get bbox(): BBox;
get n(): number;
translate(dx: number, dy: number, ...i: number[]): Polygon;
}
export declare class PolyAnnotationView extends AnnotationView implements Pannable, Moveable, AutoRanged {
model: PolyAnnotation;
visuals: PolyAnnotation.Visuals;
protected poly: Polygon;
get bbox(): BBox;
connect_signals(): void;
readonly [auto_ranged] = true;
bounds(): Rect;
log_bounds(): Rect;
protected _mappers(): {
x: CoordinateMapper;
y: CoordinateMapper;
};
protected _paint(ctx: Context2d): void;
interactive_hit(sx: number, sy: number): boolean;
private _hit_test;
private _can_hit;
private _pan_state;
on_pan_start(ev: PanEvent): boolean;
on_pan(ev: PanEvent): void;
on_pan_end(ev: PanEvent): void;
private get _has_hover();
private _is_hovered;
on_enter(_ev: MoveEvent): boolean;
on_move(_ev: MoveEvent): void;
on_leave(_ev: MoveEvent): void;
cursor(sx: number, sy: number): string | null;
}
export declare namespace PolyAnnotation {
type Attrs = p.AttrsOf<Props>;
type Props = Annotation.Props & {
xs: p.Property<Arrayable<number>>;
ys: p.Property<Arrayable<number>>;
xs_units: p.Property<CoordinateUnits>;
ys_units: p.Property<CoordinateUnits>;
editable: p.Property<boolean>;
} & Mixins;
type Mixins = mixins.Line & mixins.Fill & mixins.Hatch & mixins.HoverLine & mixins.HoverFill & mixins.HoverHatch;
type Visuals = Annotation.Visuals & {
line: visuals.Line;
fill: visuals.Fill;
hatch: visuals.Hatch;
hover_line: visuals.Line;
hover_fill: visuals.Fill;
hover_hatch: visuals.Hatch;
};
}
export interface PolyAnnotation extends PolyAnnotation.Attrs {
}
export declare class PolyAnnotation extends Annotation {
properties: PolyAnnotation.Props;
__view_type__: PolyAnnotationView;
constructor(attrs?: Partial<PolyAnnotation.Attrs>);
readonly pan: Signal<["pan" | "pan:start" | "pan:end", KeyModifiers], this>;
update({ xs, ys }: {
xs: Arrayable<number>;
ys: Arrayable<number>;
}): void;
clear(): void;
}
export {};
//# sourceMappingURL=poly_annotation.d.ts.map