blob: 62661c60e7caedd99f20f4328d98c2bf3c6287b7 [file] [log] [blame]
Parker Schuh58b39e82019-02-22 22:32:46 -08001#ifndef _AOS_VISION_IMAGE_IMAGE_STREAM_H_
2#define _AOS_VISION_IMAGE_IMAGE_STREAM_H_
3
4#include "aos/vision/events/epoll_events.h"
5#include "aos/vision/image/camera_params.pb.h"
6#include "y2019/jevois/camera/reader.h"
7
8#include <memory>
9
10namespace y2019 {
11namespace camera {
12
13// Converts a camera reader into a virtual base class that calls ProcessImage
14// on each new image.
15class ImageStreamEvent : public ::aos::events::EpollEvent {
16 public:
17 static std::unique_ptr<Reader> GetCamera(const std::string &fname,
18 ImageStreamEvent *obj,
19 aos::vision::CameraParams params) {
20 using namespace std::placeholders;
21 std::unique_ptr<Reader> camread(new Reader(
22 fname, std::bind(&ImageStreamEvent::ProcessHelper, obj, _1, _2),
23 params));
24 camread->StartAsync();
25 return camread;
26 }
27
28 explicit ImageStreamEvent(std::unique_ptr<Reader> reader)
29 : ::aos::events::EpollEvent(reader->fd()), reader_(std::move(reader)) {}
30
31 explicit ImageStreamEvent(const std::string &fname,
32 aos::vision::CameraParams params)
33 : ImageStreamEvent(GetCamera(fname, this, params)) {}
34
35 void ProcessHelper(aos::vision::DataRef data,
36 aos::monotonic_clock::time_point timestamp) {
37 if (data.size() < 300) {
38 LOG(INFO, "got bad img of size(%d)\n", static_cast<int>(data.size()));
39 return;
40 }
41 ProcessImage(data, timestamp);
42 }
43 virtual void ProcessImage(aos::vision::DataRef data,
44 aos::monotonic_clock::time_point timestamp) = 0;
45
46 void ReadEvent() override { reader_->HandleFrame(); }
47
48 private:
49 std::unique_ptr<Reader> reader_;
50};
51
52} // namespace vision
53} // namespace aos
54
55#endif // _AOS_VISION_DEBUG_IMAGE_STREAM_H_