X-Git-Url: http://dolda2000.com/gitweb/?p=kaka%2Fcakelight.git;a=blobdiff_plain;f=src%2Fkaka%2Fcakelight%2FFrameGrabber.java;h=8fbb16f55f7f9f7393ad506d92f74aa352532858;hp=d228b7bc189faa2f17859f12c6f226e13cb4d470;hb=4a2d60564647052562fad28644904298ba83667b;hpb=e59e98fcf77a104e31dd97641b0ceea6d0a79e00 diff --git a/src/kaka/cakelight/FrameGrabber.java b/src/kaka/cakelight/FrameGrabber.java index d228b7b..8fbb16f 100644 --- a/src/kaka/cakelight/FrameGrabber.java +++ b/src/kaka/cakelight/FrameGrabber.java @@ -1,8 +1,11 @@ package kaka.cakelight; import java.io.*; +import java.util.Optional; -public class FrameGrabber { +import static kaka.cakelight.Main.log; + +public class FrameGrabber implements Closeable { private Configuration config; private File file; private int bytesPerFrame; @@ -16,10 +19,11 @@ public class FrameGrabber { fg.config = config; fg.file = new File(config.video.device); fg.bytesPerFrame = config.video.width * config.video.height * config.video.bpp; + fg.prepare(); return fg; } - public boolean prepare() { + private boolean prepare() { try { fileStream = new FileInputStream(file); return true; @@ -29,24 +33,24 @@ public class FrameGrabber { } } - public Frame grabFrame() { + /** + * Must be run in the same thread as {@link #prepare}. + */ + public Optional grabFrame() { try { byte[] data = new byte[bytesPerFrame]; int count = fileStream.read(data); - System.out.println("count = " + count); - return Frame.of(data, config); + log("# of bytes read = " + count); + return Optional.of(Frame.of(data, config)); } catch (IOException e) { e.printStackTrace(); } - return null; + return Optional.empty(); } - public void close() { - try { - fileStream.close(); - } catch (IOException e) { - e.printStackTrace(); - } + @Override + public void close() throws IOException { + fileStream.close(); } }