Vi una serie de tutoriales y libros de juegos 2D en los que la posición anterior de un objeto se almacenaba en estado en lugar del vector de velocidad. Luego se calcula la velocidad de cada cuadro como una diferencia entre las posiciones.
¿Cuáles son las ventajas de ese método?
Respuestas:
Sin saber exactamente los tutoriales o libros que has leído, esto es lo que puedo contarte.
Para ser más precisos en términos de definición física: la dirección del vector se calcula como la diferencia entre la posición actual y la última posición. La velocidad del vector es igual a la dividida por el tiempo transcurrido al pasar de una posición a otra. Ver: http://www.physicsclassroom.com/class/1DKin/Lesson-1/Speed-and-Velocity
Sin embargo, cuando se considera que el tiempo transcurrido es el "cuadro 1" genérico, es decir, desde el último cuadro hasta la corriente, entonces la velocidad del vector y la dirección del vector se vuelven iguales. En pseudocódigo:
Entonces, en general, la razón principal para almacenar la posición en el último cuadro y obtener la posición en el cuadro actual es que puede ser la única forma o la forma más barata de conocer la dirección actualizada (y, por lo tanto, la velocidad actualizada), es decir, la dirección del movimiento en el cuadro actual.
Suponga que almacena la dirección (o incluso la velocidad) en un cuadro dado. En el siguiente cuadro, la única forma de saber si la dirección (o incluso la velocidad) ha cambiado es si la calcula de nuevo. La razón es que la dirección anterior o la velocidad anterior no le permiten conocer la dirección actual o la velocidad actual en caso de que el movimiento cambie de un cuadro a otro.
Ahora, teniendo en cuenta los tutoriales que ha mencionado en el comentario a su propia pregunta, se vuelve aún más claro. En uno de los tutoriales, los autores dicen que:
Entonces, como puede ver, el último cuadro de posición de almacenamiento permite, como dije anteriormente, el cálculo actualizado de la velocidad en el cuadro actual cuando el objeto (en el tutorial es una partícula) cambia de posición. Si guardó solo la dirección o la velocidad en el último cuadro, no podría actualizarlo tan fácilmente en caso de que la posición cambiara del cuadro pasado al actual. Por lo tanto, como también se señaló en el otro tutorial al que se vinculó, guardar la posición anterior permite la actualización automática de la velocidad cuando cambian las posiciones.
fuente