Files
pixelarium/lib/imaging/impl/PixelariumCzi.hpp
T

68 lines
1.9 KiB
C++
Raw Normal View History

2025-09-22 23:13:28 +02:00
#pragma once
2025-09-25 19:25:17 +02:00
#include <memory>
2025-09-22 23:13:28 +02:00
#include <string>
#include "../IPixelariumImage.hpp"
2025-09-26 21:09:51 +02:00
#include "utilities/ILog.hpp"
2025-09-25 19:25:17 +02:00
#include "libCZI.h"
2025-09-22 23:13:28 +02:00
namespace pixelarium::imaging
{
2025-09-26 21:09:51 +02:00
/// @brief An implementation of IImageQuery to work on CZI images.
/// @note Check the documentation here https://zeiss.github.io/libczi/pages/mainpage.html#czi-in-a-nutshell
2025-09-23 21:57:08 +02:00
struct CziParams : public IImageQuery
{
2025-09-26 21:09:51 +02:00
/// @brief A map providing the start coordinate for each dimension in the CZI
std::unordered_map<libCZI::DimensionIndex, int> dimension_map;
2025-09-23 21:57:08 +02:00
};
2025-09-26 21:09:51 +02:00
/// @brief Implements support for .czi-images in the realm of IPixelariumImage
2025-09-22 23:13:28 +02:00
class PixelariumCzi : public IPixelariumImage
{
2025-09-26 21:09:51 +02:00
using Log = pixelarium::utils::log::ILog;
2025-09-22 23:13:28 +02:00
public:
2025-09-26 21:09:51 +02:00
explicit PixelariumCzi(const std::string& uri, const Log& log);
2025-09-25 19:25:17 +02:00
~PixelariumCzi()
{
if (this->czi_reader_)
this->czi_reader_->Close();
}
2025-09-22 23:13:28 +02:00
// IPixelariumImage member implementations
public:
2025-09-23 21:57:08 +02:00
std::unique_ptr<cv::Mat> TryGetImage() override;
2025-09-22 23:13:28 +02:00
2025-09-26 21:09:51 +02:00
std::unique_ptr<cv::Mat> TryGetImage(const IImageQuery&) override;
2025-09-22 23:13:28 +02:00
2025-09-23 21:57:08 +02:00
std::vector<std::unique_ptr<cv::Mat>> TryGetImages(const IImageQuery&) override
2025-09-22 23:13:28 +02:00
{
2025-09-23 21:57:08 +02:00
// ToDo: proper error
throw std::runtime_error("Not implemented.");
2025-09-22 23:13:28 +02:00
}
bool Empty() const noexcept override { return this->is_empty_; }
2025-09-25 19:25:17 +02:00
const libCZI::SubBlockStatistics& GetStatistics() const { return this->image_statistics_; }
2025-09-22 23:13:28 +02:00
public:
const static ImageFileType type_{ImageFileType::CZI};
2025-09-26 21:09:51 +02:00
private:
std::unique_ptr<cv::Mat> SubblockToCvMat(int index);
2025-09-22 23:13:28 +02:00
private:
// this should be set by each image getter
// after a new cv::Mat could be instantiated
bool is_empty_{true};
2025-09-25 19:25:17 +02:00
libCZI::SubBlockStatistics image_statistics_;
std::shared_ptr<libCZI::ICZIReader> czi_reader_;
2025-09-26 21:09:51 +02:00
std::unordered_map<libCZI::DimensionIndex, int> dimension_map_;
const Log& log_;
2025-09-22 23:13:28 +02:00
};
} // namespace pixelarium::imaging