123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384 |
- 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 defined from "../Core/defined.js";
- import DeveloperError from "../Core/DeveloperError.js";
- import DistanceDisplayConditionGeometryInstanceAttribute from "../Core/DistanceDisplayConditionGeometryInstanceAttribute.js";
- import GeometryInstance from "../Core/GeometryInstance.js";
- import Iso8601 from "../Core/Iso8601.js";
- import CesiumMath from "../Core/Math.js";
- import Matrix3 from "../Core/Matrix3.js";
- import Matrix4 from "../Core/Matrix4.js";
- import PlaneGeometry from "../Core/PlaneGeometry.js";
- import PlaneOutlineGeometry from "../Core/PlaneOutlineGeometry.js";
- import ShowGeometryInstanceAttribute from "../Core/ShowGeometryInstanceAttribute.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 Property from "./Property.js";
- const positionScratch = new Cartesian3();
- const scratchColor = new Color();
- function PlaneGeometryOptions(entity) {
- this.id = entity;
- this.vertexFormat = undefined;
- this.plane = undefined;
- this.dimensions = undefined;
- }
- /**
- * A {@link GeometryUpdater} for planes.
- * Clients do not normally create this class directly, but instead rely on {@link DataSourceDisplay}.
- * @alias PlaneGeometryUpdater
- * @constructor
- *
- * @param {Entity} entity The entity containing the geometry to be visualized.
- * @param {Scene} scene The scene where visualization is taking place.
- */
- function PlaneGeometryUpdater(entity, scene) {
- GeometryUpdater.call(this, {
- entity: entity,
- scene: scene,
- geometryOptions: new PlaneGeometryOptions(entity),
- geometryPropertyName: "plane",
- observedPropertyNames: ["availability", "position", "orientation", "plane"],
- });
- this._onEntityPropertyChanged(entity, "plane", entity.plane, undefined);
- }
- if (defined(Object.create)) {
- PlaneGeometryUpdater.prototype = Object.create(GeometryUpdater.prototype);
- PlaneGeometryUpdater.prototype.constructor = PlaneGeometryUpdater;
- }
- /**
- * 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.
- */
- PlaneGeometryUpdater.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);
- let attributes;
- let color;
- 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
- );
- 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;
- }
- color = ColorGeometryInstanceAttribute.fromColor(currentColor);
- attributes = {
- show: show,
- distanceDisplayCondition: distanceDisplayConditionAttribute,
- color: color,
- };
- } else {
- attributes = {
- show: show,
- distanceDisplayCondition: distanceDisplayConditionAttribute,
- };
- }
- const planeGraphics = entity.plane;
- const options = this._options;
- let modelMatrix = entity.computeModelMatrix(time);
- const plane = Property.getValueOrDefault(
- planeGraphics.plane,
- time,
- options.plane
- );
- const dimensions = Property.getValueOrUndefined(
- planeGraphics.dimensions,
- time,
- options.dimensions
- );
- options.plane = plane;
- options.dimensions = dimensions;
- modelMatrix = createPrimitiveMatrix(
- plane,
- dimensions,
- modelMatrix,
- modelMatrix
- );
- return new GeometryInstance({
- id: entity,
- geometry: new PlaneGeometry(this._options),
- modelMatrix: modelMatrix,
- 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.
- */
- PlaneGeometryUpdater.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 planeGraphics = entity.plane;
- const options = this._options;
- let modelMatrix = entity.computeModelMatrix(time);
- const plane = Property.getValueOrDefault(
- planeGraphics.plane,
- time,
- options.plane
- );
- const dimensions = Property.getValueOrUndefined(
- planeGraphics.dimensions,
- time,
- options.dimensions
- );
- options.plane = plane;
- options.dimensions = dimensions;
- modelMatrix = createPrimitiveMatrix(
- plane,
- dimensions,
- modelMatrix,
- modelMatrix
- );
- return new GeometryInstance({
- id: entity,
- geometry: new PlaneOutlineGeometry(),
- modelMatrix: modelMatrix,
- attributes: {
- show: new ShowGeometryInstanceAttribute(
- isAvailable &&
- entity.isShowing &&
- this._showProperty.getValue(time) &&
- this._showOutlineProperty.getValue(time)
- ),
- color: ColorGeometryInstanceAttribute.fromColor(outlineColor),
- distanceDisplayCondition: DistanceDisplayConditionGeometryInstanceAttribute.fromDistanceDisplayCondition(
- distanceDisplayCondition
- ),
- },
- });
- };
- PlaneGeometryUpdater.prototype._isHidden = function (entity, plane) {
- return (
- !defined(plane.plane) ||
- !defined(plane.dimensions) ||
- !defined(entity.position) ||
- GeometryUpdater.prototype._isHidden.call(this, entity, plane)
- );
- };
- PlaneGeometryUpdater.prototype._getIsClosed = function (options) {
- return false;
- };
- PlaneGeometryUpdater.prototype._isDynamic = function (entity, plane) {
- return (
- !entity.position.isConstant || //
- !Property.isConstant(entity.orientation) || //
- !plane.plane.isConstant || //
- !plane.dimensions.isConstant || //
- !Property.isConstant(plane.outlineWidth)
- );
- };
- PlaneGeometryUpdater.prototype._setStaticOptions = function (entity, plane) {
- const isColorMaterial =
- this._materialProperty instanceof ColorMaterialProperty;
- const options = this._options;
- options.vertexFormat = isColorMaterial
- ? PerInstanceColorAppearance.VERTEX_FORMAT
- : MaterialAppearance.MaterialSupport.TEXTURED.vertexFormat;
- options.plane = plane.plane.getValue(Iso8601.MINIMUM_VALUE, options.plane);
- options.dimensions = plane.dimensions.getValue(
- Iso8601.MINIMUM_VALUE,
- options.dimensions
- );
- };
- PlaneGeometryUpdater.DynamicGeometryUpdater = DynamicPlaneGeometryUpdater;
- /**
- * @private
- */
- function DynamicPlaneGeometryUpdater(
- geometryUpdater,
- primitives,
- groundPrimitives
- ) {
- DynamicGeometryUpdater.call(
- this,
- geometryUpdater,
- primitives,
- groundPrimitives
- );
- }
- if (defined(Object.create)) {
- DynamicPlaneGeometryUpdater.prototype = Object.create(
- DynamicGeometryUpdater.prototype
- );
- DynamicPlaneGeometryUpdater.prototype.constructor = DynamicPlaneGeometryUpdater;
- }
- DynamicPlaneGeometryUpdater.prototype._isHidden = function (
- entity,
- plane,
- time
- ) {
- const options = this._options;
- const position = Property.getValueOrUndefined(
- entity.position,
- time,
- positionScratch
- );
- return (
- !defined(position) ||
- !defined(options.plane) ||
- !defined(options.dimensions) ||
- DynamicGeometryUpdater.prototype._isHidden.call(this, entity, plane, time)
- );
- };
- DynamicPlaneGeometryUpdater.prototype._setOptions = function (
- entity,
- plane,
- time
- ) {
- const options = this._options;
- options.plane = Property.getValueOrDefault(plane.plane, time, options.plane);
- options.dimensions = Property.getValueOrUndefined(
- plane.dimensions,
- time,
- options.dimensions
- );
- };
- const scratchAxis = new Cartesian3();
- const scratchUp = new Cartesian3();
- const scratchTranslation = new Cartesian3();
- const scratchScale = new Cartesian3();
- const scratchRotation = new Matrix3();
- const scratchRotationScale = new Matrix3();
- const scratchLocalTransform = new Matrix4();
- function createPrimitiveMatrix(plane, dimensions, transform, result) {
- const normal = plane.normal;
- const distance = plane.distance;
- const translation = Cartesian3.multiplyByScalar(
- normal,
- -distance,
- scratchTranslation
- );
- let up = Cartesian3.clone(Cartesian3.UNIT_Z, scratchUp);
- if (
- CesiumMath.equalsEpsilon(
- Math.abs(Cartesian3.dot(up, normal)),
- 1.0,
- CesiumMath.EPSILON8
- )
- ) {
- up = Cartesian3.clone(Cartesian3.UNIT_Y, up);
- }
- const left = Cartesian3.cross(up, normal, scratchAxis);
- up = Cartesian3.cross(normal, left, up);
- Cartesian3.normalize(left, left);
- Cartesian3.normalize(up, up);
- const rotationMatrix = scratchRotation;
- Matrix3.setColumn(rotationMatrix, 0, left, rotationMatrix);
- Matrix3.setColumn(rotationMatrix, 1, up, rotationMatrix);
- Matrix3.setColumn(rotationMatrix, 2, normal, rotationMatrix);
- const scale = Cartesian3.fromElements(
- dimensions.x,
- dimensions.y,
- 1.0,
- scratchScale
- );
- const rotationScaleMatrix = Matrix3.multiplyByScale(
- rotationMatrix,
- scale,
- scratchRotationScale
- );
- const localTransform = Matrix4.fromRotationTranslation(
- rotationScaleMatrix,
- translation,
- scratchLocalTransform
- );
- return Matrix4.multiplyTransformation(transform, localTransform, result);
- }
- /**
- * @private
- */
- PlaneGeometryUpdater.createPrimitiveMatrix = createPrimitiveMatrix;
- export default PlaneGeometryUpdater;
|