Added game duration to tournament match view.

This commit is contained in:
LevelX2 2014-10-01 17:29:44 +02:00
parent fde0888ffc
commit 8c9b97969e
3 changed files with 89 additions and 4 deletions

View file

@ -0,0 +1,76 @@
/*
* Copyright 2010 BetaSteward_at_googlemail.com. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without modification, are
* permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice, this list of
* conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright notice, this list
* of conditions and the following disclaimer in the documentation and/or other materials
* provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY BetaSteward_at_googlemail.com ``AS IS'' AND ANY EXPRESS OR IMPLIED
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
* FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BetaSteward_at_googlemail.com OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* The views and conclusions contained in the software and documentation are those of the
* authors and should not be interpreted as representing official policies, either expressed
* or implied, of BetaSteward_at_googlemail.com.
*/
package mage.utils;
import java.util.Date;
/**
*
* @author LevelX2
*/
public class DateFormat {
/**
* calculates the duration between two dates and returns a string in the format hhh:mm:ss
*
* @param fromDate - start date
* @param toDate - end date
* @return a string in the format hhh:mm:ss
*/
public static String getDuration(Date fromDate, Date toDate) {
if (fromDate == null || toDate == null || fromDate.getTime() > toDate.getTime()) {
return "";
}
return getDuration((toDate.getTime() - fromDate.getTime()) / 1000);
}
/**
* Converts seconds to a string with hours, minutes and seconds
*
* @param seconds - seconds of the duration
* @return a string in the format hhh:mm:ss
*/
public static String getDuration(long seconds) {
StringBuilder sb = new StringBuilder();
long h = seconds / 3600;
seconds = seconds % 3600;
long m = seconds / 60;
long s = seconds % 60;
sb.append(h).append(":");
if (m<10) {
sb.append("0");
}
sb.append(m).append(":");
if (s<10) {
sb.append("0");
}
sb.append(s);
return sb.toString();
}
}

View file

@ -42,7 +42,7 @@ import mage.game.tournament.TournamentPairing;
public class RoundView implements Serializable { public class RoundView implements Serializable {
private static final long serialVersionUID = 1L; private static final long serialVersionUID = 1L;
List<TournamentGameView> games = new ArrayList<TournamentGameView>(); List<TournamentGameView> games = new ArrayList<>();
public RoundView(Round round) { public RoundView(Round round) {
for (TournamentPairing pair: round.getPairs()) { for (TournamentPairing pair: round.getPairs()) {

View file

@ -29,9 +29,11 @@
package mage.view; package mage.view;
import java.io.Serializable; import java.io.Serializable;
import java.util.Date;
import java.util.UUID; import java.util.UUID;
import mage.game.Game; import mage.game.Game;
import mage.game.tournament.TournamentPairing; import mage.game.tournament.TournamentPairing;
import mage.utils.DateFormat;
/** /**
* *
@ -54,15 +56,22 @@ public class TournamentGameView implements Serializable {
this.matchId = pair.getMatch().getId(); this.matchId = pair.getMatch().getId();
this.gameId = game.getId(); this.gameId = game.getId();
this.players = pair.getPlayer1().getPlayer().getName() + " - " + pair.getPlayer2().getPlayer().getName(); this.players = pair.getPlayer1().getPlayer().getName() + " - " + pair.getPlayer2().getPlayer().getName();
String duelingTime = "";
if (game.hasEnded()) { if (game.hasEnded()) {
this.state = "Finished"; if (game.getEndTime() != null) {
duelingTime = " (" + DateFormat.getDuration((game.getEndTime().getTime() - game.getStartTime().getTime())/1000) + ")";
}
this.state = "Finished" + duelingTime;
this.result = game.getWinner(); this.result = game.getWinner();
} }
else { else {
this.state = "Dueling"; duelingTime = " (" + DateFormat.getDuration((new Date().getTime() - game.getStartTime().getTime())/1000) + ")";
this.state = "Dueling" + duelingTime;
this.result = ""; this.result = "";
} }
this.tableId = pair.getTableId(); this.tableId = pair.getTableId();
} }
public int getRoundNum() { public int getRoundNum() {