Enhance image type support (#18)

* adds tiff support

* doc update

* adds memory-based =IPixelariumImage= implementation

* add usage example for custom user control

* enhance

* clang-format

fix readme

fix docs
This commit is contained in:
m-aXimilian
2025-10-12 21:47:17 +02:00
committed by Maximilian Kueffner
parent 356f966d01
commit e3e161ce52
16 changed files with 385 additions and 15 deletions
+47
View File
@@ -0,0 +1,47 @@
#pragma once
#include <stdexcept>
#include <string>
#include "../IPixelariumImage.hpp"
#include "utilities/ILog.hpp"
namespace pixelarium::imaging
{
/// @brief Implements support for in-memory images in the realm of IPixelariumImage
class PixelariumMem : public IPixelariumImage
{
using Log = pixelarium::utils::log::ILog;
public:
explicit PixelariumMem(const cv::Mat& img, const std::string& name, const Log& log);
// IPixelariumImage member implementations
public:
std::unique_ptr<cv::Mat> TryGetImage() override;
std::unique_ptr<cv::Mat> TryGetImage(const IImageQuery&) override { throw std::runtime_error("Not implemented."); }
std::vector<std::unique_ptr<cv::Mat>> TryGetImages(const IImageQuery&) override
{
throw std::runtime_error("Not implemented.");
}
void SetImage(const cv::Mat& img) { this->img_ = img; }
std::string Name() const noexcept override { return this->name_; }
bool Empty() const noexcept override { return this->is_empty_; }
public:
const static ImageFileType type_{ImageFileType::kMemory};
private:
// this should be set by each image getter
// after a new cv::Mat could be instantiated
bool is_empty_{true};
cv::Mat img_;
const Log& log_;
std::string name_;
};
} // namespace pixelarium::imaging