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