- Created RaceXMLCreator class - made a function to convert limit to GPS Coordinate (limitToGPSCoordinate) - can rotate a GPS Coordinate around a point (rotate) - can get center of a race with (getCenter) #story[1092]main
parent
4e8d4f2433
commit
f23c3f854d
@ -1,127 +0,0 @@
|
|||||||
//
|
|
||||||
// This file was generated by the JavaTM Architecture for XML Binding(JAXB) Reference Implementation, v2.2.8-b130911.1802
|
|
||||||
// See <a href="http://java.sun.com/xml/jaxb">http://java.sun.com/xml/jaxb</a>
|
|
||||||
// Any modifications to this file will be lost upon recompilation of the source schema.
|
|
||||||
// Generated on: 2017.08.03 at 02:28:57 AM NZST
|
|
||||||
//
|
|
||||||
|
|
||||||
|
|
||||||
package mock.xml;
|
|
||||||
|
|
||||||
import javax.xml.bind.annotation.XmlRegistry;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This object contains factory methods for each
|
|
||||||
* Java content interface and Java element interface
|
|
||||||
* generated in the race package.
|
|
||||||
* <p>An ObjectFactory allows you to programatically
|
|
||||||
* construct new instances of the Java representation
|
|
||||||
* for XML content. The Java representation of XML
|
|
||||||
* content can consist of schema derived interfaces
|
|
||||||
* and classes representing the binding of schema
|
|
||||||
* type definitions, element declarations and model
|
|
||||||
* groups. Factory methods for each of these are
|
|
||||||
* provided in this class.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
@XmlRegistry
|
|
||||||
public class ObjectFactory {
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create a new ObjectFactory that can be used to create new instances of schema derived classes for package: race
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public ObjectFactory() {
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create an instance of {@link Race }
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public Race createRace() {
|
|
||||||
return new Race();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create an instance of {@link Race.CourseLimit }
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public Race.CourseLimit createRaceCourseLimit() {
|
|
||||||
return new Race.CourseLimit();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create an instance of {@link Race.Course }
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public Race.Course createRaceCourse() {
|
|
||||||
return new Race.Course();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create an instance of {@link Race.Course.CompoundMark }
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public Race.Course.CompoundMark createRaceCourseCompoundMark() {
|
|
||||||
return new Race.Course.CompoundMark();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create an instance of {@link Race.CompoundMarkSequence }
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public Race.CompoundMarkSequence createRaceCompoundMarkSequence() {
|
|
||||||
return new Race.CompoundMarkSequence();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create an instance of {@link Race.Participants }
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public Race.Participants createRaceParticipants() {
|
|
||||||
return new Race.Participants();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create an instance of {@link Race.RaceStartTime }
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public Race.RaceStartTime createRaceRaceStartTime() {
|
|
||||||
return new Race.RaceStartTime();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create an instance of {@link Race.CourseLimit.Limit }
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public Race.CourseLimit.Limit createRaceCourseLimitLimit() {
|
|
||||||
return new Race.CourseLimit.Limit();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create an instance of {@link Race.Course.CompoundMark.Mark }
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public Race.Course.CompoundMark.Mark createRaceCourseCompoundMarkMark() {
|
|
||||||
return new Race.Course.CompoundMark.Mark();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create an instance of {@link Race.CompoundMarkSequence.Corner }
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public Race.CompoundMarkSequence.Corner createRaceCompoundMarkSequenceCorner() {
|
|
||||||
return new Race.CompoundMarkSequence.Corner();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create an instance of {@link Race.Participants.Yacht }
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public Race.Participants.Yacht createRaceParticipantsYacht() {
|
|
||||||
return new Race.Participants.Yacht();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@ -0,0 +1,142 @@
|
|||||||
|
package mock.xml;
|
||||||
|
|
||||||
|
import shared.dataInput.RaceXMLReader;
|
||||||
|
import shared.enums.XMLFileType;
|
||||||
|
import shared.exceptions.InvalidRaceDataException;
|
||||||
|
import shared.exceptions.XMLReaderException;
|
||||||
|
import shared.model.CompoundMark;
|
||||||
|
import shared.model.Corner;
|
||||||
|
import shared.model.GPSCoordinate;
|
||||||
|
|
||||||
|
import javax.xml.bind.JAXBContext;
|
||||||
|
import javax.xml.bind.JAXBException;
|
||||||
|
import javax.xml.bind.Marshaller;
|
||||||
|
import java.io.StringWriter;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Created by Gondr on 3/08/2017.
|
||||||
|
*/
|
||||||
|
public class RaceXMLCreator {
|
||||||
|
|
||||||
|
public static Race copyRace(RaceXMLReader reader) throws InvalidRaceDataException, XMLReaderException {
|
||||||
|
RaceFactory raceFactory = new RaceFactory();
|
||||||
|
Race race = raceFactory.createRace();
|
||||||
|
race.setRaceID(String.valueOf(reader.getRaceId()));
|
||||||
|
race.setRaceType(String.valueOf(reader.getRaceType()));
|
||||||
|
race.setCreationTimeDate("CREATION_TIME");//this needs to be changed later
|
||||||
|
|
||||||
|
//Race Start Time
|
||||||
|
Race.RaceStartTime raceStartTime = raceFactory.createRaceRaceStartTime();
|
||||||
|
raceStartTime.setPostpone("false");
|
||||||
|
raceStartTime.setTime("START_TIME");//this needs to be changed later
|
||||||
|
race.setRaceStartTime(raceStartTime);
|
||||||
|
|
||||||
|
//Participants
|
||||||
|
Race.Participants participants = raceFactory.createRaceParticipants();
|
||||||
|
for (int i :reader.getParticipants()) {
|
||||||
|
Race.Participants.Yacht yacht = raceFactory.createRaceParticipantsYacht();
|
||||||
|
yacht.setSourceID(String.valueOf(i));
|
||||||
|
participants.getYacht().add(yacht); //java schema does not clone the array so this is "safe".
|
||||||
|
}
|
||||||
|
race.setParticipants(participants);
|
||||||
|
|
||||||
|
//compound marks sequence
|
||||||
|
Race.CompoundMarkSequence cms = raceFactory.createRaceCompoundMarkSequence();
|
||||||
|
for (Corner mark: reader.getCornersList()){
|
||||||
|
Race.CompoundMarkSequence.Corner corner = raceFactory.createRaceCompoundMarkSequenceCorner();
|
||||||
|
corner.setCompoundMarkID(String.valueOf(mark.getId()));
|
||||||
|
corner.setSeqID(String.valueOf(mark.getSeqID()));
|
||||||
|
cms.getCorner().add(corner);
|
||||||
|
}
|
||||||
|
race.setCompoundMarkSequence(cms);
|
||||||
|
|
||||||
|
//Course
|
||||||
|
Race.Course course = raceFactory.createRaceCourse();
|
||||||
|
for (CompoundMark mark: reader.getCompoundMarks()){
|
||||||
|
Race.Course.CompoundMark cm = raceFactory.createRaceCourseCompoundMark();
|
||||||
|
cm.setName(mark.getName());
|
||||||
|
cm.setCompoundMarkID(String.valueOf(mark.getId()));
|
||||||
|
if (mark.getMark1() != null){
|
||||||
|
Race.Course.CompoundMark.Mark m1 = raceFactory.createRaceCourseCompoundMarkMark();
|
||||||
|
m1.setName(mark.getMark1().getName());
|
||||||
|
m1.setTargetLat(String.valueOf(mark.getMark1().getPosition().getLatitude()));
|
||||||
|
m1.setTargetLng(String.valueOf(mark.getMark1().getPosition().getLongitude()));
|
||||||
|
m1.setSourceID(String.valueOf(mark.getMark1().getSourceID()));
|
||||||
|
cm.getMark().add(m1);
|
||||||
|
}
|
||||||
|
//make this not copy paste later but just need the concept working right now
|
||||||
|
if (mark.getMark2() != null){
|
||||||
|
Race.Course.CompoundMark.Mark m2 = raceFactory.createRaceCourseCompoundMarkMark();
|
||||||
|
m2.setName(mark.getMark1().getName());
|
||||||
|
m2.setTargetLat(String.valueOf(mark.getMark1().getPosition().getLatitude()));
|
||||||
|
m2.setTargetLng(String.valueOf(mark.getMark1().getPosition().getLongitude()));
|
||||||
|
m2.setSourceID(String.valueOf(mark.getMark1().getSourceID()));
|
||||||
|
cm.getMark().add(m2);
|
||||||
|
}
|
||||||
|
course.getCompoundMark().add(cm);
|
||||||
|
}
|
||||||
|
race.setCourse(course);
|
||||||
|
|
||||||
|
//Course Limit
|
||||||
|
Race.CourseLimit courseLimit = raceFactory.createRaceCourseLimit();
|
||||||
|
for (int i = 0; i < reader.getBoundary().size(); i++){
|
||||||
|
Race.CourseLimit.Limit limit = raceFactory.createRaceCourseLimitLimit();
|
||||||
|
limit.setSeqID(String.valueOf(i+1));
|
||||||
|
limit.setLat(String.valueOf(reader.getBoundary().get(i).getLatitude()));
|
||||||
|
limit.setLon(String.valueOf(reader.getBoundary().get(i).getLongitude()));
|
||||||
|
courseLimit.getLimit().add(limit);
|
||||||
|
}
|
||||||
|
race.setCourseLimit(courseLimit);
|
||||||
|
|
||||||
|
return race;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String alterRaceToWind(String s, double degrees) throws XMLReaderException, InvalidRaceDataException, JAXBException {
|
||||||
|
RaceXMLReader reader = new RaceXMLReader(s, XMLFileType.ResourcePath);
|
||||||
|
|
||||||
|
Race race = copyRace(reader);
|
||||||
|
|
||||||
|
GPSCoordinate center = getCenter(race);
|
||||||
|
for(Race.CourseLimit.Limit limit: race.getCourseLimit().getLimit()){
|
||||||
|
GPSCoordinate rotatedLim = rotate(center, limitToGPSCoordinate(limit), degrees);
|
||||||
|
limit.setLat(String.valueOf(rotatedLim.getLatitude()));
|
||||||
|
limit.setLon(String.valueOf(rotatedLim.getLongitude()));
|
||||||
|
}
|
||||||
|
|
||||||
|
JAXBContext context = JAXBContext.newInstance(Race.class);
|
||||||
|
Marshaller jaxbMarshaller = context.createMarshaller();
|
||||||
|
jaxbMarshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true);
|
||||||
|
|
||||||
|
StringWriter sw = new StringWriter();
|
||||||
|
|
||||||
|
jaxbMarshaller.marshal(race, sw);
|
||||||
|
return sw.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static GPSCoordinate limitToGPSCoordinate(Race.CourseLimit.Limit limit){
|
||||||
|
return new GPSCoordinate(Double.parseDouble(limit.getLat()), Double.parseDouble(limit.getLon()));
|
||||||
|
}
|
||||||
|
|
||||||
|
public static GPSCoordinate rotate(GPSCoordinate pivot, GPSCoordinate point, double degrees){
|
||||||
|
double radDeg = Math.toRadians(degrees);
|
||||||
|
double deltaLat = (point.getLatitude() - pivot.getLatitude());
|
||||||
|
double deltaLon = (point.getLongitude() - pivot.getLongitude());
|
||||||
|
//map to (0,1) vector and use vector maths to rotate.
|
||||||
|
double resLat = deltaLat * Math.cos(radDeg) - deltaLon * Math.sin(radDeg) + pivot.getLatitude();
|
||||||
|
double resLon = deltaLat * Math.sin(radDeg) + deltaLon * Math.cos(radDeg) + pivot.getLongitude();
|
||||||
|
return new GPSCoordinate(resLat, resLon);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static GPSCoordinate getCenter(Race race){
|
||||||
|
double avgLat = 0;
|
||||||
|
double avgLng = 0;
|
||||||
|
for (Race.CourseLimit.Limit limit: race.getCourseLimit().getLimit()){
|
||||||
|
avgLat += Double.parseDouble(limit.getLat());
|
||||||
|
avgLng += Double.parseDouble(limit.getLon());
|
||||||
|
}
|
||||||
|
avgLat = avgLat/race.getCourseLimit().getLimit().size();
|
||||||
|
avgLng = avgLng/race.getCourseLimit().getLimit().size();
|
||||||
|
return new GPSCoordinate(avgLat, avgLng);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
Loading…
Reference in new issue