C++-难以理解easeInOutSine

C++ - Trouble understanding easeInOutSine

本文关键字:easeInOutSine C++-      更新时间:2023-10-16

我正在努力理解这个宽松公式:

float easeInOutSine(float t, float b, float c, float d)
{
    return -c/2 * (cos(M_PI*t/d) - 1) + b;
};

以下是变量相等的情况:

t: 当前时间b: 起始值c: 价值变动d: 持续时间

我正试图将其应用于精灵转换,并对到底需要传递什么感到困惑。

例如,如果我想以每秒0.25个单位的速度将球从y=0移动到y=10,哪个值是?我真正想要的是另一种解释,解释这些变量相对于我追求的东西意味着什么。

t必须是系统/模拟的时间。每次你叫它,它都会改变。

b应该是起始值0

c应该是10,最终值,

d应该是40000(假设您的时间以毫秒为单位)。这基本上就是持续时间。每四秒你想前进一个单位,总共需要40秒。

你可以用一个示例程序测试/玩它:

float easeInOutSine(float t, float b, float c, float d)
{
    return -c/2 * (cos(M_PI*t/d) - 1) + b;
}
int main() {
    for (unsigned t = 0; t <= 40*1000; t += 1000) {
        cout << "t= " << t << " y=" << easeInOutSine(t, 0, 10, 40000) << std::endl;
    }
}

输出:

t= 0 y=0
t= 1000 y=0.0154133
t= 2000 y=0.0615583
t= 3000 y=0.13815
t= 4000 y=0.244717
t= 5000 y=0.380602
t= 6000 y=0.544967
t= 7000 y=0.736799
t= 8000 y=0.954915
t= 9000 y=1.19797
t= 10000 y=1.46447
t= 11000 y=1.75276
t= 12000 y=2.06107
t= 13000 y=2.38751
t= 14000 y=2.73005
t= 15000 y=3.08658
t= 16000 y=3.45492
t= 17000 y=3.83277
t= 18000 y=4.21783
t= 19000 y=4.6077
t= 20000 y=5
t= 21000 y=5.3923
t= 22000 y=5.78217
t= 23000 y=6.16723
t= 24000 y=6.54508
t= 25000 y=6.91342
t= 26000 y=7.26995
t= 27000 y=7.61249
t= 28000 y=7.93893
t= 29000 y=8.24724
t= 30000 y=8.53553
t= 31000 y=8.80203
t= 32000 y=9.04508
t= 33000 y=9.2632
t= 34000 y=9.45503
t= 35000 y=9.6194
t= 36000 y=9.75528
t= 37000 y=9.86185
t= 38000 y=9.93844
t= 39000 y=9.98459
t= 40000 y=10