SlideIO 2.0.0
Open-source library for reading of medical images
Loading...
Searching...
No Matches
ndpitifftools.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_ndpitifftools_HPP
5#define OPENCV_slideio_ndpitifftools_HPP
6
7
8#include "slideio/drivers/ndpi/ndpi_api_def.hpp"
9#include "slideio/base/resolution.hpp"
10#include "slideio/base/slideio_enums.hpp"
11#include "slideio/base/base.hpp"
12#include <opencv2/core.hpp>
13#include <string>
14#include <vector>
15
16namespace libtiff
17{
18 struct tiff;
19 typedef tiff TIFF;
20}
21
22#if defined(_MSC_VER)
23#pragma warning( push )
24#pragma warning(disable: 4251)
25#endif
26
27namespace slideio
28{
29 class NDPIFile;
30
31 struct SLIDEIO_NDPI_EXPORTS NDPITiffDirectory
32 {
33 enum class Type
34 {
35 Tiled = 0,
36 SingleStripe = 1,
37 SingleStripeMCU = 2,
38 Striped = 3
39 };
40 int width;
41 int height;
42 bool tiled;
43 int tileWidth;
44 int tileHeight;
45 int channels;
46 int bitsPerSample;
47 int photometric;
48 int YCbCrSubsampling[2];
49 uint32_t compression;
50 Compression slideioCompression;
51 int dirIndex;
52 int64 offset;
53 std::string description;
54 std::string userLabel;
55 std::string comments;
56 std::vector<NDPITiffDirectory> subdirectories;
57 Resolution res;
58 cv::Point2d position;
59 bool interleaved;
60 int rowsPerStrip;
61 DataType dataType;
62 int stripSize;
63 double magnification;
64 uint32_t blankLines;
65 std::vector<uint64_t> mcuStarts;
66 uint64_t jpegHeaderOffset;
67 uint64_t jpegSOFMarker;
68 uint32_t jpegHeaderSize;
69 uint32_t rawStripSize = 0;
70 bool auxImage = false;
71
72 Type getType() const {
73 if(tiled) {
74 return Type::Tiled;
75 }
76 else if(tileWidth > 0 && tileHeight > 0 && !mcuStarts.empty() && slideioCompression == Compression::Jpeg) {
77 return Type::SingleStripeMCU;
78 }
79 else if(rowsPerStrip == height) {
80 return Type::SingleStripe;
81 }
82 else {
83 return Type::Striped;
84 }
85 }
86 };
87
88 SLIDEIO_NDPI_EXPORTS std::ostream& operator << (std::ostream& os, const NDPITiffDirectory::Type& type);
89
90 class SLIDEIO_NDPI_EXPORTS NDPITiffTools
91 {
92 public:
93 static libtiff::TIFF* openTiffFile(const std::string& path);
94 static void closeTiffFile(libtiff::TIFF* file);
95 static cv::Size computeMCUTileSize(FILE* file, const cv::Size& dirSize);
96 static std::pair<uint64_t, uint64_t> getJpegHeaderPos(FILE* file);
97 static void readMCUTile(FILE* file, const NDPITiffDirectory& dir, int tile, cv::OutputArray output);
98 static void jpeglibDecodeTile(const uint8_t* jpg_buffer, size_t jpg_size, const cv::Size& tileSize, cv::OutputArray output);
99 static void scanTiffDirTags(libtiff::TIFF* tiff, int dirIndex, int64_t dirOffset, slideio::NDPITiffDirectory& dir);
100 static void updateJpegXRCompressedDirectoryMedatata(libtiff::TIFF* tiff, NDPITiffDirectory& dir);
101 static void scanTiffDir(libtiff::TIFF* tiff, int dirIndex, int64_t dirOffset, slideio::NDPITiffDirectory& dir);
102 static void readNotRGBStripedDir(libtiff::TIFF* tiff, const NDPITiffDirectory& dir, cv::_OutputArray output);
103 static void readRegularStripedDir(libtiff::TIFF* file, const slideio::NDPITiffDirectory& dir, cv::OutputArray output);
104 static void readJpegXRStripedDir(libtiff::TIFF* tiff, const NDPITiffDirectory& dir, cv::_OutputArray output);
105 static void readStripedDir(libtiff::TIFF* file, const slideio::NDPITiffDirectory& dir, cv::OutputArray output);
106 static void readJpegXRTile(libtiff::TIFF* tiff, const slideio::NDPITiffDirectory& dir, int tile, const std::vector<int>& vector, cv::OutputArray output);
107 static void readTile(libtiff::TIFF* hFile, const slideio::NDPITiffDirectory& dir, int tile,
108 const std::vector<int>& channelIndices, cv::OutputArray output);
109 static void readJpegXRStrip(libtiff::TIFF* tiff, const NDPITiffDirectory& dir, int strip, const std::vector<int>& vector, cv::_OutputArray output);
110 static void readNotRGBStrip(libtiff::TIFF* tiff, const NDPITiffDirectory& dir, int strip, const std::vector<int>& vector, cv::_OutputArray output);
111 static void readRegularStrip(libtiff::TIFF* tiff, const NDPITiffDirectory& dir, int strip, const std::vector<int>& vector, cv::_OutputArray output);
112 static void readStripe(libtiff::TIFF* hFile, const slideio::NDPITiffDirectory& dir, int strip,
113 const std::vector<int>& channelIndices, cv::OutputArray output);
114 static void setCurrentDirectory(libtiff::TIFF* hFile, const slideio::NDPITiffDirectory& dir);
115 static void decodeJxrBlock(const uint8_t* data, size_t dataBlockSize, cv::OutputArray output);
116 static void readRegularTile(libtiff::TIFF* hFile, const slideio::NDPITiffDirectory& dir, int tile,
117 const std::vector<int>& channelIndices, cv::OutputArray output);
118 static void readNotRGBTile(libtiff::TIFF* hFile, const slideio::NDPITiffDirectory& dir, int tile,
119 const std::vector<int>& channelIndices, cv::OutputArray output);
120 static int computeStripHeight(int height, int rowsPerStrip, int strip);
121 static cv::Size computeTileSize(const NDPITiffDirectory& dir, int tile);
122 static cv::Size computeTileCounts(const NDPITiffDirectory& dir);
123 static void readJpegScanlines(libtiff::TIFF* tiff, FILE* file, const NDPITiffDirectory& dir, int firstScanline,
124 int numberScanlines, const std::vector<int>& channelIndices, cv::_OutputArray output);
125 static void readJpegDirectoryRegion(libtiff::TIFF* tiff, const std::string& filePath, const cv::Rect& region, const NDPITiffDirectory& dir,
126 const std::vector<int>& channelIndices, cv::_OutputArray output);
127 static void readDirectoryJpegHeaders(NDPIFile* ndpi, NDPITiffDirectory& dir);
128 static void readUncompressedScanlines(libtiff::TIFF* tiff, FILE* file, const NDPITiffDirectory& dir, int firstScanline, int numberScanlines, const std::vector<int>& vector,
129 cv::_OutputArray tileRaster);
130 private:
131 static void fixJpegHeader(const NDPITiffDirectory& dir, uint8_t* data);
132 };
133
134 class NDPITIFFKeeper
135 {
136 public:
137 NDPITIFFKeeper(libtiff::TIFF* hfile=nullptr);
138 ~NDPITIFFKeeper();
139 libtiff::TIFF* getHandle() const{
140 return m_hFile;
141 }
142 bool isValid() const{
143 return getHandle() != nullptr;
144 }
145 operator libtiff::TIFF* () const {
146 return getHandle();
147 }
148 NDPITIFFKeeper& operator = (libtiff::TIFF* hFile){
149 m_hFile = hFile;
150 return *this;
151 }
152
153 private:
154 libtiff::TIFF* m_hFile;
155 };
156}
157
158#if defined(_MSC_VER)
159#pragma warning( pop )
160#endif
161
162#endif
Definition: exceptions.hpp:15
Compression
raster data compression enum
Definition: slideio_enums.hpp:12