MorphWeightSpline

new Cesium.MorphWeightSpline(options)

对变形目标使用的权重值数组进行线性插值的样条。
Name Type Description
options object 具有以下属性的对象:
Name Type Description
times Array.<number> 每个点的严格递增、无单位浮点时间数组。 这些值与时钟时间无关,它们是曲线的参数化。
weights Array.<number> 给定的浮点控制权重数组。权重按以下方式排序: 所有目标的权重按时间顺序和它们在 glTF 中出现的顺序排列, 其中变形目标来自该 glTF。这意味着对于 2 个目标,weights = [w(0,0), w(0,1), w(1,0), w(1,1) ...] 其中 w(i,j) 中的 i 和 j 分别是时间索引和目标索引。
Throws:
Example:
const times = [ 0.0, 1.5, 3.0, 4.5, 6.0 ];
const weights = [0.0, 1.0, 0.25, 0.75, 0.5, 0.5, 0.75, 0.25, 1.0, 0.0]; // 两个目标
const spline = new Cesium.WeightSpline({
    times : times,
    weights : weights
});

const p0 = spline.evaluate(times[0]);
See:

Methods

clampTime(time)number

将给定时间钳制到样条覆盖的周期内。
Name Type Description
time number 时间。
Returns:
钳制到动画周期的时间。

evaluate(time, result)Array.<number>

在给定时间评估曲线。
Name Type Description
time number 评估曲线的时间。
result Array.<number> optional 存储结果的对象。
Returns:
修改后的结果参数,或给定时间曲线上的新点实例。
Throws:
  • DeveloperError : time 必须在范围 [t0, tn] 内,其中 t0 是数组 times 的第一个元素,tn 是数组 times 的最后一个元素。

findTimeInterval(time)number

times 中查找索引 i,使得参数 time 位于区间 [times[i], times[i + 1]] 内。
Name Type Description
time number 时间。
Returns:
区间起始元素的索引。
Throws:
  • DeveloperError : time 必须在范围 [t0, tn] 内,其中 t0 是数组 times 的第一个元素,tn 是数组 times 的最后一个元素。
将给定时间环绕到样条覆盖的周期内。
Name Type Description
time number 时间。
Returns:
环绕更新后的动画时间。
Need help? The fastest way to get answers is from the community and team on the Cesium Forum.