X-Git-Url: http://dolda2000.com/gitweb/?p=kaka%2Fcakelight.git;a=blobdiff_plain;f=src%2Fkaka%2Fcakelight%2Fmode%2FVideoMode.java;fp=src%2Fkaka%2Fcakelight%2Fmode%2FVideoMode.java;h=c7985e3615c4af9425df81d2f9891cfaed7fc8e5;hp=1f43ffbf7d7da90bfd496452b42697a1bfdf4b1a;hb=fa9808cd57e32f096495ad06689f7d23878f5217;hpb=c9edf58db4c00b7b95bb7f521063e5ecd79db262 diff --git a/src/kaka/cakelight/mode/VideoMode.java b/src/kaka/cakelight/mode/VideoMode.java index 1f43ffb..c7985e3 100644 --- a/src/kaka/cakelight/mode/VideoMode.java +++ b/src/kaka/cakelight/mode/VideoMode.java @@ -15,6 +15,7 @@ public class VideoMode extends Mode { private Thread grabberThread; private Consumer frameConsumer; private VideoDeviceListener deviceListener; + private boolean isPaused = false; public VideoMode() { deviceListener = new VideoDeviceListener(); @@ -29,15 +30,12 @@ public class VideoMode extends Mode { @Override public void pause() { - try { - grabberThread.wait(); - } catch (InterruptedException e) { - e.printStackTrace(); - } + isPaused = true; } @Override public void resume() { + isPaused = false; grabberThread.notify(); } @@ -54,11 +52,14 @@ public class VideoMode extends Mode { try (FrameGrabber grabber = FrameGrabber.from(videoDevice, config)) { while (!isInterrupted()) { Optional frame = grabber.grabFrame(); + if (isPaused) { + wait(); + } if (frameConsumer != null) frame.ifPresent(frameConsumer); frame.ifPresent(VideoMode.this::onVideoFrame); // timeIt("frame", grabber::grabFrame); } - } catch (IOException e) { + } catch (IOException | InterruptedException e) { e.printStackTrace(); } }