From 20d28e80a5c861a9d5f449ea911ab75b4f37ad0d Mon Sep 17 00:00:00 2001 From: Jef Date: Tue, 24 Sep 2024 14:54:57 +0200 Subject: Initial community commit --- .../openmpt-trunk/tracklib/FadeLaws.h | 62 ++++++++++++++++++++++ 1 file changed, 62 insertions(+) create mode 100644 Src/external_dependencies/openmpt-trunk/tracklib/FadeLaws.h (limited to 'Src/external_dependencies/openmpt-trunk/tracklib/FadeLaws.h') diff --git a/Src/external_dependencies/openmpt-trunk/tracklib/FadeLaws.h b/Src/external_dependencies/openmpt-trunk/tracklib/FadeLaws.h new file mode 100644 index 00000000..c4a3c2f2 --- /dev/null +++ b/Src/external_dependencies/openmpt-trunk/tracklib/FadeLaws.h @@ -0,0 +1,62 @@ +/* + * FadeLaws.h + * ---------- + * Purpose: Various fade law implementations for sample and pattern fading / interpolation + * Notes : (currently none) + * Authors: OpenMPT Devs + * The OpenMPT source code is released under the BSD license. Read LICENSE for more details. + */ + +#pragma once + +#include "openmpt/all/BuildSettings.hpp" + +#include "mpt/base/numbers.hpp" +#include + +OPENMPT_NAMESPACE_BEGIN + +namespace Fade +{ + enum Law + { + kLinear, + kPow, + kSqrt, + kLog, + kQuarterSine, + kHalfSine, + }; + + // Maps fade curve position in [0,1] to value in [0,1] + typedef double (*Func) (double pos); + + inline double LinearFunc(double pos) + { return pos; } + inline double PowFunc(double pos) + { return pos * pos; } + inline double SqrtFunc(double pos) + { return std::sqrt(pos); } + inline double LogFunc(double pos) + { return std::log10(1.0 + pos * 99.0) * 0.5; } + inline double QuarterSineFunc(double pos) + { return std::sin((0.5 * mpt::numbers::pi) * pos); } + inline double HalfSineFunc(double pos) + { return (1.0 + std::cos(mpt::numbers::pi + mpt::numbers::pi * pos)) * 0.5; } + + inline Func GetFadeFunc(Law fadeLaw) + { + switch(fadeLaw) + { + default: + case Fade::kLinear: return LinearFunc; + case Fade::kPow: return PowFunc; + case Fade::kSqrt: return SqrtFunc; + case Fade::kLog: return LogFunc; + case Fade::kQuarterSine: return QuarterSineFunc; + case Fade::kHalfSine: return HalfSineFunc; + } + } +} + +OPENMPT_NAMESPACE_END -- cgit