All Downloads are FREE. Search and download functionalities are using the official Maven repository.

main.cesium.CatmullRomSpline.kt Maven / Gradle / Ivy

// Automatically generated - do not modify!

@file:JsModule("cesium")

@file:Suppress(
    "NON_EXTERNAL_DECLARATION_IN_INAPPROPRIATE_FILE",
)

package cesium

/**
 * A Catmull-Rom spline is a cubic spline where the tangent at control points,
 * except the first and last, are computed using the previous and next control points.
 * Catmull-Rom splines are in the class C1.
 * ```
 * // spline above the earth from Philadelphia to Los Angeles
 * const spline = new CatmullRomSpline({
 *     times : [ 0.0, 1.5, 3.0, 4.5, 6.0 ],
 *     points : [
 *         new Cartesian3(1235398.0, -4810983.0, 4146266.0),
 *         new Cartesian3(1372574.0, -5345182.0, 4606657.0),
 *         new Cartesian3(-757983.0, -5542796.0, 4514323.0),
 *         new Cartesian3(-2821260.0, -5248423.0, 4021290.0),
 *         new Cartesian3(-2539788.0, -4724797.0, 3620093.0)
 *     ]
 * });
 *
 * const p0 = spline.evaluate(times[i]);         // equal to positions[i]
 * const p1 = spline.evaluate(times[i] + delta); // interpolated value when delta < times[i + 1] - times[i]
 * ```
 * @see Online Documentation
 */
external class CatmullRomSpline(options: ConstructorOptions) {
    /**
     * @property [times] An array of strictly increasing, unit-less, floating-point times at each point.
     *   The values are in no way connected to the clock time. They are the parameterization for the curve.
     * @property [points] The array of [Cartesian3] control points.
     * @property [firstTangent] The tangent of the curve at the first control point.
     *   If the tangent is not given, it will be estimated.
     * @property [lastTangent] The tangent of the curve at the last control point.
     *   If the tangent is not given, it will be estimated.
     */
    interface ConstructorOptions {
        var times: Array
        var points: Array
        var firstTangent: Cartesian3?
        var lastTangent: Cartesian3?
    }

    /**
     * An array of times for the control points.
     * @see Online Documentation
     */
    val times: Array

    /**
     * An array of [Cartesian3] control points.
     * @see Online Documentation
     */
    val points: Array

    /**
     * The tangent at the first control point.
     * @see Online Documentation
     */
    val firstTangent: Cartesian3

    /**
     * The tangent at the last control point.
     * @see Online Documentation
     */
    val lastTangent: Cartesian3

    /**
     * Finds an index `i` in `times` such that the parameter
     * `time` is in the interval `[times[i], times[i + 1]]`.
     * @param [time] The time.
     * @return The index for the element at the start of the interval.
     * @see Online Documentation
     */
    fun findTimeInterval(time: Double): Int

    /**
     * Wraps the given time to the period covered by the spline.
     * @param [time] The time.
     * @return The time, wrapped around to the updated animation.
     * @see Online Documentation
     */
    fun wrapTime(time: Double): Double

    /**
     * Clamps the given time to the period covered by the spline.
     * @param [time] The time.
     * @return The time, clamped to the animation period.
     * @see Online Documentation
     */
    fun clampTime(time: Double): Double

    /**
     * Evaluates the curve at a given time.
     * @param [time] The time at which to evaluate the curve.
     * @param [result] The object onto which to store the result.
     * @return The modified result parameter or a new instance of the point on the curve at the given time.
     * @see Online Documentation
     */
    fun evaluate(
        time: Double,
        result: Cartesian3? = definedExternally,
    ): Cartesian3
}

inline fun CatmullRomSpline(
    block: CatmullRomSpline.ConstructorOptions.() -> Unit,
): CatmullRomSpline {
    val options: CatmullRomSpline.ConstructorOptions = js("({})")
    block(options)
    return CatmullRomSpline(options)
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy