mirror of
https://github.com/michaelrausch/Party-Parrots-At-Sea.git
synced 2026-05-09 14:28:43 +00:00
ae80b434f6
Tags #docs
246 lines
7.3 KiB
Java
246 lines
7.3 KiB
Java
package seng302;
|
|
|
|
import java.lang.reflect.Array;
|
|
import java.util.*;
|
|
|
|
public class Race {
|
|
private ArrayList<Boat> boats; // The boats in the race
|
|
private ArrayList<Leg> legs; // The legs in the race
|
|
private ArrayList<Boat> finishingOrder; // The order in which the boats finish the race
|
|
private PriorityQueue<Event> events; // The events that occur in the race
|
|
private int numberOfBoats = 0;
|
|
private long startTime = 0;
|
|
private double timeScale = 1;
|
|
|
|
public Race() {
|
|
this.boats = new ArrayList<Boat>();
|
|
this.legs = new ArrayList<Leg>();
|
|
this.finishingOrder = new ArrayList<Boat>();
|
|
|
|
// create a priority queue with a custom Comparator to order events
|
|
this.events = new PriorityQueue<Event>(new Comparator<Event>() {
|
|
@Override
|
|
public int compare(Event o1, Event o2) {
|
|
Long time1 = o1.getTime();
|
|
Long time2 = o2.getTime();
|
|
|
|
// order event asc. by time. if tie appears, then order team
|
|
// name alphabetically.
|
|
if (time1 != time2) {
|
|
return time1.compareTo(time2);
|
|
} else {
|
|
return o1.getBoat().getTeamName().compareTo(o2.getBoat().getTeamName());
|
|
}
|
|
}
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Add a boat to the race
|
|
*
|
|
* @param boat, the boat to add
|
|
*/
|
|
public void addBoat(Boat boat) {
|
|
boats.add(boat);
|
|
numberOfBoats += 1;
|
|
}
|
|
|
|
/**
|
|
* Returns a list of boats in a random order
|
|
*
|
|
* @returns a list of boats
|
|
*/
|
|
public Boat[] getShuffledBoats() {
|
|
// Shuffle the list of boats
|
|
long seed = System.nanoTime();
|
|
Collections.shuffle(this.boats, new Random(seed));
|
|
|
|
return boats.toArray(new Boat[boats.size()]);
|
|
}
|
|
|
|
/**
|
|
* Returns a list of boats in the order that they
|
|
* finished the race (position 0 is first place)
|
|
*
|
|
* @returns a list of boats
|
|
*/
|
|
public Boat[] getFinishedBoats() {
|
|
return this.finishingOrder.toArray(new Boat[this.finishingOrder.size()]);
|
|
}
|
|
|
|
/**
|
|
* Returns the number of boats in the race
|
|
*
|
|
* @returns the number of boats in the race
|
|
*/
|
|
public int getNumberOfBoats() {
|
|
return numberOfBoats;
|
|
}
|
|
|
|
/**
|
|
* Returns a list of boats in the race
|
|
*
|
|
* @returns a list of the boats competing in the race
|
|
*/
|
|
public Boat[] getBoats() {
|
|
return boats.toArray(new Boat[boats.size()]);
|
|
}
|
|
|
|
/**
|
|
* Prints the order in which the boats finished
|
|
*/
|
|
public void displayFinishingOrder() {
|
|
int numberOfBoats = this.getNumberOfBoats();
|
|
Boat[] boats = this.getFinishedBoats();
|
|
|
|
System.out.println("\n\n");
|
|
System.out.println("--- Finishing Order ---");
|
|
|
|
for (int i = 0; i < Array.getLength(boats); i++) {
|
|
System.out.println("#" + Integer.toString(i + 1) + " - " + boats[i].getTeamName());
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Prints the list of boats competing in the race
|
|
*/
|
|
public void displayStartingBoats() {
|
|
int numberOfBoats = this.getNumberOfBoats();
|
|
Boat[] boats = this.getBoats();
|
|
|
|
System.out.println("######################");
|
|
System.out.println("# Competing Boats ");
|
|
System.out.println("######################");
|
|
|
|
for (int i = 0; i < numberOfBoats; i++) {
|
|
String velocityKnots = String.format("%1.2f", boats[i].getVelocity() * 1.943844492);
|
|
|
|
System.out.println(boats[i].getTeamName() + " Velocity: " + velocityKnots);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Adds a leg to the race
|
|
*
|
|
* @param leg, the leg to add to the race
|
|
*/
|
|
public void addLeg(Leg leg) {
|
|
this.legs.add(leg);
|
|
}
|
|
|
|
/**
|
|
* Gets legs array
|
|
*
|
|
* @return an array of legs
|
|
*/
|
|
public ArrayList<Leg> getLegs() {
|
|
return this.legs;
|
|
}
|
|
|
|
/**
|
|
* Sets time scale
|
|
*
|
|
* @param timeScale
|
|
*/
|
|
public void setTimeScale(double timeScale) {
|
|
this.timeScale = timeScale;
|
|
}
|
|
|
|
/**
|
|
* Temporary method used to generated all the events.
|
|
*/
|
|
private void generateEvents() {
|
|
|
|
//calculate the time for every boat passes each leg, and create an event
|
|
for (Boat boat : this.boats) {
|
|
long totalDistance = 0;
|
|
for (Leg leg : this.legs) {
|
|
long time = (long) (1000 * totalDistance / boat.getVelocity());
|
|
Event event = new Event(time, boat, leg);
|
|
events.add(event);
|
|
totalDistance += leg.getDistance();
|
|
|
|
// If finishing leg, add another event for when the boat finishes the race
|
|
if (leg.getIsFinishingLeg()) {
|
|
time = (long) (1000 * totalDistance / boat.getVelocity());
|
|
event = new Event(time, boat, leg, true);
|
|
events.add(event);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Note: this function is useless so far
|
|
* Calculates how far a boat has travelled in meter
|
|
*
|
|
* @param velocity the velocity of boat
|
|
* @return a float number of distance the boat has been travelled
|
|
*/
|
|
public float getDistanceTravelled(long velocity) {
|
|
long timeDiff = System.currentTimeMillis() - this.startTime;
|
|
long timeElapse = (long) (timeDiff / 1000 * this.timeScale);
|
|
return timeElapse * velocity;
|
|
}
|
|
|
|
/**
|
|
* Iterate over events in the race and print the
|
|
* event string for each event
|
|
*/
|
|
public void iterateEvents() {
|
|
// iterates all events. ends when no event in events.
|
|
while (!events.isEmpty()) {
|
|
Event peekEvent = events.peek();
|
|
long currentTime = (long) ((System.currentTimeMillis() - this.startTime) * this.timeScale);
|
|
|
|
if (currentTime > peekEvent.getTime()) {
|
|
// pull out the event
|
|
Event nextEvent = events.poll();
|
|
|
|
// I just simply print it out for testing
|
|
System.out.println(nextEvent.getEventString());
|
|
nextEvent.boatPassedMarker();
|
|
|
|
if (nextEvent.getIsFinishingEvent()) {
|
|
this.finishingOrder.add(nextEvent.getBoat());
|
|
}
|
|
}
|
|
|
|
// Wait for 100ms to slow down the while loop
|
|
try {
|
|
Thread.sleep(100);
|
|
} catch (java.lang.InterruptedException e) {
|
|
continue;
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Start the race and print each marker with the order
|
|
* in which the boats passed that marker
|
|
*/
|
|
public void startRace() {
|
|
// record start time.
|
|
generateEvents();
|
|
this.startTime = System.currentTimeMillis();
|
|
iterateEvents();
|
|
}
|
|
|
|
/**
|
|
* Print the order in which the boats passed each marker
|
|
*/
|
|
public void showRaceMarkerResults() {
|
|
for (Leg leg : this.legs) {
|
|
Boat[] boats = leg.getMarker().getBoats();
|
|
|
|
System.out.println("--- " + leg.getMarkerLabel() + " ---");
|
|
|
|
// Print the order in which the boats passed the marker
|
|
for (int i = 0; i < this.getNumberOfBoats(); i++) {
|
|
System.out.println("#" + Integer.toString(i + 1) + " - " + boats[i].getTeamName());
|
|
}
|
|
|
|
System.out.println("");
|
|
}
|
|
}
|
|
} |