BMPRecordingStrategy.cpp
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
25
26
27// IVT
28#include <Image/ByteImage.h>
29
34
36 const std::filesystem::path& filePath,
37 const std::string& name) :
38 visionx::imrec::AbstractSequencedRecordingStrategy(filePath / name, ".bmp")
39{
40 // pass
41}
42
47
48void
50 const std::chrono::microseconds timestamp)
51{
52 const auto& [sequence_number, frame_name] = writeMetadataFrame(frame, timestamp);
53 const std::filesystem::path path = deriveFramePath(sequence_number, frame_name);
54 frame.SaveToFile(path.c_str());
55}
std::string timestamp()
virtual std::tuple< unsigned int, std::string > writeMetadataFrame(const CByteImage &frame, std::chrono::microseconds timestamp)
AbstractSequencedRecordingStrategy()
Default constructor to manually start the recording.
std::filesystem::path deriveFramePath(const unsigned int sequence_number, const std::string &frame_name)
Returns the next sequenced full path and increments the sequence number.
void recordFrame(const CByteImage &frame, std::chrono::microseconds timestamp) override
Adds the given frame to the recording.
ArmarX headers.