6#include "slideio/drivers/ome-tiff/ot_api_def.hpp"
7#include "slideio/core/cvscene.hpp"
8#include "slideio/drivers/ome-tiff/otscene.hpp"
9#include "slideio/imagetools/tifftools.hpp"
10#include "slideio/core/tools/tilecomposer.hpp"
11#include "slideio/drivers/ome-tiff/otstructs.hpp"
12#include "slideio/drivers/ome-tiff/tiffdata.hpp"
13#include "slideio/imagetools/tifffiles.hpp"
14#include "slideio/drivers/ome-tiff/otdimensions.hpp"
18#pragma warning( push )
19#pragma warning(disable: 4251)
28 class SLIDEIO_OMETIFF_EXPORTS OTScene :
public CVScene,
public Tiler
31 explicit OTScene(
const ImageData& filePath);
32 int getNumChannels()
const override;
33 cv::Rect getRect()
const override;
34 int findZoomLevel(
double zoom)
const;
36 int getTileCount(
void* userData)
override;
37 bool getTileRect(
int tileIndex, cv::Rect& tileRect,
void* userData)
override;
38 bool readTile(
int tileIndex,
const std::vector<int>& channelIndices, cv::OutputArray tileRaster,
39 void* userData)
override;
40 void initializeBlock(
const cv::Size& blockSize,
const std::vector<int>& channelIndices, cv::OutputArray output)
override;
41 std::string getChannelName(
int channel)
const override;
42 void readResampledBlockChannelsEx(
const cv::Rect& blockRect,
const cv::Size& blockSize,
43 const std::vector<int>& componentIndices,
int zSliceIndex,
int tFrameIndex,
44 cv::OutputArray output)
override;
45 std::string getFilePath()
const override;
46 std::string getName()
const override;
47 slideio::DataType getChannelDataType(
int channel)
const override;
48 Resolution getResolution()
const override;
49 double getMagnification()
const override;
51 int getNumZSlices()
const override;
52 int getNumTFrames()
const override;
53 int getNumTiffFiles()
const {
return m_files.getNumberOfOpenFiles(); }
54 int getNumTiffDataItems()
const {
return static_cast<int>(m_tiffData.size()); }
55 const TiffData& getTiffData(
int index)
const {
return m_tiffData[index]; }
56 double getZSliceResolution()
const override {
return m_zResolution; }
57 double getTFrameResolution()
const override {
return m_tResolution; }
59 void extractImagePyramids();
61 void initializeChannelAttributes(tinyxml2::XMLElement* pixels);
62 void extractMagnificationFromMetadata();
63 void extractTiffData(tinyxml2::XMLElement* pixels);
64 void extractImageIndex();
65 LevelInfo extractLevelInfo(
const TiffDirectory& dir,
int index)
const;
66 void collectTiffDataIndices(std::vector<int> channelIndices,
int zSliceIndex,
int tFrameIndex,
67 std::vector<int>& tiffDataIndices)
const;
69 int m_numChannels = 0;
70 std::vector<std::string> m_channelNames;
71 tinyxml2::XMLElement* m_imageXml;
72 std::shared_ptr<tinyxml2::XMLDocument> m_imageDoc;
73 std::string m_imageId;
74 std::vector<TiffData> m_tiffData;
75 std::string m_dimensionOrder;
76 DataType m_dataType = DataType::DT_Unknown;
80 bool m_bigEndian =
false;
81 std::string m_imageName;
82 std::string m_filePath;
84 Resolution m_resolution = {};
85 double m_magnification = 0;
86 int m_imageIndex = -1;
88 double m_zResolution = 0.0;
89 double m_tResolution = 0.0;
Definition: exceptions.hpp:15
Compression
raster data compression enum
Definition: slideio_enums.hpp:12