Methods
(static) computeFixedToIcrfMatrix(date, resultopt) → {Matrix3}
Computes a rotation matrix to transform a point or vector from the Earth-Fixed frame axes (ITRF)
to the International Celestial Reference Frame (GCRF/ICRF) inertial frame axes
at a given time. This function may return undefined if the data necessary to
do the transformation is not yet loaded.
Parameters:
Name | Type | Attributes | Description |
---|---|---|---|
date |
JulianDate | The time at which to compute the rotation matrix. | |
result |
Matrix3 |
<optional> |
The object onto which to store the result. If this parameter is not specified, a new instance is created and returned. |
- Source:
- See:
-
- Transforms.preloadIcrfFixed
Returns:
The rotation matrix, or undefined if the data necessary to do the
transformation is not yet loaded.
- Type
- Matrix3
Example
// Transform a point from the ICRF axes to the Fixed axes.
var now = Cesium.JulianDate.now();
var pointInFixed = Cesium.Cartesian3.fromDegrees(0.0, 0.0);
var fixedToIcrf = Cesium.Transforms.computeIcrfToFixedMatrix(now);
var pointInInertial = new Cesium.Cartesian3();
if (Cesium.defined(fixedToIcrf)) {
pointInInertial = Cesium.Matrix3.multiplyByVector(fixedToIcrf, pointInFixed, pointInInertial);
}
(static) computeIcrfToFixedMatrix(date, resultopt) → {Matrix3}
Computes a rotation matrix to transform a point or vector from the International Celestial
Reference Frame (GCRF/ICRF) inertial frame axes to the Earth-Fixed frame axes (ITRF)
at a given time. This function may return undefined if the data necessary to
do the transformation is not yet loaded.
Parameters:
Name | Type | Attributes | Description |
---|---|---|---|
date |
JulianDate | The time at which to compute the rotation matrix. | |
result |
Matrix3 |
<optional> |
The object onto which to store the result. If this parameter is not specified, a new instance is created and returned. |
- Source:
- See:
-
- Transforms.preloadIcrfFixed
Returns:
The rotation matrix, or undefined if the data necessary to do the
transformation is not yet loaded.
- Type
- Matrix3
Example
scene.preRender.addEventListener(function(scene, time) {
var icrfToFixed = Cesium.Transforms.computeIcrfToFixedMatrix(time);
if (Cesium.defined(icrfToFixed)) {
var offset = Cesium.Matrix4.multiplyByPoint(camera.transform, camera.position, new Cesium.Cartesian3());
var transform = Cesium.Matrix4.fromRotationTranslation(icrfToFixed)
var inverseTransform = Cesium.Matrix4.inverseTransformation(transform, new Cesium.Matrix4());
Cesium.Matrix4.multiplyByPoint(inverseTransform, offset, offset);
camera.lookAtTransform(transform, offset);
}
});
(static) computeTemeToPseudoFixedMatrix(date, resultopt) → {Matrix3}
Computes a rotation matrix to transform a point or vector from True Equator Mean Equinox (TEME) axes to the
pseudo-fixed axes at a given time. This method treats the UT1 time standard as equivalent to UTC.
Parameters:
Name | Type | Attributes | Description |
---|---|---|---|
date |
JulianDate | The time at which to compute the rotation matrix. | |
result |
Matrix3 |
<optional> |
The object onto which to store the result. |
- Source:
Returns:
The modified result parameter or a new Matrix3 instance if none was provided.
- Type
- Matrix3
Example
//Set the view to in the inertial frame.
scene.preRender.addEventListener(function(scene, time) {
var now = Cesium.JulianDate.now();
var offset = Cesium.Matrix4.multiplyByPoint(camera.transform, camera.position, new Cesium.Cartesian3());
var transform = Cesium.Matrix4.fromRotationTranslation(Cesium.Transforms.computeTemeToPseudoFixedMatrix(now));
var inverseTransform = Cesium.Matrix4.inverseTransformation(transform, new Cesium.Matrix4());
Cesium.Matrix4.multiplyByPoint(inverseTransform, offset, offset);
camera.lookAtTransform(transform, offset);
});
(static) eastNorthUpToFixedFrame(origin, ellipsoidopt, resultopt) → {Matrix4}
Computes a 4x4 transformation matrix from a reference frame with an east-north-up axes
centered at the provided origin to the provided ellipsoid's fixed reference frame.
The local axes are defined as:
- The
x
axis points in the local east direction. - The
y
axis points in the local north direction. - The
z
axis points in the direction of the ellipsoid surface normal which passes through the position.
Parameters:
Name | Type | Attributes | Default | Description |
---|---|---|---|---|
origin |
Cartesian3 | The center point of the local reference frame. | ||
ellipsoid |
Ellipsoid |
<optional> |
Ellipsoid.WGS84 | The ellipsoid whose fixed frame is used in the transformation. |
result |
Matrix4 |
<optional> |
The object onto which to store the result. |
- Source:
Returns:
The modified result parameter or a new Matrix4 instance if none was provided.
- Type
- Matrix4
Example
// Get the transform from local east-north-up at cartographic (0.0, 0.0) to Earth's fixed frame.
var center = Cesium.Cartesian3.fromDegrees(0.0, 0.0);
var transform = Cesium.Transforms.eastNorthUpToFixedFrame(center);
(static) headingPitchRollQuaternion(origin, headingPitchRoll, ellipsoidopt, resultopt) → {Quaternion}
Computes a quaternion from a reference frame with axes computed from the heading-pitch-roll angles
centered at the provided origin. Heading is the rotation from the local north
direction where a positive angle is increasing eastward. Pitch is the rotation from the local east-north plane. Positive pitch angles
are above the plane. Negative pitch angles are below the plane. Roll is the first rotation applied about the local east axis.
Parameters:
Name | Type | Attributes | Default | Description |
---|---|---|---|---|
origin |
Cartesian3 | The center point of the local reference frame. | ||
headingPitchRoll |
HeadingPitchRoll | The heading, pitch, and roll. | ||
ellipsoid |
Ellipsoid |
<optional> |
Ellipsoid.WGS84 | The ellipsoid whose fixed frame is used in the transformation. |
result |
Quaternion |
<optional> |
The object onto which to store the result. |
- Source:
Returns:
The modified result parameter or a new Quaternion instance if none was provided.
- Type
- Quaternion
Example
// Get the quaternion from local heading-pitch-roll at cartographic (0.0, 0.0) to Earth's fixed frame.
var center = Cesium.Cartesian3.fromDegrees(0.0, 0.0);
var heading = -Cesium.Math.PI_OVER_TWO;
var pitch = Cesium.Math.PI_OVER_FOUR;
var roll = 0.0;
var hpr = new HeadingPitchRoll(heading, pitch, roll);
var quaternion = Cesium.Transforms.headingPitchRollQuaternion(center, hpr);
(static) headingPitchRollToFixedFrame(origin, headingPitchRoll, ellipsoidopt, resultopt) → {Matrix4}
Computes a 4x4 transformation matrix from a reference frame with axes computed from the heading-pitch-roll angles
centered at the provided origin to the provided ellipsoid's fixed reference frame. Heading is the rotation from the local north
direction where a positive angle is increasing eastward. Pitch is the rotation from the local east-north plane. Positive pitch angles
are above the plane. Negative pitch angles are below the plane. Roll is the first rotation applied about the local east axis.
Parameters:
Name | Type | Attributes | Default | Description |
---|---|---|---|---|
origin |
Cartesian3 | The center point of the local reference frame. | ||
headingPitchRoll |
HeadingPitchRoll | The heading, pitch, and roll. | ||
ellipsoid |
Ellipsoid |
<optional> |
Ellipsoid.WGS84 | The ellipsoid whose fixed frame is used in the transformation. |
result |
Matrix4 |
<optional> |
The object onto which to store the result. |
- Source:
Returns:
The modified result parameter or a new Matrix4 instance if none was provided.
- Type
- Matrix4
Example
// Get the transform from local heading-pitch-roll at cartographic (0.0, 0.0) to Earth's fixed frame.
var center = Cesium.Cartesian3.fromDegrees(0.0, 0.0);
var heading = -Cesium.Math.PI_OVER_TWO;
var pitch = Cesium.Math.PI_OVER_FOUR;
var roll = 0.0;
var hpr = new Cesium.HeadingPitchRoll(heading, pitch, roll);
var transform = Cesium.Transforms.headingPitchRollToFixedFrame(center, hpr);
(static) northEastDownToFixedFrame(origin, ellipsoidopt, resultopt) → {Matrix4}
Computes a 4x4 transformation matrix from a reference frame with an north-east-down axes
centered at the provided origin to the provided ellipsoid's fixed reference frame.
The local axes are defined as:
- The
x
axis points in the local north direction. - The
y
axis points in the local east direction. - The
z
axis points in the opposite direction of the ellipsoid surface normal which passes through the position.
Parameters:
Name | Type | Attributes | Default | Description |
---|---|---|---|---|
origin |
Cartesian3 | The center point of the local reference frame. | ||
ellipsoid |
Ellipsoid |
<optional> |
Ellipsoid.WGS84 | The ellipsoid whose fixed frame is used in the transformation. |
result |
Matrix4 |
<optional> |
The object onto which to store the result. |
- Source:
Returns:
The modified result parameter or a new Matrix4 instance if none was provided.
- Type
- Matrix4
Example
// Get the transform from local north-east-down at cartographic (0.0, 0.0) to Earth's fixed frame.
var center = Cesium.Cartesian3.fromDegrees(0.0, 0.0);
var transform = Cesium.Transforms.northEastDownToFixedFrame(center);
(static) northUpEastToFixedFrame(origin, ellipsoidopt, resultopt) → {Matrix4}
Computes a 4x4 transformation matrix from a reference frame with an north-up-east axes
centered at the provided origin to the provided ellipsoid's fixed reference frame.
The local axes are defined as:
- The
x
axis points in the local north direction. - The
y
axis points in the direction of the ellipsoid surface normal which passes through the position. - The
z
axis points in the local east direction.
Parameters:
Name | Type | Attributes | Default | Description |
---|---|---|---|---|
origin |
Cartesian3 | The center point of the local reference frame. | ||
ellipsoid |
Ellipsoid |
<optional> |
Ellipsoid.WGS84 | The ellipsoid whose fixed frame is used in the transformation. |
result |
Matrix4 |
<optional> |
The object onto which to store the result. |
- Source:
Returns:
The modified result parameter or a new Matrix4 instance if none was provided.
- Type
- Matrix4
Example
// Get the transform from local north-up-east at cartographic (0.0, 0.0) to Earth's fixed frame.
var center = Cesium.Cartesian3.fromDegrees(0.0, 0.0);
var transform = Cesium.Transforms.northUpEastToFixedFrame(center);
(static) northWestUpToFixedFrame(origin, ellipsoidopt, resultopt) → {Matrix4}
Computes a 4x4 transformation matrix from a reference frame with an north-west-up axes
centered at the provided origin to the provided ellipsoid's fixed reference frame.
The local axes are defined as:
- The
x
axis points in the local north direction. - The
y
axis points in the local west direction. - The
z
axis points in the direction of the ellipsoid surface normal which passes through the position.
Parameters:
Name | Type | Attributes | Default | Description |
---|---|---|---|---|
origin |
Cartesian3 | The center point of the local reference frame. | ||
ellipsoid |
Ellipsoid |
<optional> |
Ellipsoid.WGS84 | The ellipsoid whose fixed frame is used in the transformation. |
result |
Matrix4 |
<optional> |
The object onto which to store the result. |
- Source:
Returns:
The modified result parameter or a new Matrix4 instance if none was provided.
- Type
- Matrix4
Example
// Get the transform from local north-West-Up at cartographic (0.0, 0.0) to Earth's fixed frame.
var center = Cesium.Cartesian3.fromDegrees(0.0, 0.0);
var transform = Cesium.Transforms.northWestUpToFixedFrame(center);
(static) pointToWindowCoordinates(modelViewProjectionMatrix, viewportTransformation, point, resultopt) → {Cartesian2}
Transform a point from model coordinates to window coordinates.
Parameters:
Name | Type | Attributes | Description |
---|---|---|---|
modelViewProjectionMatrix |
Matrix4 | The 4x4 model-view-projection matrix. | |
viewportTransformation |
Matrix4 | The 4x4 viewport transformation. | |
point |
Cartesian3 | The point to transform. | |
result |
Cartesian2 |
<optional> |
The object onto which to store the result. |
- Source:
Returns:
The modified result parameter or a new Cartesian2 instance if none was provided.
- Type
- Cartesian2
(static) preloadIcrfFixed(timeInterval) → {Promise.<undefined>}
Preloads the data necessary to transform between the ICRF and Fixed axes, in either
direction, over a given interval. This function returns a promise that, when resolved,
indicates that the preload has completed.
Parameters:
Name | Type | Description |
---|---|---|
timeInterval |
TimeInterval | The interval to preload. |
- Source:
- See:
-
- Transforms.computeIcrfToFixedMatrix
- Transforms.computeFixedToIcrfMatrix
- when
Returns:
A promise that, when resolved, indicates that the preload has completed
and evaluation of the transformation between the fixed and ICRF axes will
no longer return undefined for a time inside the interval.
- Type
- Promise.<undefined>
Example
var interval = new Cesium.TimeInterval(...);
when(Cesium.Transforms.preloadIcrfFixed(interval), function() {
// the data is now loaded
});