forked from eden-emu/eden
		
	core: Hacky TAS syncing & load pausing
To keep the TAS inputs synced to the game speed even through lag spikes and loading zones, deeper access is required. First, the `TAS::UpdateThread` has to be executed exactly once per frame. This is done by connecting it to the service method the game calls to pass parameters to the GPU: `Service::VI::QueueBuffer`. Second, the loading time of new subareas and/or kingdoms (SMO) can vary. To counteract that, the `CPU_BOOST_MODE` can be detected: In the `APM`-interface, the call to enabling/disabling the boost mode can be caught and forwarded to the TASing system, which can pause the script execution if neccessary and enabled in the settings.
This commit is contained in:
		
							parent
							
								
									518852f505
								
							
						
					
					
						commit
						cce0d58312
					
				
					 9 changed files with 140 additions and 107 deletions
				
			
		|  | @ -500,7 +500,6 @@ struct Values { | |||
| 
 | ||||
|     // Controls
 | ||||
|     InputSetting<std::array<PlayerInput, 10>> players; | ||||
|     std::shared_ptr<InputCommon::InputSubsystem> inputSubsystem = NULL; | ||||
| 
 | ||||
|     Setting<bool> use_docked_mode{true, "use_docked_mode"}; | ||||
| 
 | ||||
|  | @ -514,9 +513,12 @@ struct Values { | |||
|                                             "motion_device"}; | ||||
|     BasicSetting<std::string> udp_input_servers{"127.0.0.1:26760", "udp_input_servers"}; | ||||
| 
 | ||||
|     BasicSetting<bool> tas_enable{false, "tas_enable"}; | ||||
|     BasicSetting<bool> pause_tas_on_load { false, "pause_tas_on_load" }; | ||||
|     BasicSetting<bool> tas_enable{ false, "tas_enable" }; | ||||
|     BasicSetting<bool> tas_reset{ false, "tas_reset" }; | ||||
|     BasicSetting<bool> tas_record{ false, "tas_record" }; | ||||
|     BasicSetting<bool> is_cpu_boxted{ false, "    BasicSetting<bool> is_cpu_boxted{ false, "cpuBoosted" }; | ||||
| " }; | ||||
| 
 | ||||
|     BasicSetting<bool> mouse_panning{false, "mouse_panning"}; | ||||
|     BasicRangedSetting<u8> mouse_panning_sensitivity{10, 1, 100, "mouse_panning_sensitivity"}; | ||||
|  | @ -550,9 +552,6 @@ struct Values { | |||
|     BasicSetting<bool> gamecard_current_game{false, "gamecard_current_game"}; | ||||
|     BasicSetting<std::string> gamecard_path{std::string(), "gamecard_path"}; | ||||
| 
 | ||||
|     // TAS
 | ||||
|     bool pauseTasOnLoad; | ||||
| 
 | ||||
|     // Debugging
 | ||||
|     bool record_frame_times; | ||||
|     BasicSetting<bool> use_gdbstub{false, "use_gdbstub"}; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 MonsterDruide1
						MonsterDruide1