SlideIO 2.0.0
Open-source library for reading of medical images
Loading...
Searching...
No Matches
otscene.hpp
1// This file is part of slideio project.
2// It is subject to the license terms in the LICENSE file found in the top-level directory
3// of this distribution and at http://slideio.com/license.html.
4#pragma once
5
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"
15#include <tinyxml2.h>
16
17#if defined(_MSC_VER)
18#pragma warning( push )
19#pragma warning(disable: 4251)
20#endif
21
22namespace slideio
23{
24 namespace ometiff
25 {
26 struct ImageData;
27
28 class SLIDEIO_OMETIFF_EXPORTS OTScene : public CVScene, public Tiler
29 {
30 public:
31 explicit OTScene(const ImageData& filePath);
32 int getNumChannels() const override;
33 cv::Rect getRect() const override;
34 int findZoomLevel(double zoom) const;
35 // Tiler methods
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;
50 Compression getCompression() 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; }
58 private:
59 void extractImagePyramids();
60 void initialize();
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;
68 private:
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;
77 int m_numZSlices = 0;
78 int m_numTFrames = 0;
79 cv::Size m_imageSize;
80 bool m_bigEndian = false;
81 std::string m_imageName;
82 std::string m_filePath;
83 Compression m_compression = Compression::Unknown;
84 Resolution m_resolution = {};
85 double m_magnification = 0;
86 int m_imageIndex = -1;
87 TIFFFiles m_files;
88 double m_zResolution = 0.0;
89 double m_tResolution = 0.0;
90 };
91 }
92}
93
94#if defined(_MSC_VER)
95#pragma warning( pop )
96#endif
Definition: exceptions.hpp:15
Compression
raster data compression enum
Definition: slideio_enums.hpp:12