b37814204f
* get image returns optional<Mat> instead of unique_ptr<Mat> * introduce complexity * rename image load function * add example for a basic reader for binary image files * fix windows build? * add a status bar underneath the menu bar * use status bar in custom_0 example app * clang formats * packing w/ pragma push * add "Save As" functions to image views * resize over reserve * rm local override uri * add simple thread pool * rename to simple_thread_pool * get rid of useless renderlib * document version inc * extract hardcoded values to in-header * clang format patch * clone registered image in custom_0 * document binary-file header * minor fixes * clang format * rm unused render cmake
152 lines
5.5 KiB
C++
152 lines
5.5 KiB
C++
#pragma once
|
|
|
|
#include <filesystem>
|
|
#include <functional>
|
|
#include <opencv2/core/mat.hpp>
|
|
#include <string>
|
|
|
|
namespace pixelarium::imaging
|
|
{
|
|
using ImageQueryFunctor = std::function<void(const std::string&, void*, int*)>;
|
|
|
|
/// @brief Enumeration of supported image file types.
|
|
enum class ImageFileType
|
|
{
|
|
/// @brief Represents an unknown or unsupported file type.
|
|
kUnknown = -10,
|
|
/// @brief Represents an abstract image type (e.g., a placeholder).
|
|
kAbstract = 0,
|
|
/// @brief Represents a PNG image file.
|
|
kPng = 1,
|
|
/// @brief Represents a JPG image file.
|
|
kJpg = 2,
|
|
/// @brief Represents a CZI image file.
|
|
kCzi = 3,
|
|
/// @brief Represents a TIFF image file.
|
|
kTiff = 4,
|
|
/// @brief Represents an in-memory image.
|
|
kMemory = 5,
|
|
};
|
|
|
|
/// @brief An abstract interface to define a semantic query
|
|
/// for a multi-dimensional image.
|
|
struct IImageQuery
|
|
{
|
|
virtual ~IImageQuery() = default;
|
|
};
|
|
|
|
/// @brief This aims to be a generic image abstraction
|
|
/// meant for codec specific implementation.
|
|
template <class Data>
|
|
class IPixelariumImage
|
|
{
|
|
public:
|
|
virtual ~IPixelariumImage() = default;
|
|
|
|
/// @brief Attempts to retrieve the image.
|
|
/// @return A unique pointer to a Mat object containing the image data,
|
|
/// or nullptr if the image is not found or cannot be retrieved.
|
|
/// May throw exceptions for multidimensional images.
|
|
virtual std::optional<Data> TryGetImage() = 0;
|
|
|
|
/// @brief Attempts to retrieve the image.
|
|
/// @param query The query object defining the images to retrieve.
|
|
/// @return A unique pointer to a Mat object containing the image data,
|
|
/// or nullptr if the image is not found or cannot be retrieved.
|
|
virtual std::optional<Data> TryGetImage(const IImageQuery& query) = 0;
|
|
|
|
/// @brief Attempts to retrieve a collection of images based on a query.
|
|
/// @param query The query object defining the images to retrieve.
|
|
/// @return A vector of unique pointers to cv::Mat objects. Each element is an image.
|
|
/// Returns an empty vector if no images are found or if an error occurs.
|
|
virtual std::vector<std::optional<Data>> TryGetImages(const IImageQuery& query) = 0;
|
|
|
|
/// @brief Checks if the image is empty.
|
|
/// @return true if the image is empty, false otherwise.
|
|
virtual bool Empty() const noexcept = 0;
|
|
|
|
// default implemented
|
|
public:
|
|
/// @brief Gets the resource identifier as a file path.
|
|
/// @return @c std::filesystem::path of the underlying resource.
|
|
virtual std::filesystem::path Uri() const noexcept { return this->uri_; }
|
|
|
|
/// @brief Gets the resource name.
|
|
/// @note Implementations of IPixelariumImage that live in memory
|
|
/// should override this to get something meaningful as the name
|
|
/// cannot be fetched from the resource uri in that case.
|
|
/// @return The name of the underlying resource.
|
|
virtual std::string Name() const noexcept
|
|
{
|
|
if (!this->uri_.empty())
|
|
{
|
|
return this->uri_.filename().string();
|
|
}
|
|
|
|
return {};
|
|
}
|
|
|
|
public:
|
|
const static ImageFileType type_{ImageFileType::kAbstract};
|
|
|
|
protected:
|
|
std::filesystem::path uri_;
|
|
};
|
|
|
|
class IPixelariumImageCvMat : public IPixelariumImage<cv::Mat>
|
|
{
|
|
public:
|
|
virtual ~IPixelariumImageCvMat() = default;
|
|
|
|
/// @brief Attempts to retrieve the image.
|
|
/// @return A unique pointer to a Mat object containing the image data,
|
|
/// or nullptr if the image is not found or cannot be retrieved.
|
|
/// May throw exceptions for multidimensional images.
|
|
virtual std::optional<cv::Mat> TryGetImage() = 0;
|
|
|
|
/// @brief Attempts to retrieve the image.
|
|
/// @param query The query object defining the images to retrieve.
|
|
/// @return A unique pointer to a Mat object containing the image data,
|
|
/// or nullptr if the image is not found or cannot be retrieved.
|
|
virtual std::optional<cv::Mat> TryGetImage(const IImageQuery& query) = 0;
|
|
|
|
/// @brief Attempts to retrieve a collection of images based on a query.
|
|
/// @param query The query object defining the images to retrieve.
|
|
/// @return A vector of unique pointers to cv::Mat objects. Each element is an image.
|
|
/// Returns an empty vector if no images are found or if an error occurs.
|
|
virtual std::vector<std::optional<cv::Mat>> TryGetImages(const IImageQuery& query) = 0;
|
|
|
|
/// @brief Checks if the image is empty.
|
|
/// @return true if the image is empty, false otherwise.
|
|
virtual bool Empty() const noexcept = 0;
|
|
|
|
/// @brief Saves an image to the resource identifier given by uri.
|
|
/// @return true if saving was successful, false otherwise.
|
|
virtual bool SaveImage(const std::string& uri);
|
|
|
|
// default implemented
|
|
public:
|
|
/// @brief Gets the resource identifier as a file path.
|
|
/// @return @c std::filesystem::path of the underlying resource.
|
|
virtual std::filesystem::path Uri() const noexcept { return this->uri_; }
|
|
|
|
/// @brief Gets the resource name.
|
|
/// @note Implementations of IPixelariumImage that live in memory
|
|
/// should override this to get something meaningful as the name
|
|
/// cannot be fetched from the resource uri in that case.
|
|
/// @return The name of the underlying resource.
|
|
virtual std::string Name() const noexcept
|
|
{
|
|
if (!this->uri_.empty())
|
|
{
|
|
return this->uri_.filename().string();
|
|
}
|
|
|
|
return {};
|
|
}
|
|
|
|
public:
|
|
const static ImageFileType type_{ImageFileType::kAbstract};
|
|
};
|
|
} // namespace pixelarium::imaging
|