Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
Tetragramm
GitHub Repository: Tetragramm/opencv
Path: blob/master/modules/imgcodecs/src/grfmt_exr.hpp
16337 views
1
/*M///////////////////////////////////////////////////////////////////////////////////////
2
//
3
// IMPORTANT: READ BEFORE DOWNLOADING, COPYING, INSTALLING OR USING.
4
//
5
// By downloading, copying, installing or using the software you agree to this license.
6
// If you do not agree to this license, do not download, install,
7
// copy or use the software.
8
//
9
//
10
// License Agreement
11
// For Open Source Computer Vision Library
12
//
13
// Copyright (C) 2000-2008, Intel Corporation, all rights reserved.
14
// Copyright (C) 2009, Willow Garage Inc., all rights reserved.
15
// Third party copyrights are property of their respective owners.
16
//
17
// Redistribution and use in source and binary forms, with or without modification,
18
// are permitted provided that the following conditions are met:
19
//
20
// * Redistribution's of source code must retain the above copyright notice,
21
// this list of conditions and the following disclaimer.
22
//
23
// * Redistribution's in binary form must reproduce the above copyright notice,
24
// this list of conditions and the following disclaimer in the documentation
25
// and/or other materials provided with the distribution.
26
//
27
// * The name of the copyright holders may not be used to endorse or promote products
28
// derived from this software without specific prior written permission.
29
//
30
// This software is provided by the copyright holders and contributors "as is" and
31
// any express or implied warranties, including, but not limited to, the implied
32
// warranties of merchantability and fitness for a particular purpose are disclaimed.
33
// In no event shall the Intel Corporation or contributors be liable for any direct,
34
// indirect, incidental, special, exemplary, or consequential damages
35
// (including, but not limited to, procurement of substitute goods or services;
36
// loss of use, data, or profits; or business interruption) however caused
37
// and on any theory of liability, whether in contract, strict liability,
38
// or tort (including negligence or otherwise) arising in any way out of
39
// the use of this software, even if advised of the possibility of such damage.
40
//
41
//M*/
42
43
#ifndef _GRFMT_EXR_H_
44
#define _GRFMT_EXR_H_
45
46
#ifdef HAVE_OPENEXR
47
48
#if defined __GNUC__ && defined __APPLE__
49
# pragma GCC diagnostic ignored "-Wshadow"
50
#endif
51
52
#include <ImfChromaticities.h>
53
#include <ImfInputFile.h>
54
#include <ImfChannelList.h>
55
#include <ImathBox.h>
56
#include "grfmt_base.hpp"
57
58
namespace cv
59
{
60
61
using namespace Imf;
62
using namespace Imath;
63
64
/* libpng version only */
65
66
class ExrDecoder CV_FINAL : public BaseImageDecoder
67
{
68
public:
69
70
ExrDecoder();
71
~ExrDecoder() CV_OVERRIDE;
72
73
int type() const CV_OVERRIDE;
74
bool readData( Mat& img ) CV_OVERRIDE;
75
bool readHeader() CV_OVERRIDE;
76
void close();
77
78
ImageDecoder newDecoder() const CV_OVERRIDE;
79
80
protected:
81
void UpSample( uchar *data, int xstep, int ystep, int xsample, int ysample );
82
void UpSampleX( float *data, int xstep, int xsample );
83
void UpSampleY( uchar *data, int xstep, int ystep, int ysample );
84
void ChromaToBGR( float *data, int numlines, int step );
85
void RGBToGray( float *in, float *out );
86
87
InputFile *m_file;
88
Imf::PixelType m_type;
89
Box2i m_datawindow;
90
bool m_ischroma;
91
const Channel *m_red;
92
const Channel *m_green;
93
const Channel *m_blue;
94
Chromaticities m_chroma;
95
int m_bit_depth;
96
bool m_native_depth;
97
bool m_iscolor;
98
bool m_isfloat;
99
100
private:
101
ExrDecoder(const ExrDecoder &); // copy disabled
102
ExrDecoder& operator=(const ExrDecoder &); // assign disabled
103
};
104
105
106
class ExrEncoder CV_FINAL : public BaseImageEncoder
107
{
108
public:
109
ExrEncoder();
110
~ExrEncoder() CV_OVERRIDE;
111
112
bool isFormatSupported( int depth ) const CV_OVERRIDE;
113
bool write( const Mat& img, const std::vector<int>& params ) CV_OVERRIDE;
114
ImageEncoder newEncoder() const CV_OVERRIDE;
115
};
116
117
}
118
119
#endif
120
121
#endif/*_GRFMT_EXR_H_*/
122
123