GoTo EndRace_PANAM_Def Race_PANAM() { turn1 := new TurnContainer(619, 112+remote_play_offsetY, 630, 95+remote_play_offsetY) turn2 := new TurnContainer(544, 45+remote_play_offsetY, 511, 52+remote_play_offsetY) turn3 := new TurnContainer(492, 84+remote_play_offsetY, 506, 111+remote_play_offsetY) lap_marker := new TurnContainer(560, 112+remote_play_offsetY) ; race_start_delay := 17400 ; this is for PS5. It may vary for PS4. Switch SysCheck { Case 1: race_start_delay := 19200 Case 2: race_start_delay := 18200 Case 3: race_start_delay := 18200 } CheckForOilChange := Mod(30 - A_Index, 30) SetFormat, IntegerFast, d CheckForMaintenance := Mod(180 - A_Index, 180) SetFormat, IntegerFast, d if (__enableMaintenance_mod__ != 0){ ToolTipper("Oil: " CheckForOilChange " race(s) remaining`nEngine: " CheckForMaintenance " race(s) remaining", 250, 45) } t_ExpectedRaceTime := 195000 t_RaceStartTime := A_TickCount t_RaceFinishTime := t_RaceStartTime + t_ExpectedRaceTime ;ToolTipper("t_ExpectedRaceTime = " t_ExpectedRaceTime "`nt_RaceStartTime = " t_RaceStartTime "`nt_RaceFinishTime = " t_RaceFinishTime) race_complete := false ; Press X to start the race ;Tooltip Press_X() ; Hold Acceleration and manage turning Nitrous_On() Accel_On(100) ;SetTimer, CheckTyresOverheating, 1000 ; Retry race if time is taking more than 5.5 mins ; (assume something went wrong with race) SetTimer, RetryRace, 330000 Sleep (race_start_delay) controller.Axes.LX.SetState(62) /* before turn 1, to avoid queue of cars */ loop { ;ToolTip, Racing, 100, 100, Screen break_point := false c1 := BitGrab(pix1x, pix1y+remote_play_offsetY, box_size) for i, c in c1 { d1 := Distance(c, color_check1) ToolTipper( d1 " " pix1y+remote_play_offsetY " " pix1x " " c) if (d1 < tolerance ){ break_point := true break } } if (break_point) break controller.Dpad.SetState("Right") Sleep, 50 controller.Dpad.SetState("None") Sleep, 100 } ToolTipper("Race End") gosub, PauseLoop Sleep, 500 return } Race_PANAM_Complete() { race_complete := true return } EndRace_PANAM_Def: