X-Git-Url: http://dolda2000.com/gitweb/?a=blobdiff_plain;f=src%2Fkaka%2Fcakelight%2FCakeLight.java;h=0c1aa1ac5be2caa68d15c8a598c51389f0f955f1;hb=fc040bcb6270ff0a4bfaab6cfeaad60edef2a11c;hp=69f6677af0d8a80ae5be7bb45514abb8de55c8dc;hpb=a276d5abce63f4d7b54ae59a026730fdf7591b85;p=kaka%2Fcakelight.git diff --git a/src/kaka/cakelight/CakeLight.java b/src/kaka/cakelight/CakeLight.java index 69f6677..0c1aa1a 100644 --- a/src/kaka/cakelight/CakeLight.java +++ b/src/kaka/cakelight/CakeLight.java @@ -1,8 +1,19 @@ package kaka.cakelight; +import kaka.cakelight.mode.Mode; +import org.jnativehook.GlobalScreen; +import org.jnativehook.NativeHookException; +import org.jnativehook.keyboard.NativeKeyAdapter; +import org.jnativehook.keyboard.NativeKeyEvent; +import org.jnativehook.mouse.NativeMouseEvent; +import org.jnativehook.mouse.NativeMouseMotionAdapter; + +import java.util.Objects; +import java.util.Stack; + public class CakeLight { private Configuration config; - private Mode mode; + private Stack modes = new Stack<>(); private LedController ledController; public CakeLight(Configuration config, LedController ledController) { @@ -13,23 +24,54 @@ public class CakeLight { public void setMode(Mode mode) { cleanup(); - this.mode = mode; - mode.setFrameListener(ledController::onFrame); - mode.enter(config); + pushMode(mode); } public void cleanup() { - if (this.mode != null) { - this.mode.exit(); + while (popMode()); + } + + public void pushMode(Mode mode) { + Objects.requireNonNull(mode); + if (!modes.isEmpty()) { + stopMode(modes.peek()); + } + modes.push(mode); + startMode(mode); + // TODO: create a composite fading mode of top of stack and new mode + } + + public boolean popMode() { + if (!modes.isEmpty()) { + Mode mode = modes.pop(); + stopMode(mode); + if (!modes.isEmpty()) { + startMode(modes.peek()); + } + return true; } + return false; + // TODO: create a composite fading mode of popped mode and top of stack, unless doing cleanup + } + + private void startMode(Mode mode) { + mode.setFrameListener(ledController::onFrame); + mode.enter(config); + } + + private void stopMode(Mode mode) { + mode.setFrameListener(ledFrame -> {}); // To avoid any frame being sent to the controller while the thread is exiting + mode.exit(); } public void startLoop() { - Console.start(this, config); + Console console = Console.start(this, config); + PipeController.start(console); +// initNativeHook(); // TODO // FrameGrabber grabber = FrameGrabber.from(config); // grabber.prepare(); -// Frame frame = grabber.grabFrame(); +// VideoFrame frame = grabber.grabFrame(); // double time = 0; // for (int i = 0; i < 100; i++) { // time += timeIt("frame", () -> grabber.grabFrame()); @@ -40,8 +82,28 @@ public class CakeLight { // saveFile(data, "/home/kaka/test.img"); } + private void initNativeHook() { + try { + GlobalScreen.registerNativeHook(); + GlobalScreen.addNativeKeyListener(new NativeKeyAdapter() { + @Override + public void nativeKeyPressed(NativeKeyEvent e) { + System.out.println("key code = " + e.getKeyCode() + ", key text = '" + NativeKeyEvent.getKeyText(e.getKeyCode()) + "'"); + } + }); + GlobalScreen.addNativeMouseMotionListener(new NativeMouseMotionAdapter() { + @Override + public void nativeMouseMoved(NativeMouseEvent e) { + System.out.println("mouse point = " + e.getPoint()); + } + }); + } catch (NativeHookException e) { + e.printStackTrace(); + } + } + public void turnOff() { cleanup(); - ledController.onFrame(LedFrame.from(config)); + ledController.onFrame(LedFrame.from(config).fillColor(0, 0, 0)); } }