| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373 | import Cartesian3 from "../Core/Cartesian3.js";import Check from "../Core/Check.js";import Color from "../Core/Color.js";import ColorGeometryInstanceAttribute from "../Core/ColorGeometryInstanceAttribute.js";import CylinderGeometry from "../Core/CylinderGeometry.js";import CylinderOutlineGeometry from "../Core/CylinderOutlineGeometry.js";import defined from "../Core/defined.js";import DeveloperError from "../Core/DeveloperError.js";import DistanceDisplayConditionGeometryInstanceAttribute from "../Core/DistanceDisplayConditionGeometryInstanceAttribute.js";import GeometryInstance from "../Core/GeometryInstance.js";import GeometryOffsetAttribute from "../Core/GeometryOffsetAttribute.js";import Iso8601 from "../Core/Iso8601.js";import OffsetGeometryInstanceAttribute from "../Core/OffsetGeometryInstanceAttribute.js";import ShowGeometryInstanceAttribute from "../Core/ShowGeometryInstanceAttribute.js";import HeightReference from "../Scene/HeightReference.js";import MaterialAppearance from "../Scene/MaterialAppearance.js";import PerInstanceColorAppearance from "../Scene/PerInstanceColorAppearance.js";import ColorMaterialProperty from "./ColorMaterialProperty.js";import DynamicGeometryUpdater from "./DynamicGeometryUpdater.js";import GeometryUpdater from "./GeometryUpdater.js";import heightReferenceOnEntityPropertyChanged from "./heightReferenceOnEntityPropertyChanged.js";import Property from "./Property.js";const defaultOffset = Cartesian3.ZERO;const offsetScratch = new Cartesian3();const positionScratch = new Cartesian3();const scratchColor = new Color();function CylinderGeometryOptions(entity) {  this.id = entity;  this.vertexFormat = undefined;  this.length = undefined;  this.topRadius = undefined;  this.bottomRadius = undefined;  this.slices = undefined;  this.numberOfVerticalLines = undefined;  this.offsetAttribute = undefined;}/** * A {@link GeometryUpdater} for cylinders. * Clients do not normally create this class directly, but instead rely on {@link DataSourceDisplay}. * @alias CylinderGeometryUpdater * @constructor * * @param {Entity} entity The entity containing the geometry to be visualized. * @param {Scene} scene The scene where visualization is taking place. */function CylinderGeometryUpdater(entity, scene) {  GeometryUpdater.call(this, {    entity: entity,    scene: scene,    geometryOptions: new CylinderGeometryOptions(entity),    geometryPropertyName: "cylinder",    observedPropertyNames: [      "availability",      "position",      "orientation",      "cylinder",    ],  });  this._onEntityPropertyChanged(entity, "cylinder", entity.cylinder, undefined);}if (defined(Object.create)) {  CylinderGeometryUpdater.prototype = Object.create(GeometryUpdater.prototype);  CylinderGeometryUpdater.prototype.constructor = CylinderGeometryUpdater;}Object.defineProperties(CylinderGeometryUpdater.prototype, {  /**   * Gets the terrain offset property   * @type {TerrainOffsetProperty}   * @memberof CylinderGeometryUpdater.prototype   * @readonly   * @private   */  terrainOffsetProperty: {    get: function () {      return this._terrainOffsetProperty;    },  },});/** * Creates the geometry instance which represents the fill of the geometry. * * @param {JulianDate} time The time to use when retrieving initial attribute values. * @returns {GeometryInstance} The geometry instance representing the filled portion of the geometry. * * @exception {DeveloperError} This instance does not represent a filled geometry. */CylinderGeometryUpdater.prototype.createFillGeometryInstance = function (time) {  //>>includeStart('debug', pragmas.debug);  Check.defined("time", time);  if (!this._fillEnabled) {    throw new DeveloperError(      "This instance does not represent a filled geometry."    );  }  //>>includeEnd('debug');  const entity = this._entity;  const isAvailable = entity.isAvailable(time);  const show = new ShowGeometryInstanceAttribute(    isAvailable &&      entity.isShowing &&      this._showProperty.getValue(time) &&      this._fillProperty.getValue(time)  );  const distanceDisplayCondition = this._distanceDisplayConditionProperty.getValue(    time  );  const distanceDisplayConditionAttribute = DistanceDisplayConditionGeometryInstanceAttribute.fromDistanceDisplayCondition(    distanceDisplayCondition  );  const attributes = {    show: show,    distanceDisplayCondition: distanceDisplayConditionAttribute,    color: undefined,    offset: undefined,  };  if (this._materialProperty instanceof ColorMaterialProperty) {    let currentColor;    if (      defined(this._materialProperty.color) &&      (this._materialProperty.color.isConstant || isAvailable)    ) {      currentColor = this._materialProperty.color.getValue(time, scratchColor);    }    if (!defined(currentColor)) {      currentColor = Color.WHITE;    }    attributes.color = ColorGeometryInstanceAttribute.fromColor(currentColor);  }  if (defined(this._options.offsetAttribute)) {    attributes.offset = OffsetGeometryInstanceAttribute.fromCartesian3(      Property.getValueOrDefault(        this._terrainOffsetProperty,        time,        defaultOffset,        offsetScratch      )    );  }  return new GeometryInstance({    id: entity,    geometry: new CylinderGeometry(this._options),    modelMatrix: entity.computeModelMatrixForHeightReference(      time,      entity.cylinder.heightReference,      this._options.length * 0.5,      this._scene.mapProjection.ellipsoid    ),    attributes: attributes,  });};/** * Creates the geometry instance which represents the outline of the geometry. * * @param {JulianDate} time The time to use when retrieving initial attribute values. * @returns {GeometryInstance} The geometry instance representing the outline portion of the geometry. * * @exception {DeveloperError} This instance does not represent an outlined geometry. */CylinderGeometryUpdater.prototype.createOutlineGeometryInstance = function (  time) {  //>>includeStart('debug', pragmas.debug);  Check.defined("time", time);  if (!this._outlineEnabled) {    throw new DeveloperError(      "This instance does not represent an outlined geometry."    );  }  //>>includeEnd('debug');  const entity = this._entity;  const isAvailable = entity.isAvailable(time);  const outlineColor = Property.getValueOrDefault(    this._outlineColorProperty,    time,    Color.BLACK,    scratchColor  );  const distanceDisplayCondition = this._distanceDisplayConditionProperty.getValue(    time  );  const attributes = {    show: new ShowGeometryInstanceAttribute(      isAvailable &&        entity.isShowing &&        this._showProperty.getValue(time) &&        this._showOutlineProperty.getValue(time)    ),    color: ColorGeometryInstanceAttribute.fromColor(outlineColor),    distanceDisplayCondition: DistanceDisplayConditionGeometryInstanceAttribute.fromDistanceDisplayCondition(      distanceDisplayCondition    ),    offset: undefined,  };  if (defined(this._options.offsetAttribute)) {    attributes.offset = OffsetGeometryInstanceAttribute.fromCartesian3(      Property.getValueOrDefault(        this._terrainOffsetProperty,        time,        defaultOffset,        offsetScratch      )    );  }  return new GeometryInstance({    id: entity,    geometry: new CylinderOutlineGeometry(this._options),    modelMatrix: entity.computeModelMatrixForHeightReference(      time,      entity.cylinder.heightReference,      this._options.length * 0.5,      this._scene.mapProjection.ellipsoid    ),    attributes: attributes,  });};CylinderGeometryUpdater.prototype._computeCenter = function (time, result) {  return Property.getValueOrUndefined(this._entity.position, time, result);};CylinderGeometryUpdater.prototype._isHidden = function (entity, cylinder) {  return (    !defined(entity.position) ||    !defined(cylinder.length) ||    !defined(cylinder.topRadius) ||    !defined(cylinder.bottomRadius) ||    GeometryUpdater.prototype._isHidden.call(this, entity, cylinder)  );};CylinderGeometryUpdater.prototype._isDynamic = function (entity, cylinder) {  return (    !entity.position.isConstant || //    !Property.isConstant(entity.orientation) || //    !cylinder.length.isConstant || //    !cylinder.topRadius.isConstant || //    !cylinder.bottomRadius.isConstant || //    !Property.isConstant(cylinder.slices) || //    !Property.isConstant(cylinder.outlineWidth) || //    !Property.isConstant(cylinder.numberOfVerticalLines)  );};CylinderGeometryUpdater.prototype._setStaticOptions = function (  entity,  cylinder) {  const heightReference = Property.getValueOrDefault(    cylinder.heightReference,    Iso8601.MINIMUM_VALUE,    HeightReference.NONE  );  const options = this._options;  options.vertexFormat =    this._materialProperty instanceof ColorMaterialProperty      ? PerInstanceColorAppearance.VERTEX_FORMAT      : MaterialAppearance.MaterialSupport.TEXTURED.vertexFormat;  options.length = cylinder.length.getValue(Iso8601.MINIMUM_VALUE);  options.topRadius = cylinder.topRadius.getValue(Iso8601.MINIMUM_VALUE);  options.bottomRadius = cylinder.bottomRadius.getValue(Iso8601.MINIMUM_VALUE);  options.slices = Property.getValueOrUndefined(    cylinder.slices,    Iso8601.MINIMUM_VALUE  );  options.numberOfVerticalLines = Property.getValueOrUndefined(    cylinder.numberOfVerticalLines,    Iso8601.MINIMUM_VALUE  );  options.offsetAttribute =    heightReference !== HeightReference.NONE      ? GeometryOffsetAttribute.ALL      : undefined;};CylinderGeometryUpdater.prototype._onEntityPropertyChanged = heightReferenceOnEntityPropertyChanged;CylinderGeometryUpdater.DynamicGeometryUpdater = DynamicCylinderGeometryUpdater;/** * @private */function DynamicCylinderGeometryUpdater(  geometryUpdater,  primitives,  groundPrimitives) {  DynamicGeometryUpdater.call(    this,    geometryUpdater,    primitives,    groundPrimitives  );}if (defined(Object.create)) {  DynamicCylinderGeometryUpdater.prototype = Object.create(    DynamicGeometryUpdater.prototype  );  DynamicCylinderGeometryUpdater.prototype.constructor = DynamicCylinderGeometryUpdater;}DynamicCylinderGeometryUpdater.prototype._isHidden = function (  entity,  cylinder,  time) {  const options = this._options;  const position = Property.getValueOrUndefined(    entity.position,    time,    positionScratch  );  return (    !defined(position) ||    !defined(options.length) ||    !defined(options.topRadius) || //    !defined(options.bottomRadius) ||    DynamicGeometryUpdater.prototype._isHidden.call(      this,      entity,      cylinder,      time    )  );};DynamicCylinderGeometryUpdater.prototype._setOptions = function (  entity,  cylinder,  time) {  const heightReference = Property.getValueOrDefault(    cylinder.heightReference,    time,    HeightReference.NONE  );  const options = this._options;  options.length = Property.getValueOrUndefined(cylinder.length, time);  options.topRadius = Property.getValueOrUndefined(cylinder.topRadius, time);  options.bottomRadius = Property.getValueOrUndefined(    cylinder.bottomRadius,    time  );  options.slices = Property.getValueOrUndefined(cylinder.slices, time);  options.numberOfVerticalLines = Property.getValueOrUndefined(    cylinder.numberOfVerticalLines,    time  );  options.offsetAttribute =    heightReference !== HeightReference.NONE      ? GeometryOffsetAttribute.ALL      : undefined;};export default CylinderGeometryUpdater;
 |