SlideIO 2.0.0
Open-source library for reading of medical images
Loading...
Searching...
No Matches
cvscene.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#ifndef OPENCV_slideio_scene_HPP
5#define OPENCV_slideio_scene_HPP
6
7#include "slideio/core/slideio_core_def.hpp"
8#include "slideio/base/resolution.hpp"
9#include "slideio/base/slideio_enums.hpp"
10#include <opencv2/core.hpp>
11#include <vector>
12#include <string>
13#include <list>
14#include "refcounter.hpp"
15#include <mutex>
16
17#include "levelinfo.hpp"
18
19#if defined(_MSC_VER)
20#pragma warning( push )
21#pragma warning(disable: 4251)
22#endif
23
24namespace slideio
25{
36 class SLIDEIO_CORE_EXPORTS CVScene : public RefCounter
37 {
38 public:
40 virtual ~CVScene() = default;
42 virtual std::string getFilePath() const = 0;
44 virtual std::string getName() const = 0;
48 virtual cv::Rect getRect() const = 0;
50 virtual int getNumChannels() const = 0;
55 virtual int getNumZSlices() const {return 1;}
60 virtual int getNumTFrames() const {return 1;}
65 virtual slideio::DataType getChannelDataType(int channel) const = 0;
71 virtual std::string getChannelName(int channel) const;
76 virtual Resolution getResolution() const = 0;
78 virtual double getZSliceResolution() const {return 0;}
80 virtual double getTFrameResolution() const {return 0;}
82 virtual double getMagnification() const = 0;
84 virtual Compression getCompression() const = 0;
93 virtual void readBlock(const cv::Rect& blockRect, cv::OutputArray output);
103 virtual void readBlockChannels(const cv::Rect& blockRect, const std::vector<int>& channelIndices, cv::OutputArray output);
114 virtual void readResampledBlock(const cv::Rect& blockRect, const cv::Size& blockSize, cv::OutputArray output);
126 virtual void readResampledBlockChannels(const cv::Rect& blockRect, const cv::Size& blockSize, const std::vector<int>& channelIndices, cv::OutputArray output);
138 virtual void read4DBlock(const cv::Rect& blockRect, const cv::Range& zSliceRange, const cv::Range& timeFrameRange, cv::OutputArray output);
151 virtual void read4DBlockChannels(const cv::Rect& blockRect, const std::vector<int>& channelIndices, const cv::Range& zSliceRange, const cv::Range& timeFrameRange, cv::OutputArray output);
164 virtual void readResampled4DBlock(const cv::Rect& blockRect, const cv::Size& blockSize, const cv::Range& zSliceRange, const cv::Range& timeFrameRange, cv::OutputArray output);
178 virtual void readResampled4DBlockChannels(const cv::Rect& blockRect, const cv::Size& blockSize, const std::vector<int>& channelIndices, const cv::Range& zSliceRange, const cv::Range& timeFrameRange, cv::OutputArray output);
180 virtual const std::list<std::string>& getAuxImageNames() const {
181 return m_auxNames;
182 }
184 virtual int getNumAuxImages() const {
185 return static_cast<int>(m_auxNames.size());
186 }
190 virtual std::shared_ptr<CVScene> getAuxImage(const std::string& imageName) const;
192 virtual std::string getRawMetadata() const { return m_rawMetadata; }
193 virtual void readResampledBlockChannelsEx(const cv::Rect& blockRect, const cv::Size& blockSize,
194 const std::vector<int>& componentIndices, int zSliceIndex, int tFrameIndex, cv::OutputArray output) = 0;
195 virtual int getNumZoomLevels() const;
196 virtual const LevelInfo* getZoomLevelInfo(int level) const;
197 std::string toString() const;
199 virtual MetadataFormat getMetadataFormat() const { return m_metadataFormat; }
201 virtual int defineChannelAttribute(const std::string& attributeName);
203 virtual int getChannelAttributeIndex(const std::string& attributeName) const;
205 virtual void setChannelAttribute(int channelIndex, const std::string& attributeName, const std::string& attributeValues);
207 virtual std::string getChannelAttributeValue(int channelIndex, const std::string& attributeName) const;
209 virtual const std::string& getChannelAttributeValue(int channelIndex, int attributeIndex) const;
211 virtual const std::string& getChannelAttributeName(int index) const;
213 virtual int getNumChannelAttributes() const {
214 return static_cast<int>(m_channelAttributeNames.size());
215 }
216 protected:
217 std::vector<int> getValidChannelIndices(const std::vector<int>& channelIndices);
218 void initializeSceneBlock(const cv::Size& blockSize, const std::vector<int>& channelIndices,
219 cv::OutputArray output) const;
220
221 protected:
222 std::list<std::string> m_auxNames;
223 std::vector<LevelInfo> m_levels;
224 mutable std::mutex m_readBlockMutex;
225 std::string m_rawMetadata;
226 MetadataFormat m_metadataFormat = MetadataFormat::None;
227 std::vector<std::string> m_channelAttributeNames;
228 std::vector<std::vector<std::string>> m_channelAttributes;
229 };
230}
231
232#define CVScenePtr std::shared_ptr<slideio::CVScene>
233
234#if defined(_MSC_VER)
235#pragma warning( pop )
236#endif
237
238#endif
class CVScene represents a base class for opencv based representations of raster images contained in ...
Definition: cvscene.hpp:37
virtual Compression getCompression() const =0
returns compression of the raster data
virtual MetadataFormat getMetadataFormat() const
returns metadata format of the image
Definition: cvscene.hpp:199
virtual slideio::DataType getChannelDataType(int channel) const =0
returns channel data type.
virtual const std::list< std::string > & getAuxImageNames() const
returns list of auxiliary image names.
Definition: cvscene.hpp:180
virtual double getMagnification() const =0
returns slide magnification extracted from the slide metadata.
virtual std::string getName() const =0
returns scene name
virtual int getNumChannels() const =0
returns number of image channels.
virtual int getNumChannelAttributes() const
returns number ofchannel attributes
Definition: cvscene.hpp:213
virtual int getNumTFrames() const
returns number of time frames in the image.
Definition: cvscene.hpp:60
virtual cv::Rect getRect() const =0
returns image rectangle.
virtual std::string getRawMetadata() const
returns string of serialized metadata. Content of the string depends on image format.
Definition: cvscene.hpp:192
virtual std::string getFilePath() const =0
returns path of the slide
virtual ~CVScene()=default
default constructor
virtual int getNumAuxImages() const
returns number of auxiliary images in the scene object.
Definition: cvscene.hpp:184
virtual Resolution getResolution() const =0
returns image resolution in x and y direction.
virtual double getZSliceResolution() const
returns thickness of a Z slice in meters for 3D images.
Definition: cvscene.hpp:78
virtual double getTFrameResolution() const
returns time between 2 time frames in seconds for images with time frames.
Definition: cvscene.hpp:80
virtual int getNumZSlices() const
returns number of z-slices in the images.
Definition: cvscene.hpp:55
Definition: exceptions.hpp:15
Compression
raster data compression enum
Definition: slideio_enums.hpp:12