add preset and round selection to highscore

This commit is contained in:
interfisch 2025-01-01 22:26:49 +01:00
parent 0b63997ce4
commit 4b8a17ff44
2 changed files with 23 additions and 11 deletions

View file

@ -86,7 +86,7 @@ func _ready() -> void:
print("i_position="+str(i_position)+" carpos is ="+str(newcarinstance.getPosition())+" instancepos="+str(newcarinstance.position)+" colori="+str(player.colori)+" color="+str(player.color)) print("i_position="+str(i_position)+" carpos is ="+str(newcarinstance.getPosition())+" instancepos="+str(newcarinstance.position)+" colori="+str(player.colori)+" color="+str(player.color))
i+=1 i+=1
print("mapname="+str(Gamestate.getSelectedMapName()+"_"+str(Gamestate.getRounds())))
func custom_array_sort_rank(a, b): func custom_array_sort_rank(a, b):
@ -245,7 +245,7 @@ func finishGame():
if Gamestate.getPlayers().size()==1: #was played in singleplayer if Gamestate.getPlayers().size()==1: #was played in singleplayer
var timediff=HighscoreHandler.updateHighscore(Gamestate.getSelectedMapName()+"_"+str(Gamestate.getRounds()),getfinalTimeByPlayer(Gamestate.getPlayers()[0])) var timediff=HighscoreHandler.updateHighscore(Gamestate.getSelectedMapName(),"normal",str(Gamestate.getRounds()),getfinalTimeByPlayer(Gamestate.getPlayers()[0]))
print("Timediff="+str(timediff)) print("Timediff="+str(timediff))
timediff=round(timediff*1000)/1000 timediff=round(timediff*1000)/1000
highscore_label.visible=true highscore_label.visible=true

View file

@ -4,25 +4,37 @@ const HIGHSCORE_FILE_PATH = "highscores.json"
func updateHighscore(mapname:String,rounds:int,preset:int,time:float): func updateHighscore(mapname:String,preset:String,rounds:String,time:float):
var highscores=loadHighscoreDict() var highscores=loadHighscoreDict()
if highscores.has(mapname): var lasthighscore=loadHighscore(mapname,preset,rounds)
var lasthighscore=loadHighscore(mapname) if lasthighscore !=null:
if time<lasthighscore: #better time if time<lasthighscore: #better time
highscores[mapname].append({"created":Time.get_unix_time_from_system(),"time":time}) highscores[mapname][preset][rounds].append({"created":Time.get_unix_time_from_system(),"time":time})
storeHighscoreDict(highscores) storeHighscoreDict(highscores)
return time-lasthighscore return time-lasthighscore
else: #first entry else: #first entry for this map and config
highscores[mapname]=[{"created":Time.get_unix_time_from_system(),"time":time}] print("first entry for this config")
if !highscores.has(mapname):
print("mapname not known")
highscores[mapname]={}
if !highscores[mapname].has(preset):
print("preset not known")
highscores[mapname][preset]={}
if !highscores[mapname][preset].has(rounds):
print("rounds not known")
highscores[mapname][preset][rounds]=[{"created":Time.get_unix_time_from_system(),"time":time}]
storeHighscoreDict(highscores) storeHighscoreDict(highscores)
return 0 return 0
func loadHighscore(mapname:String): func loadHighscore(mapname:String,preset:String,rounds:String):
var highscores=loadHighscoreDict() var highscores=loadHighscoreDict()
if highscores.has(mapname): if highscores.has(mapname):
if highscores[mapname].size()>0: if highscores[mapname].has(preset):
return highscores[mapname][highscores[mapname].size()-1]["time"] #return last entry if highscores[mapname][preset].has(rounds):
if highscores[mapname][preset][rounds].size()>0:
return highscores[mapname][preset][rounds][highscores[mapname].size()-1]["time"] #return last entry
else: else:
return null return null