mirror of
https://github.com/a-b-street/abstreet.git
synced 2025-01-04 04:23:25 +03:00
1.4 KiB
1.4 KiB
Time travel
aka reversible simulation. There are two ways to think about implementing this:
- the full thing -- make the entire Sim rewind
- just a UI trick
- conceptually, be able to reproduce the Draw{Car,Ped}Inputs parametrically
- baseline: literally record those inputs every tick and just lookup. huge memory hog.
- the cooler thing: record timelines of agents as the real sim plays and interpolate.
Going to just focus on the UI trick approach for now. To be useful, what things in the UI need to work?
- rendering of course -- show things where they were
- warping to an agent? easy
- showing route of an agent? hard
So we need to disable some plugins while we're in this special mode. I wonder if each plugin should sort of declare a dependency on a live sim or if at a higher level, the list of plugins should change?
Some initial steps: = make a plugin that asks for all Draw stuff every tick and just saves it = activate the time travel plugin and have keys to go back/forward = supply the Draw{Car,Ped} stuff from the time travel plugin, not the sim - objects_onscreen is the main place! - need to get draw car/ped on lane/turn, so index them that way, maybe implement a trait?
- deactivate lots of other plugins while in this mode
= make sim ctrl a proper plugin
- anything that accesses sim and looks up agents becomes weird!
- interpolate instead of storing everything