package com.momega.spacesimulator.builder; import java.util.ArrayList; import java.util.List; import org.springframework.stereotype.Component; import com.momega.spacesimulator.model.*; /** * The builder creates very simple model of the solar system just with the sun, moon and earth. * The moon and earth are orbiting common barycentre. * Created by martin on 7/14/14. */ @Component public class SimpleSolarSystemModelBuilder extends AbstractModelBuilder { protected CelestialBody sun; protected SphereOfInfluence sunSoi; @Override public void initPlanets() { sun = new CelestialBody(); updateDynamicalPoint(sun, "Sun", 1.989 * 1E6, 25.05, 696.342, 286.13, 63.87, "Sun", "/images/sun.png"); setCentralPoint(sun); createTrajectory(sun, new double[] {1, 0.7, 0}); sun.setTextureFileName("/textures/realsun.jpg"); BaryCentre earthMoonBarycenter = new BaryCentre(); updateDynamicalPoint(earthMoonBarycenter, "Earth-Moon Barycenter", 0, 0, 1, 0, null, null); createKeplerianElements(earthMoonBarycenter, sun, 149598.261d * 1E6, 0.0166739, 287.5824, 365.256814, 2456661.138788696378, 0.0018601064, 175.395d); createTrajectory(earthMoonBarycenter, new double[]{0, 0.5, 1}); CelestialBody earth = new Planet(); updateDynamicalPoint(earth, "Earth", 5.97219, 0.997269, 6.371, 0d, 90d, 190.147d, "Earth", "/images/earth.png"); createKeplerianElements(earth, earthMoonBarycenter, 4.686955382086 * 1E6, 0.055557, 264.7609, 27.427302, 2456796.39770, 5.241500, 208.1199); createTrajectory(earth, new double[]{0, 0.5, 1}); earth.setTextureFileName("/textures/earth_hi.jpg"); CelestialBody moon = new CelestialBody(); updateDynamicalPoint(moon, "Moon", 0.07349, 27.321, 1.737, 269.9949, 66.5392, 38.3213d, "Moon", "/images/moon.png"); createKeplerianElements(moon, earthMoonBarycenter, 384.399 * 1E6, 0.055557, 84.7609, 27.427302, 2456796.39770989, 5.241500, 208.1199); createTrajectory(moon, new double[]{0.5,0.5,0.5}); moon.setTextureFileName("/textures/moon_4k.jpg"); addMovingObject(sun); addMovingObject(earthMoonBarycenter); addMovingObject(earth); addMovingObject(moon); sunSoi = addPlanetToSoiTree(sun, null); SphereOfInfluence earthSoi = addPlanetToSoiTree(earth, sunSoi, earthMoonBarycenter.getKeplerianElements()); addPlanetToSoiTree(moon, earthSoi); } @Override public void initSpacecrafts() { CelestialBody earth = (CelestialBody) findMovingObject("Earth"); CelestialBody moon = (CelestialBody) findMovingObject("Moon"); Vector3d position = KeplerianOrbit.getCartesianPosition(200 * 1E3 + earth.getRadius(), Math.PI / 2, Math.toRadians(23.439291), Math.PI, 2d); Vector3d top = earth.getOrientation().getV(); Vector3d velocity = position.normalize().cross(top).scale(8200d).negate(); List<SpacecraftSubsystem> subsystems = new ArrayList<>(); Propulsion propulsion = new Propulsion(); propulsion.setMass(29000); propulsion.setFuel(28000); propulsion.setMassFlow(5); propulsion.setSpecificImpulse(311); propulsion.setName("Main Engine"); subsystems.add(propulsion); HabitableModule habitableModule = new HabitableModule(); habitableModule.setCrewCapacity(1); habitableModule.setMass(1000); habitableModule.setName("Habitat"); subsystems.add(habitableModule); Spacecraft spacecraft = createSpacecraft(earth, "Spacecraft 1", position, velocity, 1, new double[] {1, 1, 0}, subsystems); addManeuver(spacecraft, "M1", 20 * 60d, 2600d, 1d, 0, Math.toRadians(90)); addManeuver(spacecraft, "M2", 130 * 60d, 950d, 1d, 0, Math.toRadians(90)); addManeuver(spacecraft, "M3", 200 * 60d, 1500d, 1d, 0, Math.toRadians(0)); addManeuver(spacecraft, "M4", 5000 * 60d, 25, 0.1d, Math.toRadians(90), Math.toRadians(0)); addManeuver(spacecraft, "M5", 5712 * 60d, 45, 1d, Math.toRadians(270), Math.toRadians(90)); addManeuver(spacecraft, "M6", 5910 * 60d, 205, 1d, Math.toRadians(180), Math.toRadians(0)); CrashSite crashSite = CrashSite.createFromLatLong(earth, model.getTime(), 14.5, 50); crashSite.setName("Crash Site"); earth.getSurfacePoints().add(crashSite); setTarget(spacecraft, moon); } @Override protected void initCamera() { CelestialBody earth = (CelestialBody) findMovingObject("Earth"); createCamera(earth); } @Override protected MovingObject getCentralObject() { return sun; } @Override public String getName() { return "Simple Solar System model, mission to Moon"; } }