From 5c6ee9fd7e44bf60c87992b9d9871905cf3ac245 Mon Sep 17 00:00:00 2001 From: Jakob Haag Date: Thu, 28 May 2020 18:21:09 +0200 Subject: [PATCH] Add RoundTimer and adjust TimerComponent --- GoldWars/GoldWars.xcodeproj/project.pbxproj | 5 ++ .../GoldWars/Components/TimerComponent.swift | 37 ++++---------- GoldWars/GoldWars/Entities/HUD.swift | 2 +- GoldWars/GoldWars/GameCenterManager.swift | 2 +- GoldWars/GoldWars/MultiplayerNetwork.swift | 1 + .../GoldWars/RoundCalculatorService.swift | 2 +- GoldWars/GoldWars/RoundTimer.swift | 51 +++++++++++++++++++ 7 files changed, 69 insertions(+), 31 deletions(-) create mode 100644 GoldWars/GoldWars/RoundTimer.swift diff --git a/GoldWars/GoldWars.xcodeproj/project.pbxproj b/GoldWars/GoldWars.xcodeproj/project.pbxproj index daf1999..4123594 100644 --- a/GoldWars/GoldWars.xcodeproj/project.pbxproj +++ b/GoldWars/GoldWars.xcodeproj/project.pbxproj @@ -20,6 +20,7 @@ 3E67854024728368007B9DE4 /* CElements.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3E67853F24728368007B9DE4 /* CElements.swift */; }; 3E6785422472CBEC007B9DE4 /* Way.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3E6785412472CBEC007B9DE4 /* Way.swift */; }; 3E6785442472CC27007B9DE4 /* DefaultWayComponent.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3E6785432472CC27007B9DE4 /* DefaultWayComponent.swift */; }; + 3EAD889524801B6A0048A10A /* RoundTimer.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3EAD889424801B6A0048A10A /* RoundTimer.swift */; }; 3EBD242E245D9332003CECE7 /* Team.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3EBD242D245D9332003CECE7 /* Team.swift */; }; 3F745DF0246F48FC00CE7375 /* PlayerMoveType.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3F745DEF246F48FC00CE7375 /* PlayerMoveType.swift */; }; 3FE19DB5246C7A22004827AB /* RoundCalculatorService.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3FE19DB4246C7A22004827AB /* RoundCalculatorService.swift */; }; @@ -83,6 +84,7 @@ 3E67853F24728368007B9DE4 /* CElements.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CElements.swift; sourceTree = ""; }; 3E6785412472CBEC007B9DE4 /* Way.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Way.swift; sourceTree = ""; }; 3E6785432472CC27007B9DE4 /* DefaultWayComponent.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = DefaultWayComponent.swift; sourceTree = ""; }; + 3EAD889424801B6A0048A10A /* RoundTimer.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RoundTimer.swift; sourceTree = ""; }; 3EBD242D245D9332003CECE7 /* Team.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Team.swift; sourceTree = ""; }; 3F745DEF246F48FC00CE7375 /* PlayerMoveType.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = PlayerMoveType.swift; sourceTree = ""; }; 3FE19DB4246C7A22004827AB /* RoundCalculatorService.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RoundCalculatorService.swift; sourceTree = ""; }; @@ -179,6 +181,7 @@ 3FE19DB4246C7A22004827AB /* RoundCalculatorService.swift */, 9E0E459624796262009817A6 /* GameCenterManager.swift */, C04783EF24685995004961FB /* SettingsScene.swift */, + 3EAD889424801B6A0048A10A /* RoundTimer.swift */, ); path = GoldWars; sourceTree = ""; @@ -410,6 +413,8 @@ 8BB6FF402472B8F000162BBD /* SingeClickButtonNode.swift in Sources */, C064E9A8246C0EA50022B228 /* LabelNode.swift in Sources */, 3F745DF0246F48FC00CE7375 /* PlayerMoveType.swift in Sources */, + AB1D75A0245DEC0500671525 /* MapFactory.swift in Sources */, + 3EAD889524801B6A0048A10A /* RoundTimer.swift in Sources */, 3E67854024728368007B9DE4 /* CElements.swift in Sources */, ABA03DA0244BD54F00A66916 /* Base.swift in Sources */, C064E9AC246C151F0022B228 /* Label.swift in Sources */, diff --git a/GoldWars/GoldWars/Components/TimerComponent.swift b/GoldWars/GoldWars/Components/TimerComponent.swift index 1a7e678..c55b1b9 100644 --- a/GoldWars/GoldWars/Components/TimerComponent.swift +++ b/GoldWars/GoldWars/Components/TimerComponent.swift @@ -11,43 +11,25 @@ import GameplayKit class TimerComponent: GKComponent { let labelNode :SKLabelNode - var endTime :Date! - var duration :Double - var isRunning = false - - init(text: String, anchorPoint: CGPoint, duration: TimeInterval) { - self.labelNode = SKLabelNode(text: text) + let roundTimer: RoundTimer + init(anchorPoint: CGPoint) { + self.labelNode = SKLabelNode(text: "") self.labelNode.fontColor = UIColor.black self.labelNode.fontSize = CGFloat(45) self.labelNode.position = CGPoint(x: anchorPoint.x, y: anchorPoint.y - 15) - self.duration = duration + 1 + self.roundTimer = RoundTimer() super.init() - startWithDuration(duration: self.duration) + startWithDuration() } - func startWithDuration(duration: TimeInterval){ - isRunning = true - endTime = Date().addingTimeInterval(duration) + func startWithDuration(){ + print("startWithDuration") + roundTimer.startTimer() RoundCalculatorService.sharedInstance.isCalculating = false } func timeLeft() -> Int { - if isRunning { - let remainingSeconds = Int(endTime.timeIntervalSince(Date())) - if(remainingSeconds == 0) { - isRunning = false - } - return remainingSeconds - } - - // if(remainingSeconds < 0){ - // startWithDuration(duration: duration) - // } - return 0 - } - - func isFinished() -> Bool { - return timeLeft() == 0 + self.roundTimer.timeLeft } func update() { @@ -72,4 +54,3 @@ class TimerComponent: GKComponent { } } - diff --git a/GoldWars/GoldWars/Entities/HUD.swift b/GoldWars/GoldWars/Entities/HUD.swift index 4229f3f..3c8a37c 100644 --- a/GoldWars/GoldWars/Entities/HUD.swift +++ b/GoldWars/GoldWars/Entities/HUD.swift @@ -62,7 +62,7 @@ class HUD: GKEntity { peerUnitsLabel.position = CGPoint(x: size.width * 0.95, y: size.height * 0.9) setColor(labelNodes: [hostLabel,hostUnitsLabel,peerLabel,peerUnitsLabel]) - addComponent(TimerComponent(text: "", anchorPoint: CGPoint(x: size.width * 0.5, y: size.height * 0.9), duration: 30)) + addComponent(TimerComponent(anchorPoint: CGPoint(x: size.width * 0.5, y: size.height * 0.9))) } func updateUnitSum(){ diff --git a/GoldWars/GoldWars/GameCenterManager.swift b/GoldWars/GoldWars/GameCenterManager.swift index 8b7ab1e..d5b043a 100644 --- a/GoldWars/GoldWars/GameCenterManager.swift +++ b/GoldWars/GoldWars/GameCenterManager.swift @@ -128,7 +128,7 @@ final class GameCenterManager: NSObject, GKMatchmakerViewControllerDelegate ,GKM if let snapshotModel = try? jsonDecoder.decode(SnapshotModel.self, from: data) { DataService.sharedInstance.snapshotModel = snapshotModel entityManager.updateSnapshotModel(snapshotModel: snapshotModel) - entityManager.getTimer().startWithDuration(duration: 31) + entityManager.getTimer().startWithDuration() } if let mapModel = try? jsonDecoder.decode(MapGenerationModel.self, from: data) { os_log("Peer hat Map erhalten", log: LOG, type: .info) diff --git a/GoldWars/GoldWars/MultiplayerNetwork.swift b/GoldWars/GoldWars/MultiplayerNetwork.swift index 985ec14..aaac30d 100644 --- a/GoldWars/GoldWars/MultiplayerNetwork.swift +++ b/GoldWars/GoldWars/MultiplayerNetwork.swift @@ -38,6 +38,7 @@ class MultiplayerNetwork{ func sendPlayerMoves(localRoundData: LocalRoundData) { if GameCenterManager.sharedInstance.isServer == false { + print("I am client") self.isSending = true let encoder = JSONEncoder() let encoded = (try? encoder.encode(localRoundData))! diff --git a/GoldWars/GoldWars/RoundCalculatorService.swift b/GoldWars/GoldWars/RoundCalculatorService.swift index af824c4..a3bc482 100644 --- a/GoldWars/GoldWars/RoundCalculatorService.swift +++ b/GoldWars/GoldWars/RoundCalculatorService.swift @@ -129,7 +129,7 @@ class RoundCalculatorService { DataService.sharedInstance.snapshotModel = currentSnapshotModel entityManager.updateSnapshotModel(snapshotModel: currentSnapshotModel!) sleep(1) - entityManager.getTimer().startWithDuration(duration: 31) + entityManager.getTimer().startWithDuration() os_log("Finished calculating Round", log: RoundCalculatorService.LOG, type: .info) } diff --git a/GoldWars/GoldWars/RoundTimer.swift b/GoldWars/GoldWars/RoundTimer.swift new file mode 100644 index 0000000..0af4c8a --- /dev/null +++ b/GoldWars/GoldWars/RoundTimer.swift @@ -0,0 +1,51 @@ +// +// RoundTimer.swift +// GoldWars +// +// Created by Jakob Haag on 28.05.20. +// Copyright © 2020 SP2. All rights reserved. +// + +import Foundation + +class RoundTimer: Timer { + + var timer: Timer? + var timeLeft: Int = 0 + + func startTimer() { + print("start Timer") + self.timeLeft = 10 + timer = Timer.scheduledTimer( + timeInterval: 1.0, + target: self, + selector: #selector(onTimerFires), + userInfo: nil, + repeats: true + ) + } + + @objc func onTimerFires() + { + print(timeLeft) + self.timeLeft = self.timeLeft - 1 + + if timeLeft == 0 { + print("Time is up") + RoundCalculatorService.sharedInstance.resetNumberOfAttacksAndFormats() + print(!MultiplayerNetwork.sharedInstance.isSending) + if !MultiplayerNetwork.sharedInstance.isSending { + MultiplayerNetwork.sharedInstance.sendPlayerMoves(playerMoves: DataService.sharedInstance.localPlayerMoves) + } + print(!RoundCalculatorService.sharedInstance.isCalculating) + print(DataService.sharedInstance.didReceiveAllData()) + print(GameCenterManager.sharedInstance.isServer) + if !RoundCalculatorService.sharedInstance.isCalculating + && DataService.sharedInstance.didReceiveAllData() + && GameCenterManager.sharedInstance.isServer { + RoundCalculatorService.sharedInstance.calculateRound() + } + print("end method \(timeLeft)") + } + } +}