initial commit, 4.5 stable
Some checks failed
🔗 GHA / 📊 Static checks (push) Has been cancelled
🔗 GHA / 🤖 Android (push) Has been cancelled
🔗 GHA / 🍏 iOS (push) Has been cancelled
🔗 GHA / 🐧 Linux (push) Has been cancelled
🔗 GHA / 🍎 macOS (push) Has been cancelled
🔗 GHA / 🏁 Windows (push) Has been cancelled
🔗 GHA / 🌐 Web (push) Has been cancelled
Some checks failed
🔗 GHA / 📊 Static checks (push) Has been cancelled
🔗 GHA / 🤖 Android (push) Has been cancelled
🔗 GHA / 🍏 iOS (push) Has been cancelled
🔗 GHA / 🐧 Linux (push) Has been cancelled
🔗 GHA / 🍎 macOS (push) Has been cancelled
🔗 GHA / 🏁 Windows (push) Has been cancelled
🔗 GHA / 🌐 Web (push) Has been cancelled
This commit is contained in:
51
thirdparty/jolt_physics/Jolt/Core/LinearCurve.cpp
vendored
Normal file
51
thirdparty/jolt_physics/Jolt/Core/LinearCurve.cpp
vendored
Normal file
@@ -0,0 +1,51 @@
|
||||
// Jolt Physics Library (https://github.com/jrouwe/JoltPhysics)
|
||||
// SPDX-FileCopyrightText: 2021 Jorrit Rouwe
|
||||
// SPDX-License-Identifier: MIT
|
||||
|
||||
#include <Jolt/Jolt.h>
|
||||
|
||||
#include <Jolt/Core/LinearCurve.h>
|
||||
#include <Jolt/Core/StreamIn.h>
|
||||
#include <Jolt/Core/StreamOut.h>
|
||||
#include <Jolt/ObjectStream/TypeDeclarations.h>
|
||||
|
||||
JPH_NAMESPACE_BEGIN
|
||||
|
||||
JPH_IMPLEMENT_SERIALIZABLE_NON_VIRTUAL(LinearCurve::Point)
|
||||
{
|
||||
JPH_ADD_ATTRIBUTE(Point, mX)
|
||||
JPH_ADD_ATTRIBUTE(Point, mY)
|
||||
}
|
||||
|
||||
JPH_IMPLEMENT_SERIALIZABLE_NON_VIRTUAL(LinearCurve)
|
||||
{
|
||||
JPH_ADD_ATTRIBUTE(LinearCurve, mPoints)
|
||||
}
|
||||
|
||||
float LinearCurve::GetValue(float inX) const
|
||||
{
|
||||
if (mPoints.empty())
|
||||
return 0.0f;
|
||||
|
||||
Points::const_iterator i2 = std::lower_bound(mPoints.begin(), mPoints.end(), inX, [](const Point &inPoint, float inValue) { return inPoint.mX < inValue; });
|
||||
|
||||
if (i2 == mPoints.begin())
|
||||
return mPoints.front().mY;
|
||||
else if (i2 == mPoints.end())
|
||||
return mPoints.back().mY;
|
||||
|
||||
Points::const_iterator i1 = i2 - 1;
|
||||
return i1->mY + (inX - i1->mX) * (i2->mY - i1->mY) / (i2->mX - i1->mX);
|
||||
}
|
||||
|
||||
void LinearCurve::SaveBinaryState(StreamOut &inStream) const
|
||||
{
|
||||
inStream.Write(mPoints);
|
||||
}
|
||||
|
||||
void LinearCurve::RestoreBinaryState(StreamIn &inStream)
|
||||
{
|
||||
inStream.Read(mPoints);
|
||||
}
|
||||
|
||||
JPH_NAMESPACE_END
|
Reference in New Issue
Block a user