Mercurial > public > geoquiz
comparison GeoQuiz/Logic/CityGameClass.swift @ 10:a793f33f05fb
refactor code and fix layout
author | Dennis C. M. <dennis@denniscm.com> |
---|---|
date | Sat, 08 Oct 2022 21:36:40 +0200 |
parents | GeoQuiz/Logic/CityGame.swift@3540c7efc216 |
children | 136928bae534 |
comparison
equal
deleted
inserted
replaced
9:3540c7efc216 | 10:a793f33f05fb |
---|---|
1 // | |
2 // CityGameClass.swift | |
3 // GeoQuiz | |
4 // | |
5 // Created by Dennis Concepción Martín on 29/9/22. | |
6 // | |
7 | |
8 import Foundation | |
9 import AVFAudio | |
10 | |
11 class CityGame: Game, ObservableObject { | |
12 | |
13 // Define type of generics | |
14 typealias T = CityData.City | |
15 | |
16 var data: [String: T] | |
17 var dataAsked = [String: T]() | |
18 | |
19 // Data | |
20 @Published var correctAnswer = ( | |
21 key: String(), | |
22 value: T(country: String(), lat: Double(), lon: Double()) | |
23 ) | |
24 | |
25 // User | |
26 @Published var userChoices = [String: T]() | |
27 @Published var userScore = 0 | |
28 @Published var userLives = 3 | |
29 @Published var correctAnswers = [String: T]() | |
30 @Published var wrongAnswers = [String: T]() | |
31 | |
32 // Alerts | |
33 @Published var alertTitle = String() | |
34 @Published var alertMessage = String() | |
35 @Published var showingGameOverAlert = false | |
36 @Published var showingEndGameAlert = false | |
37 @Published var showingWrongAnswerAlert = false | |
38 @Published var showingExitGameAlert = false | |
39 | |
40 // Animations | |
41 @Published var scoreScaleAmount = 1.0 | |
42 @Published var livesScaleAmount = 1.0 | |
43 | |
44 // Sound effects | |
45 @Published var player: AVAudioPlayer? | |
46 | |
47 init() { | |
48 let data: CityData = load("cities.json") | |
49 self.data = data.cities | |
50 | |
51 let user = User() | |
52 userLives = user.settings.numberOfLives | |
53 | |
54 if let userSettings = UserDefaults.standard.data(forKey: "UserSettings") { | |
55 if let decodedUserSettings = try? JSONDecoder().decode(UserSettings.self, from: userSettings) { | |
56 userLives = decodedUserSettings.numberOfLives | |
57 } | |
58 } | |
59 | |
60 askQuestion { | |
61 selector() | |
62 } | |
63 } | |
64 } | |
65 | |
66 extension CityGame { | |
67 func selector() { | |
68 | |
69 // Get random choices | |
70 var userChoices = [String: T]() | |
71 | |
72 while userChoices.count < 2 { | |
73 if let choice = data.randomElement() { | |
74 let userChoicesCountry = userChoices.map { $0.value.country } | |
75 | |
76 if !userChoicesCountry.contains(choice.value.country) { | |
77 userChoices[choice.key] = choice.value | |
78 } | |
79 } else { | |
80 fatalError("Couldn't get a random value from data") | |
81 } | |
82 } | |
83 | |
84 // Get question asked (correct answer) | |
85 let userChoicesCountry = userChoices.map { $0.value.country } | |
86 let correctAnswer = data.first(where: { | |
87 !userChoices.keys.contains($0.key) && // Avoid duplicated cities | |
88 !dataAsked.keys.contains($0.key) && // Avoid cities already asked | |
89 !userChoicesCountry.contains($0.value.country) // Avoid duplicated country names in userChoices | |
90 }) | |
91 | |
92 // Unwrap optional | |
93 if let correctAnswer = correctAnswer { | |
94 userChoices[correctAnswer.key] = correctAnswer.value | |
95 dataAsked[correctAnswer.key] = correctAnswer.value | |
96 self.correctAnswer = correctAnswer | |
97 } else { | |
98 fatalError("Couldn't unwrap optional value") | |
99 } | |
100 | |
101 self.userChoices = userChoices | |
102 } | |
103 } | |
104 |