123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116 |
- import {
- defined,
- destroyObject,
- DeveloperError,
- getElement,
- } from "@cesium/engine";
- import knockout from "../ThirdParty/knockout.js";
- import SelectionIndicatorViewModel from "./SelectionIndicatorViewModel.js";
- /**
- * A widget for displaying an indicator on a selected object.
- *
- * @alias SelectionIndicator
- * @constructor
- *
- * @param {Element|string} container The DOM element or ID that will contain the widget.
- * @param {Scene} scene The Scene instance to use.
- *
- * @exception {DeveloperError} Element with id "container" does not exist in the document.
- */
- function SelectionIndicator(container, scene) {
- //>>includeStart('debug', pragmas.debug);
- if (!defined(container)) {
- throw new DeveloperError("container is required.");
- }
- //>>includeEnd('debug')
- container = getElement(container);
- this._container = container;
- const el = document.createElement("div");
- el.className = "cesium-selection-wrapper";
- el.setAttribute(
- "data-bind",
- '\
- style: { "top" : _screenPositionY, "left" : _screenPositionX },\
- css: { "cesium-selection-wrapper-visible" : isVisible }'
- );
- container.appendChild(el);
- this._element = el;
- const svgNS = "http://www.w3.org/2000/svg";
- const path =
- "M -34 -34 L -34 -11.25 L -30 -15.25 L -30 -30 L -15.25 -30 L -11.25 -34 L -34 -34 z M 11.25 -34 L 15.25 -30 L 30 -30 L 30 -15.25 L 34 -11.25 L 34 -34 L 11.25 -34 z M -34 11.25 L -34 34 L -11.25 34 L -15.25 30 L -30 30 L -30 15.25 L -34 11.25 z M 34 11.25 L 30 15.25 L 30 30 L 15.25 30 L 11.25 34 L 34 34 L 34 11.25 z";
- const svg = document.createElementNS(svgNS, "svg:svg");
- svg.setAttribute("width", 160);
- svg.setAttribute("height", 160);
- svg.setAttribute("viewBox", "0 0 160 160");
- const group = document.createElementNS(svgNS, "g");
- group.setAttribute("transform", "translate(80,80)");
- svg.appendChild(group);
- const pathElement = document.createElementNS(svgNS, "path");
- pathElement.setAttribute("data-bind", "attr: { transform: _transform }");
- pathElement.setAttribute("d", path);
- group.appendChild(pathElement);
- el.appendChild(svg);
- const viewModel = new SelectionIndicatorViewModel(
- scene,
- this._element,
- this._container
- );
- this._viewModel = viewModel;
- knockout.applyBindings(this._viewModel, this._element);
- }
- Object.defineProperties(SelectionIndicator.prototype, {
- /**
- * Gets the parent container.
- * @memberof SelectionIndicator.prototype
- *
- * @type {Element}
- */
- container: {
- get: function () {
- return this._container;
- },
- },
- /**
- * Gets the view model.
- * @memberof SelectionIndicator.prototype
- *
- * @type {SelectionIndicatorViewModel}
- */
- viewModel: {
- get: function () {
- return this._viewModel;
- },
- },
- });
- /**
- * @returns {boolean} true if the object has been destroyed, false otherwise.
- */
- SelectionIndicator.prototype.isDestroyed = function () {
- return false;
- };
- /**
- * Destroys the widget. Should be called if permanently
- * removing the widget from layout.
- */
- SelectionIndicator.prototype.destroy = function () {
- const container = this._container;
- knockout.cleanNode(this._element);
- container.removeChild(this._element);
- return destroyObject(this);
- };
- export default SelectionIndicator;
|