JPGRecordingStrategy.h
Go to the documentation of this file.
1/*
2 * This file is part of ArmarX.
3 *
4 * ArmarX is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 as
6 * published by the Free Software Foundation.
7 *
8 * ArmarX is distributed in the hope that it will be useful, but
9 * WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 *
13 * You should have received a copy of the GNU General Public License
14 * along with this program. If not, see <http://www.gnu.org/licenses/>.
15 *
16 * @package visionx::imrec
17 * @author Christian R. G. Dreher <christian.dreher@student.kit.edu>
18 * @date 2018
19 * @copyright http://www.gnu.org/licenses/gpl-2.0.txt
20 * GNU General Public License
21 */
22
23
24#pragma once
25
26
27// STD/STL
28#include <filesystem>
29#include <string>
30
31// ArmarX
33
35
37{
38
39 /**
40 * Concrete strategy for a JPG image recording
41 */
43 {
44
45 protected:
46 unsigned int m_jpg_quality;
47
48 public:
50 JPGRecordingStrategy(const std::filesystem::path& filePath,
51 const std::string& name,
52 unsigned int jpg_quality = 95);
53 ~JPGRecordingStrategy() override;
54
55 void startRecording() override;
56 void recordFrame(const cv::Mat& frame, std::chrono::microseconds timestamp) override;
57 };
58
59} // namespace visionx::imrec::strats
std::string timestamp()
AbstractSequencedRecordingStrategy()
Default constructor to manually start the recording.
void startRecording() override
Starts the recording manually if constructed empty.
void recordFrame(const cv::Mat &frame, std::chrono::microseconds timestamp) override
Adds the given frame to the recording.