WarpPI/core/src/main/java/it/cavallium/warppi/Engine.java

147 lines
4.8 KiB
Java
Raw Normal View History

package it.cavallium.warppi;
import java.io.IOException;
import it.cavallium.warppi.Platform.ConsoleUtils;
import it.cavallium.warppi.boot.StartupArguments;
import it.cavallium.warppi.device.HardwareDevice;
import it.cavallium.warppi.device.HardwareTouchDevice;
import it.cavallium.warppi.device.InputManager;
import it.cavallium.warppi.device.Keyboard;
import it.cavallium.warppi.flow.BehaviorSubject;
import it.cavallium.warppi.flow.Observable;
import it.cavallium.warppi.gui.DisplayManager;
import it.cavallium.warppi.gui.HUD;
import it.cavallium.warppi.gui.HardwareDisplay;
import it.cavallium.warppi.gui.screens.Screen;
import it.cavallium.warppi.util.ClassUtils;
public class Engine {
public static final Engine INSTANCE = new Engine();
2018-09-04 12:12:41 +02:00
private static Platform platform;
private static boolean running = false;
private static BehaviorSubject<LoadingStatus> loadPhase = BehaviorSubject.create();
2018-09-22 11:17:30 +02:00
private final BehaviorSubject<Boolean> loaded = BehaviorSubject.create(false);
private HardwareDevice hardwareDevice;
2018-09-22 11:17:30 +02:00
private Engine() {}
/**
* Start an instance of the calculator.
2018-09-22 11:17:30 +02:00
*
2018-09-04 12:12:41 +02:00
* @param platform
* Platform implementation
* @param screen
* Default screen to show at startup
* @param disp
* Hardware display
* @param hud
* Head-up display
* @param args
* Startup arguments
* @throws InterruptedException
* @throws IOException
*/
2018-09-22 11:17:30 +02:00
public static void start(final Platform platform, final Screen screen, final HardwareDisplay disp,
final HardwareTouchDevice touchdevice, final HUD hud, final StartupArguments args)
throws InterruptedException, IOException {
2018-09-28 11:39:28 +02:00
if (Engine.running) {
2018-09-02 14:21:08 +02:00
throw new RuntimeException("Already running!");
2018-09-28 11:39:28 +02:00
} else {
2018-09-22 11:17:30 +02:00
Engine.running = true;
Engine.INSTANCE.startInstance(platform, screen, disp, touchdevice, hud, args);
}
}
2018-09-22 11:17:30 +02:00
private void startInstance(final Platform platform, final Screen screen, final HardwareDisplay disp,
final HardwareTouchDevice touchdevice, final HUD hud, final StartupArguments args)
throws InterruptedException, IOException {
2018-09-04 12:12:41 +02:00
Engine.platform = platform;
platform.getConsoleUtils().out().println("WarpPI Calculator");
initializeEnvironment(args);
2018-09-22 11:17:30 +02:00
final Thread currentThread = Thread.currentThread();
currentThread.setPriority(Thread.MAX_PRIORITY);
2018-09-04 12:12:41 +02:00
Engine.getPlatform().setThreadName(currentThread, "Main thread");
2018-09-22 11:17:30 +02:00
final DisplayManager dm = new DisplayManager(disp, hud, screen, "WarpPI Calculator by Andrea Cavalli (@Cavallium)");
final Keyboard k = new Keyboard();
final InputManager im = new InputManager(k, touchdevice);
hardwareDevice = new HardwareDevice(dm, im);
2018-09-22 11:17:30 +02:00
hardwareDevice.setup(() -> Engine.loadPhase.onNext(new LoadingStatus()));
}
private void onShutdown() {
2018-09-04 12:12:41 +02:00
Engine.platform.getConsoleUtils().out().println(1, "Shutdown...");
beforeShutdown();
2018-09-04 12:12:41 +02:00
Engine.platform.getConsoleUtils().out().println(1, "");
Engine.platform.getConsoleUtils().out().println(1, "Closed.");
Engine.getPlatform().exit(0);
}
2018-09-22 11:17:30 +02:00
private void initializeEnvironment(final StartupArguments args) throws IOException {
ClassUtils.classLoader = this.getClass();
StaticVars.startupArguments = args;
StaticVars.debugWindow2x = args.isZoomed();
2018-09-28 11:39:28 +02:00
if (args.isVerboseLoggingEnabled() || args.isDebugEnabled()) {
StaticVars.outputLevel = ConsoleUtils.OUTPUTLEVEL_DEBUG_VERBOSE;
2018-09-28 11:39:28 +02:00
}
2018-09-04 12:12:41 +02:00
Engine.platform.getConsoleUtils().out().println(ConsoleUtils.OUTPUTLEVEL_DEBUG_MIN, args);
checkDeviceType();
2018-10-06 16:37:44 +02:00
if (args.isRaspberryModeAllowed() == false) {
Engine.getPlatform().setRunningOnRaspberry(false);
}
if (Engine.getPlatform().isRunningOnRaspberry()) {
2018-09-04 12:12:41 +02:00
Engine.getPlatform().getGpio().wiringPiSetupPhys();
Engine.getPlatform().getGpio().pinMode(12, Engine.getPlatform().getGpio().valuePwmOutput());
} else {
StaticVars.screenPos = new int[] { 0, 0 };
2018-10-06 16:37:44 +02:00
if (Engine.getPlatform().isJavascript() == false) {
Engine.getPlatform().getSettings().setDebugEnabled(true);
}
}
}
private void checkDeviceType() {
// TODO Auto-generated method stub
}
public void beforeShutdown() {
Keyboard.stopKeyboard();
}
public Observable<Boolean> isLoaded() {
return loaded;
}
public Observable<LoadingStatus> getLoadPhase() {
2018-09-22 11:17:30 +02:00
return Engine.loadPhase;
}
2018-09-22 11:17:30 +02:00
public HardwareDevice getHardwareDevice() {
return hardwareDevice;
}
2018-09-22 11:17:30 +02:00
2018-09-04 12:12:41 +02:00
public static Platform getPlatform() {
2018-09-22 11:17:30 +02:00
return Engine.platform;
2018-09-04 12:12:41 +02:00
}
public static class LoadingStatus {
protected LoadingStatus() {
}
public void done() {
Engine.INSTANCE.loaded.onNext(true);
Engine.INSTANCE.hardwareDevice.getDisplayManager().waitForExit();
Engine.INSTANCE.onShutdown();
}
public void failed() {
Engine.INSTANCE.onShutdown();
}
}
}