LinearCurve.cpp 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. // Jolt Physics Library (https://github.com/jrouwe/JoltPhysics)
  2. // SPDX-FileCopyrightText: 2021 Jorrit Rouwe
  3. // SPDX-License-Identifier: MIT
  4. #include <Jolt/Jolt.h>
  5. #include <Jolt/Core/LinearCurve.h>
  6. #include <Jolt/Core/StreamIn.h>
  7. #include <Jolt/Core/StreamOut.h>
  8. #include <Jolt/ObjectStream/TypeDeclarations.h>
  9. JPH_NAMESPACE_BEGIN
  10. JPH_IMPLEMENT_SERIALIZABLE_NON_VIRTUAL(LinearCurve::Point)
  11. {
  12. JPH_ADD_ATTRIBUTE(Point, mX)
  13. JPH_ADD_ATTRIBUTE(Point, mY)
  14. }
  15. JPH_IMPLEMENT_SERIALIZABLE_NON_VIRTUAL(LinearCurve)
  16. {
  17. JPH_ADD_ATTRIBUTE(LinearCurve, mPoints)
  18. }
  19. float LinearCurve::GetValue(float inX) const
  20. {
  21. if (mPoints.empty())
  22. return 0.0f;
  23. Points::const_iterator i2 = lower_bound(mPoints.begin(), mPoints.end(), inX, [](const Point &inPoint, float inValue) { return inPoint.mX < inValue; });
  24. if (i2 == mPoints.begin())
  25. return mPoints.front().mY;
  26. else if (i2 == mPoints.end())
  27. return mPoints.back().mY;
  28. Points::const_iterator i1 = i2 - 1;
  29. return i1->mY + (inX - i1->mX) * (i2->mY - i1->mY) / (i2->mX - i1->mX);
  30. }
  31. void LinearCurve::SaveBinaryState(StreamOut &inStream) const
  32. {
  33. inStream.Write(mPoints);
  34. }
  35. void LinearCurve::RestoreBinaryState(StreamIn &inStream)
  36. {
  37. inStream.Read(mPoints);
  38. }
  39. JPH_NAMESPACE_END