catmullRom method

num catmullRom(
  1. List v,
  2. num k
)

Implementation

num catmullRom (List v, num k) {
  int m = v.length - 1;
  num f = m * k;
  int i = f.floor();
  var fn = Utils.catmullRom;
  if (v[0] == v[m]) {
    if (k < 0) {
      i = ((f = m * (1 + k))).floor();
    }
    return fn(v[(i - 1 + m) % m], v[i], v[(i + 1) % m], v[(i + 2) % m], f - i);
  }
  else {
    if (k < 0) {
      return v[0] - (fn(v[0], v[0], v[1], v[1], -f) - v[0]);
    }
    if (k > 1) {
      return v[m] - (fn(v[m], v[m], v[m - 1], v[m - 1], f - m) - v[m]);
    }
    return fn(v[i > 0? i - 1 : 0], v[i], v[m < i + 1 ? m : i + 1], v[m < i + 2 ? m : i + 2], f - i);
  }
}