QuaternionCurve.lua 1.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940
  1. class "QuaternionCurve"
  2. function QuaternionCurve:QuaternionCurve(...)
  3. for k,v in pairs(arg) do
  4. if type(v) == "table" then
  5. if v.__ptr ~= nil then
  6. arg[k] = v.__ptr
  7. end
  8. end
  9. end
  10. if self.__ptr == nil and arg[1] ~= "__skip_ptr__" then
  11. self.__ptr = Polycore.QuaternionCurve(unpack(arg))
  12. end
  13. end
  14. function QuaternionCurve:interpolate(t, useShortestPath)
  15. local retVal = Polycore.QuaternionCurve_interpolate(self.__ptr, t, useShortestPath)
  16. if Polycore.__ptr_lookup[retVal] ~= nil then
  17. return Polycore.__ptr_lookup[retVal]
  18. else
  19. Polycore.__ptr_lookup[retVal] = Quaternion("__skip_ptr__")
  20. Polycore.__ptr_lookup[retVal].__ptr = retVal
  21. return Polycore.__ptr_lookup[retVal]
  22. end
  23. end
  24. function QuaternionCurve:generatePointsFromCurves(wCurve, xCurve, yCurve, zCurve)
  25. local retVal = Polycore.QuaternionCurve_generatePointsFromCurves(self.__ptr, wCurve.__ptr, xCurve.__ptr, yCurve.__ptr, zCurve.__ptr)
  26. end
  27. function QuaternionCurve:recalcTangents()
  28. local retVal = Polycore.QuaternionCurve_recalcTangents(self.__ptr)
  29. end