X-Git-Url: http://dolda2000.com/gitweb/?a=blobdiff_plain;f=src%2Fkaka%2Fcakelight%2FCakeLight.java;h=95a3be11f639b20786597345012901655d5f8b0f;hb=6e568391dad1a1c47b5697a2f1ef90a685859a84;hp=afc7b2674020a010cd4fc551d0ce34aa3543388e;hpb=4a2d60564647052562fad28644904298ba83667b;p=kaka%2Fcakelight.git diff --git a/src/kaka/cakelight/CakeLight.java b/src/kaka/cakelight/CakeLight.java index afc7b26..95a3be1 100644 --- a/src/kaka/cakelight/CakeLight.java +++ b/src/kaka/cakelight/CakeLight.java @@ -1,28 +1,32 @@ package kaka.cakelight; -import static kaka.cakelight.Main.timeIt; - public class CakeLight { private Configuration config; private Mode mode; + private LedController ledController; - public CakeLight(Configuration config) { + public CakeLight(Configuration config, LedController ledController) { this.config = config; + this.ledController = ledController; + Color.calculateGammaCorrection(config.gamma); } public void setMode(Mode mode) { cleanup(); this.mode = mode; + mode.setFrameListener(ledController::onFrame); mode.enter(config); } public void cleanup() { if (this.mode != null) { + this.mode.setFrameListener(ledFrame -> {}); // To avoid any frame being sent to the controller while the thread is exiting this.mode.exit(); } } public void startLoop() { + Console.start(this, config); // TODO // FrameGrabber grabber = FrameGrabber.from(config); // grabber.prepare(); @@ -36,4 +40,9 @@ public class CakeLight { // byte[] data = frame.getData(); // saveFile(data, "/home/kaka/test.img"); } + + public void turnOff() { + cleanup(); + ledController.onFrame(LedFrame.from(config).fillColor(0, 0, 0)); + } }