Помогите формулировать кубическое уравнение смягчения
-
27-10-2019 - |
Вопрос
У меня есть следующий кусок кода
int steps = 10;
for (int i = 0; i <= steps; i++) {
float t = i / float(steps);
console.log( "t " + t );
}
Это выкладывает числа линейным образом, подобным этому {0, 0,1, 0,2, ..., 0,9, 1,0} Я хотел бы применить кубическое (в или вне) уравнение облегчения, чтобы выходные числа увеличились или уменьшались постепенно
ОБНОВИТЬ
Не уверен, что моя реализация, если правильная, но я получаю кривую, как и ожидалось
float b = 0;
float c = 1;
float d = 1;
for (int i = 0; i <= steps; i++) {
float t = i / float(steps);
t /= d;
float e = c * t * t * t + b;
console.log( "e " + e );
//console.log( "t " + t );
}
Решение
EASIN Кубическая функция
/**
* @param {Number} t The current time
* @param {Number} b The start value
* @param {Number} c The change in value
* @param {Number} d The duration time
*/
function easeInCubic(t, b, c, d) {
t /= d;
return c*t*t*t + b;
}
Удобная кубическая функция
/**
* @see {easeInCubic}
*/
function easeOutCubic(t, b, c, d) {
t /= d;
t--;
return c*(t*t*t + 1) + b;
}
Здесь вы можете найти разные полезные уравнения: http://www.gizma.com/easing/#cub1
Поместите этот код через некоторое время, как вы не надеваете, и у вас будет выходы кубических уменьшающихся чисел.
Другие советы
Вы можете использовать код из плагина jQuery Ealeing: http://gsgd.co.uk/sandbox/jquery/easing/
/*
* t: current time
* b: begInnIng value
* c: change In value
* d: duration
*/
easeInCubic: function (x, t, b, c, d) {
return c*(t/=d)*t*t + b;
},
easeOutCubic: function (x, t, b, c, d) {
return c*((t=t/d-1)*t*t + 1) + b;
},
easeInOutCubic: function (x, t, b, c, d) {
if ((t/=d/2) < 1) return c/2*t*t*t + b;
return c/2*((t-=2)*t*t + 2) + b;
}
Не связан с StackOverflow