Resolve WES-97 "Integrate signpredictor in spellingbee"
This commit is contained in:
committed by
Lukas Van Rossem
parent
f827c29d3a
commit
3abc24a39c
@@ -44,57 +44,6 @@ public partial class GameController : MonoBehaviour
|
||||
/// </summary>
|
||||
private float timerValue;
|
||||
|
||||
/// <summary>
|
||||
/// "Game over" or "You win!"
|
||||
/// </summary>
|
||||
public TMP_Text endText;
|
||||
|
||||
/// <summary>
|
||||
/// LPM
|
||||
/// </summary>
|
||||
public TMP_Text lpmText;
|
||||
|
||||
/// <summary>
|
||||
/// Letters ( right | wrong )
|
||||
/// </summary>
|
||||
public TMP_Text lettersRightText;
|
||||
public TMP_Text lettersWrongText;
|
||||
|
||||
/// <summary>
|
||||
/// Letters
|
||||
/// </summary>
|
||||
public TMP_Text lettersText;
|
||||
|
||||
/// <summary>
|
||||
/// Accuracy
|
||||
/// </summary>
|
||||
public TMP_Text accuracyText;
|
||||
|
||||
/// <summary>
|
||||
/// Words
|
||||
/// </summary>
|
||||
public TMP_Text wordsText;
|
||||
|
||||
/// <summary>
|
||||
/// Time
|
||||
/// </summary>
|
||||
public TMP_Text timeText;
|
||||
|
||||
/// <summary>
|
||||
/// Score
|
||||
/// </summary>
|
||||
public TMP_Text scoreText;
|
||||
|
||||
/// <summary>
|
||||
/// The game over panel
|
||||
/// </summary>
|
||||
public GameObject gameEndedPanel;
|
||||
|
||||
/// <summary>
|
||||
/// Button for restarting the game
|
||||
/// </summary>
|
||||
public Button replayButton;
|
||||
|
||||
/// <summary>
|
||||
/// Indicates if the game is still going
|
||||
/// </summary>
|
||||
@@ -104,7 +53,7 @@ public partial class GameController : MonoBehaviour
|
||||
/// Amount of seconds user gets per letter of the current word
|
||||
/// Set to 1 for testing; should be increased later
|
||||
/// </summary>
|
||||
private int secondsPerLetter = 1;
|
||||
private const int secondsPerLetter = 5;
|
||||
|
||||
/// <summary>
|
||||
/// Counter that keeps track of how many letters have been spelled correctly
|
||||
@@ -136,24 +85,18 @@ public partial class GameController : MonoBehaviour
|
||||
/// </summary>
|
||||
private User user;
|
||||
|
||||
/// <summary>
|
||||
/// Reference to the minigame progress of the current user
|
||||
/// </summary>
|
||||
private Progress progress = null;
|
||||
|
||||
/// <summary>
|
||||
/// Reference to the minigame ScriptableObject
|
||||
/// </summary>
|
||||
public Minigame minigame;
|
||||
|
||||
|
||||
/// <summary>
|
||||
/// Letter prefab
|
||||
/// </summary>
|
||||
public GameObject letterPrefab;
|
||||
|
||||
/// <summary>
|
||||
/// Reference to letter prefab
|
||||
/// Reference to letter container
|
||||
/// </summary>
|
||||
public Transform letterContainer;
|
||||
|
||||
@@ -167,6 +110,16 @@ public partial class GameController : MonoBehaviour
|
||||
/// </summary>
|
||||
public TMP_Text timerText;
|
||||
|
||||
/// <summary>
|
||||
/// Bonus time display
|
||||
/// </summary>
|
||||
public GameObject bonusTimeText;
|
||||
|
||||
/// <summary>
|
||||
/// Timer to display the bonus time
|
||||
/// </summary>
|
||||
private float bonusActiveRemaining = 0.0f;
|
||||
|
||||
/// <summary>
|
||||
/// The GameObjects representing the letters
|
||||
/// </summary>
|
||||
@@ -178,41 +131,39 @@ public partial class GameController : MonoBehaviour
|
||||
public Transform Scoreboard;
|
||||
|
||||
/// <summary>
|
||||
/// Reference to the entries grid
|
||||
/// Accuracy feeback object
|
||||
/// </summary>
|
||||
public Transform EntriesGrid;
|
||||
public Feedback feedback;
|
||||
|
||||
/// <summary>
|
||||
/// The GameObjects representing the letters
|
||||
/// Reference to the gameEnded panel, so we can update its display
|
||||
/// </summary>
|
||||
private List<GameObject> entries = new List<GameObject>();
|
||||
|
||||
/// <summary>
|
||||
/// Reference to the ScoreboardEntry prefab
|
||||
/// </summary>
|
||||
public GameObject scoreboardEntry;
|
||||
|
||||
public GameObject gameEndedPanel;
|
||||
|
||||
/// <summary>
|
||||
/// Start is called before the first frame update
|
||||
/// </summary>
|
||||
public void Start()
|
||||
{
|
||||
words.Clear();
|
||||
correctLetters = 0;
|
||||
incorrectLetters = 0;
|
||||
|
||||
words.Clear();
|
||||
// We use -1 instead of 0 so SetNextWord can simply increment it each time
|
||||
spelledWords = -1;
|
||||
gameEnded = false;
|
||||
wordIndex = 0;
|
||||
timerValue = 0.0f;
|
||||
|
||||
gameEnded = false;
|
||||
timerValue = 30.0f;
|
||||
bonusActiveRemaining = 0.0f;
|
||||
startTime = DateTime.Now;
|
||||
|
||||
gameEndedPanel.SetActive(false);
|
||||
replayButton.onClick.AddListener(Start);
|
||||
bonusTimeText.SetActive(false);
|
||||
|
||||
// Create entry in current user for keeping track of progress
|
||||
user = userList.GetCurrentUser();
|
||||
progress = user.GetMinigameProgress(minigame.index);
|
||||
Progress progress = user.GetMinigameProgress(minigame.index);
|
||||
if (progress == null)
|
||||
{
|
||||
progress = new Progress();
|
||||
@@ -223,12 +174,30 @@ public partial class GameController : MonoBehaviour
|
||||
}
|
||||
userList.Save();
|
||||
|
||||
DeleteWord();
|
||||
|
||||
currentTheme = minigame.themeList.themes[minigame.themeList.currentThemeIndex];
|
||||
feedback.signPredictor.model = currentTheme.model;
|
||||
words.AddRange(currentTheme.learnables);
|
||||
ShuffleWords();
|
||||
SetNextWord();
|
||||
NextWord();
|
||||
|
||||
// Set calllbacks
|
||||
feedback.getSignCallback = () =>
|
||||
{
|
||||
if (letterIndex < currentWord.Length)
|
||||
{
|
||||
return currentWord[letterIndex].ToString().ToUpper();
|
||||
}
|
||||
return null;
|
||||
};
|
||||
feedback.predictSignCallback = (sign) =>
|
||||
{
|
||||
bool successful = sign.ToUpper() == currentWord[letterIndex].ToString().ToUpper();
|
||||
if (successful)
|
||||
{
|
||||
AddSeconds(secondsPerLetter);
|
||||
}
|
||||
NextLetter(successful);
|
||||
};
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
@@ -238,32 +207,15 @@ public partial class GameController : MonoBehaviour
|
||||
{
|
||||
if (!gameEnded)
|
||||
{
|
||||
// Get keyboard input
|
||||
// Check if the correct char has been given as input
|
||||
foreach (char c in Input.inputString)
|
||||
{
|
||||
if (Char.ToUpper(c) == Char.ToUpper(currentWord[letterIndex]))
|
||||
{
|
||||
// correct letter
|
||||
letters[letterIndex].GetComponent<Image>().color = Color.green;
|
||||
correctLetters++;
|
||||
letterIndex++;
|
||||
|
||||
if (letterIndex >= currentWord.Length)
|
||||
{
|
||||
DeleteWord();
|
||||
StartCoroutine(Wait());
|
||||
SetNextWord();
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
// incorrect letter
|
||||
incorrectLetters++;
|
||||
}
|
||||
}
|
||||
|
||||
timerValue -= Time.deltaTime;
|
||||
if (bonusActiveRemaining <= 0.0 && bonusTimeText.activeSelf)
|
||||
{
|
||||
bonusTimeText.SetActive(false);
|
||||
}
|
||||
else
|
||||
{
|
||||
bonusActiveRemaining -= Time.deltaTime;
|
||||
}
|
||||
|
||||
if (timerValue <= 0.0f)
|
||||
{
|
||||
@@ -302,59 +254,26 @@ public partial class GameController : MonoBehaviour
|
||||
return spelledWords * 5 + correctLetters;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Set score metrics
|
||||
/// </summary>
|
||||
private void SetScoreMetrics()
|
||||
{
|
||||
// LPM
|
||||
TimeSpan duration = DateTime.Now.Subtract(startTime);
|
||||
lpmText.text = (60f * correctLetters / duration.TotalSeconds).ToString("#") + " LPM";
|
||||
|
||||
// Letters ( right | wrong ) total
|
||||
lettersRightText.text = correctLetters.ToString();
|
||||
lettersWrongText.text = incorrectLetters.ToString();
|
||||
lettersText.text = (correctLetters + incorrectLetters).ToString();
|
||||
|
||||
// Accuracy
|
||||
if (correctLetters + incorrectLetters > 0)
|
||||
{
|
||||
accuracyText.text = ((correctLetters) * 100f / (correctLetters + incorrectLetters)).ToString("#.##") + "%";
|
||||
}
|
||||
else
|
||||
{
|
||||
accuracyText.text = "-";
|
||||
}
|
||||
|
||||
|
||||
// Words
|
||||
wordsText.text = spelledWords.ToString();
|
||||
|
||||
// Time
|
||||
timeText.text = duration.ToString(@"mm\:ss");
|
||||
|
||||
// Score
|
||||
scoreText.text = "Score: " + CalculateScore().ToString();
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Displays the game over panel and score values
|
||||
/// </summary>
|
||||
private void ActivateGameOver()
|
||||
{
|
||||
DeleteWord();
|
||||
endText.text = "GAME OVER";
|
||||
|
||||
SetScoreMetrics();
|
||||
|
||||
gameEndedPanel.SetActive(true);
|
||||
gameEndedPanel.transform.SetAsLastSibling();
|
||||
|
||||
gameEnded = true;
|
||||
DeleteWord();
|
||||
|
||||
// Save the scores and show the scoreboard
|
||||
SaveScores();
|
||||
SetScoreBoard();
|
||||
gameEndedPanel.GetComponent<GameEndedPanel>().GenerateContent(
|
||||
startTime: startTime,
|
||||
totalWords: spelledWords,
|
||||
correctLetters: correctLetters,
|
||||
incorrectLetters: incorrectLetters,
|
||||
result: "VERLOREN",
|
||||
score: CalculateScore()
|
||||
);
|
||||
|
||||
gameEndedPanel.SetActive(true);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
@@ -362,20 +281,21 @@ public partial class GameController : MonoBehaviour
|
||||
/// </summary>
|
||||
private void ActivateWin()
|
||||
{
|
||||
// @lukas stuff
|
||||
DeleteWord();
|
||||
endText.text = "YOU WIN!";
|
||||
|
||||
SetScoreMetrics();
|
||||
|
||||
gameEndedPanel.SetActive(true);
|
||||
gameEndedPanel.transform.SetAsLastSibling();
|
||||
|
||||
gameEnded = true;
|
||||
DeleteWord();
|
||||
|
||||
// Save the scores and show the scoreboard
|
||||
SaveScores();
|
||||
SetScoreBoard();
|
||||
gameEndedPanel.GetComponent<GameEndedPanel>().GenerateContent(
|
||||
startTime: startTime,
|
||||
totalWords: spelledWords,
|
||||
correctLetters: correctLetters,
|
||||
incorrectLetters: incorrectLetters,
|
||||
result: "GEWONNEN",
|
||||
score: CalculateScore()
|
||||
);
|
||||
|
||||
gameEndedPanel.SetActive(true);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
@@ -384,7 +304,8 @@ public partial class GameController : MonoBehaviour
|
||||
private void SaveScores()
|
||||
{
|
||||
// Calculate new score
|
||||
int newScore = spelledWords * 5 + correctLetters;
|
||||
int newScore = CalculateScore();
|
||||
|
||||
// Save the score as a tuple: < int score, string time ago>
|
||||
Score score = new Score();
|
||||
score.scoreValue = newScore;
|
||||
@@ -392,7 +313,7 @@ public partial class GameController : MonoBehaviour
|
||||
|
||||
// Save the new score
|
||||
user = userList.GetCurrentUser();
|
||||
progress = user.GetMinigameProgress(minigame.index);
|
||||
Progress progress = user.GetMinigameProgress(minigame.index);
|
||||
|
||||
// Get the current list of scores
|
||||
List<Score> latestScores = progress.Get<List<Score>>("latestScores");
|
||||
@@ -409,110 +330,9 @@ public partial class GameController : MonoBehaviour
|
||||
progress.AddOrUpdate<List<Score>>("latestScores", latestScores.Take(10).ToList());
|
||||
progress.AddOrUpdate<List<Score>>("highestScores", highestScores.Take(10).ToList());
|
||||
|
||||
Debug.Log(progress.Get<List<Score>>("highestScores"));
|
||||
|
||||
userList.Save();
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Sets the scoreboard
|
||||
/// </summary>
|
||||
private void SetScoreBoard()
|
||||
{
|
||||
// Clean the previous scoreboard entries
|
||||
for (int i = 0; i < entries.Count; i++)
|
||||
{
|
||||
Destroy(entries[i]);
|
||||
}
|
||||
entries.Clear();
|
||||
|
||||
// Instantiate new entries
|
||||
// Get all scores from all users
|
||||
List<Tuple<string, Score>> allScores = new List<Tuple<string, Score>>();
|
||||
foreach (User user in userList.GetUsers())
|
||||
{
|
||||
// Get user's progress for this minigame
|
||||
progress = user.GetMinigameProgress(minigame.index);
|
||||
if (progress != null)
|
||||
{
|
||||
// Add scores to dictionary
|
||||
List<Score> scores = progress.Get<List<Score>>("highestScores");
|
||||
foreach (Score score in scores)
|
||||
{
|
||||
allScores.Add(new Tuple<string, Score>(user.username, score));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Sort allScores based on Score.scoreValue
|
||||
allScores.Sort((a, b) => b.Item2.scoreValue.CompareTo(a.Item2.scoreValue));
|
||||
|
||||
// Instantiate scoreboard entries
|
||||
int rank = 1;
|
||||
foreach (Tuple<string, Score> tup in allScores.Take(10))
|
||||
{
|
||||
string username = tup.Item1;
|
||||
Score score = tup.Item2;
|
||||
|
||||
GameObject entry = Instantiate(scoreboardEntry, EntriesGrid);
|
||||
entries.Add(entry);
|
||||
// Set the player icon
|
||||
entry.transform.Find("Image").GetComponent<Image>().sprite = userList.GetUserByUsername(username).avatar;
|
||||
|
||||
// Set the player name
|
||||
entry.transform.Find("PlayerName").GetComponent<TMP_Text>().text = username;
|
||||
|
||||
// Set the score
|
||||
entry.transform.Find("Score").GetComponent<TMP_Text>().text = score.scoreValue.ToString();
|
||||
|
||||
// Set the rank
|
||||
entry.transform.Find("Rank").GetComponent<TMP_Text>().text = rank.ToString();
|
||||
|
||||
// Set the ago
|
||||
// Convert the score.time to Datetime
|
||||
DateTime time = DateTime.Parse(score.time);
|
||||
DateTime currentTime = DateTime.Now;
|
||||
TimeSpan diff = currentTime.Subtract(time);
|
||||
|
||||
string formatted;
|
||||
if (diff.Days > 0)
|
||||
{
|
||||
formatted = $"{diff.Days}d ";
|
||||
}
|
||||
else if (diff.Hours > 0)
|
||||
{
|
||||
formatted = $"{diff.Hours}h ";
|
||||
}
|
||||
else if (diff.Minutes > 0)
|
||||
{
|
||||
formatted = $"{diff.Minutes}m ";
|
||||
}
|
||||
else
|
||||
{
|
||||
formatted = "now";
|
||||
}
|
||||
|
||||
entry.transform.Find("Ago").GetComponent<TMP_Text>().text = formatted;
|
||||
|
||||
|
||||
// Alternating colors looks nice
|
||||
if (rank % 2 == 0)
|
||||
{
|
||||
Image image = entry.transform.GetComponent<Image>();
|
||||
image.color = new Color(image.color.r, image.color.g, image.color.b, 0f);
|
||||
}
|
||||
|
||||
// Make new score stand out
|
||||
if (diff.TotalSeconds < 1)
|
||||
{
|
||||
Image image = entry.transform.GetComponent<Image>();
|
||||
image.color = new Color(0, 229, 255, 233);
|
||||
}
|
||||
|
||||
rank++;
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Delete all letter objects
|
||||
/// </summary>
|
||||
@@ -532,23 +352,57 @@ public partial class GameController : MonoBehaviour
|
||||
private void AddSeconds(int seconds)
|
||||
{
|
||||
timerValue += (float)seconds;
|
||||
bonusTimeText.SetActive(true);
|
||||
bonusActiveRemaining = 2.0f;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Display the next letter
|
||||
/// </summary>
|
||||
/// <param name="successful">true if the letter was correctly signed, false otherwise</param>
|
||||
private void NextLetter(bool successful)
|
||||
{
|
||||
// Change color of current letter (skip spaces)
|
||||
if (successful)
|
||||
{
|
||||
correctLetters++;
|
||||
letters[letterIndex].GetComponent<Image>().color = Color.green;
|
||||
}
|
||||
else
|
||||
{
|
||||
incorrectLetters++;
|
||||
letters[letterIndex].GetComponent<Image>().color = new Color(0.5f, 0.0f, 0.0f);
|
||||
}
|
||||
|
||||
do
|
||||
{
|
||||
letterIndex++;
|
||||
} while (letterIndex < currentWord.Length && currentWord[letterIndex] == ' ');
|
||||
|
||||
// Change the color of the next letter or change to new word
|
||||
if (letterIndex < currentWord.Length)
|
||||
{
|
||||
letters[letterIndex].GetComponent<Image>().color = Color.yellow;
|
||||
}
|
||||
else
|
||||
{
|
||||
StartCoroutine(Wait());
|
||||
NextWord();
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Display next word in the series
|
||||
/// </summary>
|
||||
private void SetNextWord()
|
||||
private void NextWord()
|
||||
{
|
||||
DeleteWord();
|
||||
spelledWords++;
|
||||
|
||||
if (wordIndex < words.Count)
|
||||
{
|
||||
currentWord = words[wordIndex].name;
|
||||
|
||||
//ChangeSprite(currentWord);
|
||||
|
||||
DisplayWord(currentWord);
|
||||
AddSeconds(currentWord.Length * secondsPerLetter + 1);
|
||||
|
||||
letterIndex = 0;
|
||||
wordIndex++;
|
||||
@@ -572,10 +426,11 @@ public partial class GameController : MonoBehaviour
|
||||
letters.Add(instance);
|
||||
|
||||
// Dynamically load appearance
|
||||
char c = Char.ToUpper(word[i]);
|
||||
Image background = instance.GetComponent<Image>();
|
||||
background.color = Color.red;
|
||||
background.color = i == 0 ? Color.yellow : c != ' ' ? Color.red : Color.clear;
|
||||
TMP_Text txt = instance.GetComponentInChildren<TMP_Text>();
|
||||
txt.text = Char.ToString(Char.ToUpper(word[i]));
|
||||
txt.text = Char.ToString(c);
|
||||
}
|
||||
wordImage.sprite = words[wordIndex].image;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user