WeightSpline

对变形目标使用的权重值数组进行线性插值的样条线。
new WeightSpline(options)
Parameters:
options (Object)
Name Description
options.times
Array.<Number>
在每个点上严格递增的、无单位的浮点时间数组。这些值与时钟时间没有任何关系。它们是曲线的参数化。
options.weights
Array.<Number>
给定的浮点控制权重数组。对权重进行排序,以便按时间顺序给出目标的所有权重,并按照它们出现在变形目标所在的GLTF中的顺序给出权重。这意味着对于2个目标,权重=[w(0,0),w(0,1),w(1,0),w(1,1)…],其中i和j在w(i,j)中分别是时间指数和目标指数。
Example
var times = [ 0.0, 1.5, 3.0, 4.5, 6.0 ];
var weights = [0.0, 1.0, 0.25, 0.75, 0.5, 0.5, 0.75, 0.25, 1.0, 0.0]; //Two targets
var spline = new bmgl.WeightSpline({
    times : times,
    weights : weights
});

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

Members

(readonly) times : Array.<Number>

控制权重的时间数组。

(readonly) weights : Array.<Number>

浮点数组控制权的数组。

Methods

clampTime(time) → {Number}
将给定的时间钳制到样条曲线所覆盖的周期。
Parameters:
time (Number) 时间。
evaluate(time, result) → {Array.<Number>}
在给定时间计算曲线。
Parameters:
time (Number) 评估曲线的时间。
result (Array.<Number>) 存储结果的对象。
Throws
  • DeveloperError : 时间必须在[t0, tn]范围内,其中t0是数组times中的第一个元素,tn是数组times中的最后一个元素。
findTimeInterval(time) → {Number}
times中查找索引i,以便参数time在间隔[times[i], times[i + 1]]中。
Parameters:
time (Number) 时间。
Throws
  • DeveloperError : 时间必须在[t0, tn]范围内,其中t0是数组times中的第一个元素,tn是数组times中的最后一个元素。
wrapTime(time) → {Number}
将给定时间包装到样条曲线所覆盖的周期。
Parameters:
time (Number) 时间。