angular-cesium-ivy
Version:
Angular library for working with Angular-Cesium.
114 lines • 22.5 kB
JavaScript
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
import { EditActions } from '../../models/edit-actions.enum';
import { EditModes } from '../../models/edit-mode.enum';
import { PolylinesEditorService } from '../../services/entity-editors/polyline-editor/polylines-editor.service';
import * as i0 from "@angular/core";
import * as i1 from "../../services/entity-editors/polyline-editor/polylines-editor.service";
import * as i2 from "../../../angular-cesium/services/coordinate-converter/coordinate-converter.service";
import * as i3 from "../polylines-editor/polylines-editor.component";
/**
*
* Range and bearing component that is used to draw range and bearing on the map.
* The inputs are used to customize the range and bearing style and behavior.
* Create component reference and use the `create()` function to start creating R&B on the map.
* The function receives an optional RangeAndBearingOptions object that defines the created range and bearing style and behavior
* (on top of the default and global definitions).
*
* Usage:
*
* my-component.ts:
*
* ```
* \@ViewChild('rangeAndBearing', {static: false}) private rangeAndBearing: RangeAndBearingComponent; // Get R&B reference
* // ...
* this.rangeAndBearing.create({style: { pointProps: { pixelSize: 12 } }, bearingLabelsStyle: { fillColor: Cesium.Color.GREEN } });
* ```
*
* my-component.html
* ```
* <range-and-bearing #rangeAndBearing></range-and-bearing> // Optional inputs defines global style and behavior.
* ```
*
*/
export class RangeAndBearingComponent {
constructor(polylineEditor, coordinateConverter) {
this.polylineEditor = polylineEditor;
this.coordinateConverter = coordinateConverter;
this.lineEditOptions = {};
this.labelsStyle = {};
this.distanceLabelsStyle = {};
this.bearingLabelsStyle = {};
}
create({ lineEditOptions = {}, labelsStyle = {}, distanceLabelsStyle = {}, bearingLabelsStyle = {}, bearingStringFn, distanceStringFn, labelsRenderFn, } = { lineEditOptions: {}, labelsStyle: {}, distanceLabelsStyle: {}, bearingLabelsStyle: {} }) {
const rnb = this.polylineEditor.create(Object.assign(Object.assign({ allowDrag: false, pointProps: {
showVirtual: false,
pixelSize: 8,
}, polylineProps: {
width: 2,
} }, this.lineEditOptions), lineEditOptions));
if (labelsRenderFn) {
rnb.setLabelsRenderFn(labelsRenderFn);
}
else if (this.labelsRenderFn) {
rnb.setLabelsRenderFn(this.labelsRenderFn);
}
else {
rnb.setLabelsRenderFn(update => {
const positions = update.positions;
let totalDistance = 0;
if (!positions || positions.length === 0) {
return [];
}
return (update.editMode === EditModes.CREATE && update.editAction !== EditActions.ADD_LAST_POINT
? [...positions, update.updatedPosition]
: positions).reduce((labels, position, index, array) => {
if (index !== 0) {
const previousPosition = array[index - 1];
const bearing = this.coordinateConverter.bearingToCartesian(previousPosition, position);
const distance = Cesium.Cartesian3.distance(previousPosition, position) / 1000;
labels.push(Object.assign(Object.assign(Object.assign(Object.assign({ text: (bearingStringFn && bearingStringFn(bearing)) ||
(this.bearingStringFn && this.bearingStringFn(bearing)) ||
`${bearing.toFixed(2)}°`, scale: 0.2, font: '80px Helvetica', pixelOffset: new Cesium.Cartesian2(-20, -8), position: new Cesium.Cartesian3((position.x + previousPosition.x) / 2, (position.y + previousPosition.y) / 2, (position.z + previousPosition.z) / 2), fillColor: Cesium.Color.WHITE, outlineColor: Cesium.Color.WHITE, showBackground: true }, this.labelsStyle), labelsStyle), this.bearingLabelsStyle), bearingLabelsStyle), Object.assign(Object.assign(Object.assign(Object.assign({ text: (distanceStringFn && distanceStringFn(totalDistance + distance)) ||
(this.distanceStringFn && this.distanceStringFn(totalDistance + distance)) ||
`${(totalDistance + distance).toFixed(2)} Km`, scale: 0.2, font: '80px Helvetica', pixelOffset: new Cesium.Cartesian2(-35, -8), position: position, fillColor: Cesium.Color.WHITE, outlineColor: Cesium.Color.WHITE, showBackground: true }, this.labelsStyle), labelsStyle), this.distanceLabelsStyle), distanceLabelsStyle));
totalDistance += distance;
}
return labels;
}, [
Object.assign(Object.assign(Object.assign(Object.assign({ text: (distanceStringFn && distanceStringFn(0)) || (this.distanceStringFn && this.distanceStringFn(0)) || `0 Km`, scale: 0.2, font: '80px Helvetica', pixelOffset: new Cesium.Cartesian2(-20, -8), position: positions[0], fillColor: Cesium.Color.WHITE, outlineColor: Cesium.Color.WHITE, showBackground: true }, this.labelsStyle), labelsStyle), this.distanceLabelsStyle), distanceLabelsStyle),
]);
});
}
return rnb;
}
}
RangeAndBearingComponent.ɵfac = function RangeAndBearingComponent_Factory(t) { return new (t || RangeAndBearingComponent)(i0.ɵɵdirectiveInject(i1.PolylinesEditorService), i0.ɵɵdirectiveInject(i2.CoordinateConverter)); };
RangeAndBearingComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: RangeAndBearingComponent, selectors: [["range-and-bearing"]], inputs: { lineEditOptions: "lineEditOptions", labelsStyle: "labelsStyle", distanceLabelsStyle: "distanceLabelsStyle", bearingLabelsStyle: "bearingLabelsStyle", bearingStringFn: "bearingStringFn", distanceStringFn: "distanceStringFn", labelsRenderFn: "labelsRenderFn" }, features: [i0.ɵɵProvidersFeature([PolylinesEditorService])], decls: 1, vars: 0, template: function RangeAndBearingComponent_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵelement(0, "polylines-editor");
} }, directives: [i3.PolylinesEditorComponent], encapsulation: 2, changeDetection: 0 });
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(RangeAndBearingComponent, [{
type: Component,
args: [{
selector: 'range-and-bearing',
template: `
<polylines-editor></polylines-editor>
`,
changeDetection: ChangeDetectionStrategy.OnPush,
providers: [PolylinesEditorService],
}]
}], function () { return [{ type: i1.PolylinesEditorService }, { type: i2.CoordinateConverter }]; }, { lineEditOptions: [{
type: Input
}], labelsStyle: [{
type: Input
}], distanceLabelsStyle: [{
type: Input
}], bearingLabelsStyle: [{
type: Input
}], bearingStringFn: [{
type: Input
}], distanceStringFn: [{
type: Input
}], labelsRenderFn: [{
type: Input
}] }); })();
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"range-and-bearing.component.js","sourceRoot":"","sources":["../../../../../../../projects/angular-cesium/src/lib/angular-cesium-widgets/components/range-and-bearing/range-and-bearing.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input } from '@angular/core';\nimport { CoordinateConverter } from '../../../angular-cesium/services/coordinate-converter/coordinate-converter.service';\nimport { EditActions } from '../../models/edit-actions.enum';\nimport { PolylineEditorObservable } from '../../models/polyline-editor-observable';\nimport { PolylineEditOptions } from '../../models/polyline-edit-options';\nimport { LabelProps, LabelStyle } from '../../models/label-props';\nimport { PolylineEditUpdate } from '../../models/polyline-edit-update';\nimport { EditModes } from '../../models/edit-mode.enum';\nimport { PolylinesEditorService } from '../../services/entity-editors/polyline-editor/polylines-editor.service';\n\n/**\n *\n * Range and bearing component that is used to draw range and bearing on the map.\n * The inputs are used to customize the range and bearing style and behavior.\n * Create component reference and use the `create()` function to start creating R&B on the map.\n * The function receives an optional RangeAndBearingOptions object that defines the created range and bearing style and behavior\n * (on top of the default and global definitions).\n *\n * Usage:\n *\n * my-component.ts:\n *\n * ```\n * \\@ViewChild('rangeAndBearing', {static: false}) private rangeAndBearing: RangeAndBearingComponent; // Get R&B reference\n *  // ...\n * this.rangeAndBearing.create({style: { pointProps: { pixelSize: 12 } }, bearingLabelsStyle: { fillColor: Cesium.Color.GREEN } });\n * ```\n *\n * my-component.html\n * ```\n * <range-and-bearing #rangeAndBearing></range-and-bearing> // Optional inputs defines global style and behavior.\n * ```\n *\n */\n@Component({\n  selector: 'range-and-bearing',\n  template: `\n    <polylines-editor></polylines-editor>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [PolylinesEditorService],\n})\nexport class RangeAndBearingComponent {\n  @Input() lineEditOptions?: PolylineEditOptions = {};\n  @Input() labelsStyle?: LabelStyle = {};\n  @Input() distanceLabelsStyle?: LabelStyle = {};\n  @Input() bearingLabelsStyle?: LabelStyle = {};\n  @Input() bearingStringFn?: (value: number) => string;\n  @Input() distanceStringFn?: (value: number) => string;\n  @Input() labelsRenderFn?: (update: PolylineEditUpdate, labels: LabelProps[]) => LabelProps[];\n\n  constructor(private polylineEditor: PolylinesEditorService, private coordinateConverter: CoordinateConverter) {\n  }\n\n  create(\n    {\n      lineEditOptions = {},\n      labelsStyle = {},\n      distanceLabelsStyle = {},\n      bearingLabelsStyle = {},\n      bearingStringFn,\n      distanceStringFn,\n      labelsRenderFn,\n    }: RangeAndBearingOptions = {lineEditOptions: {}, labelsStyle: {}, distanceLabelsStyle: {}, bearingLabelsStyle: {}},\n  ): PolylineEditorObservable {\n    const rnb = this.polylineEditor.create({\n      allowDrag: false,\n      pointProps: {\n        showVirtual: false,\n        pixelSize: 8,\n      },\n      polylineProps: {\n        width: 2,\n      },\n      ...this.lineEditOptions,\n      ...lineEditOptions,\n    });\n\n    if (labelsRenderFn) {\n      rnb.setLabelsRenderFn(labelsRenderFn);\n    } else if (this.labelsRenderFn) {\n      rnb.setLabelsRenderFn(this.labelsRenderFn);\n    } else {\n      rnb.setLabelsRenderFn(update => {\n        const positions = update.positions;\n        let totalDistance = 0;\n        if (!positions || positions.length === 0) {\n          return [];\n        }\n        return (update.editMode === EditModes.CREATE && update.editAction !== EditActions.ADD_LAST_POINT\n            ? [...positions, update.updatedPosition]\n            : positions\n        ).reduce(\n          (labels, position, index, array) => {\n            if (index !== 0) {\n              const previousPosition = array[index - 1];\n              const bearing = this.coordinateConverter.bearingToCartesian(previousPosition, position);\n              const distance = Cesium.Cartesian3.distance(previousPosition, position) / 1000;\n              labels.push(\n                {\n                  text:\n                    (bearingStringFn && bearingStringFn(bearing)) ||\n                    (this.bearingStringFn && this.bearingStringFn(bearing)) ||\n                    `${bearing.toFixed(2)}°`,\n                  scale: 0.2,\n                  font: '80px Helvetica',\n                  pixelOffset: new Cesium.Cartesian2(-20, -8),\n                  position: new Cesium.Cartesian3(\n                    (position.x + previousPosition.x) / 2,\n                    (position.y + previousPosition.y) / 2,\n                    (position.z + previousPosition.z) / 2,\n                  ),\n                  fillColor: Cesium.Color.WHITE,\n                  outlineColor: Cesium.Color.WHITE,\n                  showBackground: true,\n                  ...(this.labelsStyle as any),\n                  ...(labelsStyle as any),\n                  ...(this.bearingLabelsStyle as any),\n                  ...(bearingLabelsStyle as any),\n                },\n                {\n                  text:\n                    (distanceStringFn && distanceStringFn(totalDistance + distance)) ||\n                    (this.distanceStringFn && this.distanceStringFn(totalDistance + distance)) ||\n                    `${(totalDistance + distance).toFixed(2)} Km`,\n                  scale: 0.2,\n                  font: '80px Helvetica',\n                  pixelOffset: new Cesium.Cartesian2(-35, -8),\n                  position: position,\n                  fillColor: Cesium.Color.WHITE,\n                  outlineColor: Cesium.Color.WHITE,\n                  showBackground: true,\n                  ...(this.labelsStyle as any),\n                  ...(labelsStyle as any),\n                  ...(this.distanceLabelsStyle as any),\n                  ...(distanceLabelsStyle as any),\n                },\n              );\n\n              totalDistance += distance;\n            }\n\n            return labels;\n          },\n          [\n            {\n              text: (distanceStringFn && distanceStringFn(0)) || (this.distanceStringFn && this.distanceStringFn(0)) || `0 Km`,\n              scale: 0.2,\n              font: '80px Helvetica',\n              pixelOffset: new Cesium.Cartesian2(-20, -8),\n              position: positions[0],\n              fillColor: Cesium.Color.WHITE,\n              outlineColor: Cesium.Color.WHITE,\n              showBackground: true,\n              ...(this.labelsStyle as any),\n              ...(labelsStyle as any),\n              ...(this.distanceLabelsStyle as any),\n              ...(distanceLabelsStyle as any),\n            },\n          ],\n        );\n      });\n    }\n\n    return rnb;\n  }\n}\n\nexport interface RangeAndBearingOptions {\n  lineEditOptions?: PolylineEditOptions;\n  labelsStyle?: LabelStyle;\n  distanceLabelsStyle?: LabelStyle;\n  bearingLabelsStyle?: LabelStyle;\n  bearingStringFn?: (value: number) => string;\n  distanceStringFn?: (value: number) => string;\n  labelsRenderFn?: (update: PolylineEditUpdate, labels: LabelProps[]) => LabelProps[];\n}\n"]}