/* * Copyright (C) 2018 dimercur * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #ifndef __CAMERA_H__ #define __CAMERA_H__ #include #include #ifndef __FOR_PC__ #include "raspicam/raspicam_cv.h" #endif /* __FOR_PC__ */ #include "img.h" /** * Enumerate for picture size */ enum captureSize {xs, sm, md, lg}; /** * Class for camera (image grab) * * @brief Class for camera (image grab) * How to grab an image and send it to the monitor: * 1. Grab an image, for example: * Img * img = new Img(cam->Grab()); * 2. Instanciate the message to send the image: * MessageImg *msgImg = new MessageImg(MESSAGE_CAM_IMAGE, img); */ class Camera { public: Camera(); /** * Create an object for accessing camera * @param size Size of picture to grab (@see captureSize) * @param fps speed of sampling */ Camera(int size, int fps); /** * Open camera * @return True if camera is open, false otherwise */ bool Open(); /** * Close and release camera */ void Close(); /** * Get width of sampled image * @return Width of sampled picture */ int GetWidth() const; /** * Get height of sampled image * @return height of sampled picture */ int GetHeight() const; /** * Get opening status for camera * @return true if camera is open, false otherwise */ bool IsOpen(); /** * Define size for sampled picture * @param size Size of picture (@see captureSize) */ void SetSize(int size); /** * Grab next image from camera * @return Image taken from camera */ Img Grab(); private: #ifdef __FOR_PC__ /** * Camera descriptor */ cv::VideoCapture cap; #else raspicam::RaspiCam_Cv cap; #endif /* __FOR_PC__ */ /** * Size for image (default= small) */ int size = sm; /** * Width of image */ int width; /** * Height of image */ int height; }; #endif //__CAMERA_H__