Coverage Report

Created: 2026-03-31 07:13

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/work/install-coverage/include/opencv4/opencv2/imgcodecs.hpp
Line
Count
Source
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 OPENCV_IMGCODECS_HPP
44
#define OPENCV_IMGCODECS_HPP
45
46
#include "opencv2/core.hpp"
47
48
/**
49
  @defgroup imgcodecs Image file reading and writing
50
  @{
51
    @defgroup imgcodecs_flags Flags used for image file reading and writing
52
    @defgroup imgcodecs_ios iOS glue
53
    @defgroup imgcodecs_macosx MacOS(OSX) glue
54
  @}
55
*/
56
57
//////////////////////////////// image codec ////////////////////////////////
58
namespace cv
59
{
60
61
//! @addtogroup imgcodecs
62
//! @{
63
64
//! @addtogroup imgcodecs_flags
65
//! @{
66
67
//! Imread flags
68
//! @note IMREAD_COLOR_BGR (IMREAD_COLOR) and IMREAD_COLOR_RGB can not be set at the same time.
69
enum ImreadModes {
70
       IMREAD_UNCHANGED            = -1, //!< If set, return the loaded image as is (with alpha channel, otherwise it gets cropped). Ignore EXIF orientation.
71
       IMREAD_GRAYSCALE            = 0,  //!< If set, always convert image to the single channel grayscale image (codec internal conversion).
72
       IMREAD_COLOR_BGR            = 1,  //!< If set, always convert image to the 3 channel BGR color image.
73
       IMREAD_COLOR                = 1,  //!< Same as IMREAD_COLOR_BGR.
74
       IMREAD_ANYDEPTH             = 2,  //!< If set, return 16-bit/32-bit image when the input has the corresponding depth, otherwise convert it to 8-bit.
75
       IMREAD_ANYCOLOR             = 4,  //!< If set, the image is read in any possible color format.
76
       IMREAD_LOAD_GDAL            = 8,  //!< If set, use the gdal driver for loading the image.
77
       IMREAD_REDUCED_GRAYSCALE_2  = 16, //!< If set, always convert image to the single channel grayscale image and the image size reduced 1/2.
78
       IMREAD_REDUCED_COLOR_2      = 17, //!< If set, always convert image to the 3 channel BGR color image and the image size reduced 1/2.
79
       IMREAD_REDUCED_GRAYSCALE_4  = 32, //!< If set, always convert image to the single channel grayscale image and the image size reduced 1/4.
80
       IMREAD_REDUCED_COLOR_4      = 33, //!< If set, always convert image to the 3 channel BGR color image and the image size reduced 1/4.
81
       IMREAD_REDUCED_GRAYSCALE_8  = 64, //!< If set, always convert image to the single channel grayscale image and the image size reduced 1/8.
82
       IMREAD_REDUCED_COLOR_8      = 65, //!< If set, always convert image to the 3 channel BGR color image and the image size reduced 1/8.
83
       IMREAD_IGNORE_ORIENTATION   = 128, //!< If set, do not rotate the image according to EXIF's orientation flag.
84
       IMREAD_COLOR_RGB            = 256, //!< If set, always convert image to the 3 channel RGB color image.
85
     };
86
87
//! Imwrite flags
88
enum ImwriteFlags {
89
       IMWRITE_JPEG_QUALITY        = 1,  //!< For JPEG, it can be a quality from 0 to 100 (the higher is the better). Default value is 95.
90
       IMWRITE_JPEG_PROGRESSIVE    = 2,  //!< Enable JPEG features, 0 or 1, default is False.
91
       IMWRITE_JPEG_OPTIMIZE       = 3,  //!< Enable JPEG features, 0 or 1, default is False.
92
       IMWRITE_JPEG_RST_INTERVAL   = 4,  //!< JPEG restart interval, 0 - 65535, default is 0 - no restart.
93
       IMWRITE_JPEG_LUMA_QUALITY   = 5,  //!< Separate luma quality level, 0 - 100, default is -1 - don't use. If JPEG_LIB_VERSION < 70, Not supported.
94
       IMWRITE_JPEG_CHROMA_QUALITY = 6,  //!< Separate chroma quality level, 0 - 100, default is -1 - don't use. If JPEG_LIB_VERSION < 70, Not supported.
95
       IMWRITE_JPEG_SAMPLING_FACTOR = 7, //!< For JPEG, set sampling factor. See cv::ImwriteJPEGSamplingFactorParams.
96
       IMWRITE_PNG_COMPRESSION     = 16, //!< For PNG, it can be the compression level from 0 to 9. A higher value means a smaller size and longer compression time. If specified, strategy is changed to IMWRITE_PNG_STRATEGY_DEFAULT (Z_DEFAULT_STRATEGY). Default value is 1 (best speed setting).
97
       IMWRITE_PNG_STRATEGY        = 17, //!< For PNG, One of cv::ImwritePNGFlags, default is IMWRITE_PNG_STRATEGY_RLE.
98
       IMWRITE_PNG_BILEVEL         = 18, //!< For PNG, Binary level PNG, 0 or 1, default is 0. For APNG, it is not supported.
99
       IMWRITE_PNG_FILTER          = 19, //!< For PNG, One of cv::ImwritePNGFilterFlags, default is IMWRITE_PNG_FILTER_SUB. For APNG, it is not supported.
100
       IMWRITE_PNG_ZLIBBUFFER_SIZE = 20, //!< For PNG with libpng, sets the size of the internal zlib compression buffer in bytes, from 6 to 1048576(1024 KiB). Default is 8192(8 KiB). For normal use, 131072(128 KiB) or 262144(256 KiB) may be sufficient. If WITH_SPNG=ON, it is not supported. For APNG, it is not supported.
101
       IMWRITE_PXM_BINARY          = 32, //!< For PPM, PGM, or PBM, it can be a binary format flag, 0 or 1. Default value is 1.
102
       IMWRITE_EXR_TYPE            = (3 << 4) + 0 /* 48 */, //!< override EXR storage type (FLOAT (FP32) is default)
103
       IMWRITE_EXR_COMPRESSION     = (3 << 4) + 1 /* 49 */, //!< override EXR compression type (ZIP_COMPRESSION = 3 is default)
104
       IMWRITE_EXR_DWA_COMPRESSION_LEVEL = (3 << 4) + 2 /* 50 */, //!< override EXR DWA compression level (45 is default)
105
       IMWRITE_WEBP_QUALITY        = 64, //!< For WEBP, it can be a lossy quality from 1 to 100 (the higher is the better) for IMWRITE_WEBP_LOSSLESS_OFF. By default (without this parameter) or if quality > 100, IMWRITE_WEBP_LOSSLESS_ON is used instead.
106
       IMWRITE_WEBP_LOSSLESS_MODE  = 65, //!< For WEBP, it can be a lossless compression strategy. See cv::ImwriteWEBPLosslessMode. Default is IMWRITE_WEBP_LOSSLESS_OFF. For Animated WEBP, it is not supported.
107
       IMWRITE_HDR_COMPRESSION     = (5 << 4) + 0 /* 80 */, //!< specify HDR compression
108
       IMWRITE_PAM_TUPLETYPE       = 128,//!< For PAM, sets the TUPLETYPE field to the corresponding string value that is defined for the format
109
       IMWRITE_TIFF_RESUNIT        = 256,//!< For TIFF, use to specify which DPI resolution unit to set. See ImwriteTiffResolutionUnitFlags. Default is IMWRITE_TIFF_RESOLUTION_UNIT_INCH.
110
       IMWRITE_TIFF_XDPI           = 257,//!< For TIFF, use to specify the X direction DPI
111
       IMWRITE_TIFF_YDPI           = 258,//!< For TIFF, use to specify the Y direction DPI
112
       IMWRITE_TIFF_COMPRESSION    = 259,//!< For TIFF, use to specify the image compression scheme. See cv::ImwriteTiffCompressionFlags. Note, for images whose depth is CV_32F, only libtiff's SGILOG compression scheme is used. For other supported depths, the compression scheme can be specified by this flag; LZW compression is the default.
113
       IMWRITE_TIFF_ROWSPERSTRIP   = 278,//!< For TIFF, use to specify the number of rows per strip.
114
       IMWRITE_TIFF_PREDICTOR      = 317,//!< For TIFF, use to specify predictor. See cv::ImwriteTiffPredictorFlags. Default is IMWRITE_TIFF_PREDICTOR_HORIZONTAL .
115
       IMWRITE_JPEG2000_COMPRESSION_X1000 = 272,//!< For JPEG2000, use to specify the target compression rate (multiplied by 1000). The value can be from 0 to 1000. Default is 1000.
116
       IMWRITE_AVIF_QUALITY        = 512,//!< For AVIF, it can be a quality between 0 and 100 (the higher the better). Default is 95.
117
       IMWRITE_AVIF_DEPTH          = 513,//!< For AVIF, it can be 8, 10 or 12. If >8, it is stored/read as CV_16U. Default is 8.
118
       IMWRITE_AVIF_SPEED          = 514,//!< For AVIF, it is between 0 (slowest) and 10(fastest). Default is 9.
119
       IMWRITE_JPEGXL_QUALITY      = 640,//!< For JPEG XL, it can be a quality from 0 to 100 (the higher is the better). Default value is 95. If set, distance parameter is re-calicurated from quality level automatically. This parameter request libjxl v0.10 or later.
120
       IMWRITE_JPEGXL_EFFORT       = 641,//!< For JPEG XL, encoder effort/speed level without affecting decoding speed; it is between 1 (fastest) and 10 (slowest). Default is 7.
121
       IMWRITE_JPEGXL_DISTANCE     = 642,//!< For JPEG XL, distance level for lossy compression: target max butteraugli distance, lower = higher quality, 0 = lossless; range: 0 .. 25. Default is 1.
122
       IMWRITE_JPEGXL_DECODING_SPEED = 643,//!< For JPEG XL, decoding speed tier for the provided options; minimum is 0 (slowest to decode, best quality/density), and maximum is 4 (fastest to decode, at the cost of some quality/density). Default is 0.
123
       IMWRITE_BMP_COMPRESSION     = 768,  //!< For BMP, use to specify compress parameter for 32bpp image. Default is IMWRITE_BMP_COMPRESSION_BITFIELDS. See cv::ImwriteBMPCompressionFlags.
124
       IMWRITE_GIF_LOOP            = 1024, //!< Not functional since 4.12.0. Replaced by cv::Animation::loop_count.
125
       IMWRITE_GIF_SPEED           = 1025, //!< Not functional since 4.12.0. Replaced by cv::Animation::durations.
126
       IMWRITE_GIF_QUALITY         = 1026, //!< For GIF, it can be a quality from 1 to 8. Default is 2. See cv::ImwriteGifCompressionFlags.
127
       IMWRITE_GIF_DITHER          = 1027, //!< For GIF, it can be a quality from -1(most dither) to 3(no dither). Default is 0.
128
       IMWRITE_GIF_TRANSPARENCY    = 1028, //!< For GIF, the alpha channel lower than this will be set to transparent. Default is 1.
129
       IMWRITE_GIF_COLORTABLE      = 1029  //!< For GIF, 0 means global color table is used, 1 means local color table is used. Default is 0.
130
};
131
132
enum ImwriteJPEGSamplingFactorParams {
133
       IMWRITE_JPEG_SAMPLING_FACTOR_411 = 0x411111, //!< 4x1,1x1,1x1
134
       IMWRITE_JPEG_SAMPLING_FACTOR_420 = 0x221111, //!< 2x2,1x1,1x1(Default)
135
       IMWRITE_JPEG_SAMPLING_FACTOR_422 = 0x211111, //!< 2x1,1x1,1x1
136
       IMWRITE_JPEG_SAMPLING_FACTOR_440 = 0x121111, //!< 1x2,1x1,1x1
137
       IMWRITE_JPEG_SAMPLING_FACTOR_444 = 0x111111  //!< 1x1,1x1,1x1(No subsampling)
138
     };
139
140
enum ImwriteTiffCompressionFlags {
141
        IMWRITE_TIFF_COMPRESSION_NONE = 1,            //!< dump mode
142
        IMWRITE_TIFF_COMPRESSION_CCITTRLE = 2,        //!< CCITT modified Huffman RLE
143
        IMWRITE_TIFF_COMPRESSION_CCITTFAX3 = 3,       //!< CCITT Group 3 fax encoding
144
        IMWRITE_TIFF_COMPRESSION_CCITT_T4 = 3,        //!< CCITT T.4 (TIFF 6 name)
145
        IMWRITE_TIFF_COMPRESSION_CCITTFAX4 = 4,       //!< CCITT Group 4 fax encoding
146
        IMWRITE_TIFF_COMPRESSION_CCITT_T6 = 4,        //!< CCITT T.6 (TIFF 6 name)
147
        IMWRITE_TIFF_COMPRESSION_LZW = 5,             //!< Lempel-Ziv  & Welch
148
        IMWRITE_TIFF_COMPRESSION_OJPEG = 6,           //!< !6.0 JPEG
149
        IMWRITE_TIFF_COMPRESSION_JPEG = 7,            //!< %JPEG DCT compression
150
        IMWRITE_TIFF_COMPRESSION_T85 = 9,             //!< !TIFF/FX T.85 JBIG compression
151
        IMWRITE_TIFF_COMPRESSION_T43 = 10,            //!< !TIFF/FX T.43 colour by layered JBIG compression
152
        IMWRITE_TIFF_COMPRESSION_NEXT = 32766,        //!< NeXT 2-bit RLE
153
        IMWRITE_TIFF_COMPRESSION_CCITTRLEW = 32771,   //!< #1 w/ word alignment
154
        IMWRITE_TIFF_COMPRESSION_PACKBITS = 32773,    //!< Macintosh RLE
155
        IMWRITE_TIFF_COMPRESSION_THUNDERSCAN = 32809, //!< ThunderScan RLE
156
        IMWRITE_TIFF_COMPRESSION_IT8CTPAD = 32895,    //!< IT8 CT w/padding
157
        IMWRITE_TIFF_COMPRESSION_IT8LW = 32896,       //!< IT8 Linework RLE
158
        IMWRITE_TIFF_COMPRESSION_IT8MP = 32897,       //!< IT8 Monochrome picture
159
        IMWRITE_TIFF_COMPRESSION_IT8BL = 32898,       //!< IT8 Binary line art
160
        IMWRITE_TIFF_COMPRESSION_PIXARFILM = 32908,   //!< Pixar companded 10bit LZW
161
        IMWRITE_TIFF_COMPRESSION_PIXARLOG = 32909,    //!< Pixar companded 11bit ZIP
162
        IMWRITE_TIFF_COMPRESSION_DEFLATE = 32946,     //!< Deflate compression, legacy tag
163
        IMWRITE_TIFF_COMPRESSION_ADOBE_DEFLATE = 8,   //!< Deflate compression, as recognized by Adobe
164
        IMWRITE_TIFF_COMPRESSION_DCS = 32947,         //!< Kodak DCS encoding
165
        IMWRITE_TIFF_COMPRESSION_JBIG = 34661,        //!< ISO JBIG
166
        IMWRITE_TIFF_COMPRESSION_SGILOG = 34676,      //!< SGI Log Luminance RLE
167
        IMWRITE_TIFF_COMPRESSION_SGILOG24 = 34677,    //!< SGI Log 24-bit packed
168
        IMWRITE_TIFF_COMPRESSION_JP2000 = 34712,      //!< Leadtools JPEG2000
169
        IMWRITE_TIFF_COMPRESSION_LERC = 34887,        //!< ESRI Lerc codec: https://github.com/Esri/lerc
170
        IMWRITE_TIFF_COMPRESSION_LZMA = 34925,        //!< LZMA2
171
        IMWRITE_TIFF_COMPRESSION_ZSTD = 50000,        //!< ZSTD: WARNING not registered in Adobe-maintained registry
172
        IMWRITE_TIFF_COMPRESSION_WEBP = 50001,        //!< WEBP: WARNING not registered in Adobe-maintained registry
173
        IMWRITE_TIFF_COMPRESSION_JXL = 50002          //!< JPEGXL: WARNING not registered in Adobe-maintained registry
174
};
175
176
enum ImwriteTiffPredictorFlags {
177
        IMWRITE_TIFF_PREDICTOR_NONE = 1,              //!< no prediction scheme used
178
        IMWRITE_TIFF_PREDICTOR_HORIZONTAL = 2,        //!< horizontal differencing
179
        IMWRITE_TIFF_PREDICTOR_FLOATINGPOINT = 3      //!< floating point predictor
180
};
181
182
enum ImwriteTiffResolutionUnitFlags {
183
        IMWRITE_TIFF_RESOLUTION_UNIT_NONE = 1,        //!< no absolute unit of measurement.
184
        IMWRITE_TIFF_RESOLUTION_UNIT_INCH = 2,        //!< inch
185
        IMWRITE_TIFF_RESOLUTION_UNIT_CENTIMETER = 3,  //!< centimeter
186
};
187
188
enum ImwriteEXRTypeFlags {
189
       // IMWRITE_EXR_TYPE_UNIT = 0, // not supported
190
       IMWRITE_EXR_TYPE_HALF   = 1, //!< store as HALF (FP16)
191
       IMWRITE_EXR_TYPE_FLOAT  = 2  //!< store as FP32 (default)
192
     };
193
194
enum ImwriteEXRCompressionFlags {
195
       IMWRITE_EXR_COMPRESSION_NO    = 0, //!< no compression
196
       IMWRITE_EXR_COMPRESSION_RLE   = 1, //!< run length encoding
197
       IMWRITE_EXR_COMPRESSION_ZIPS  = 2, //!< zlib compression, one scan line at a time
198
       IMWRITE_EXR_COMPRESSION_ZIP   = 3, //!< zlib compression, in blocks of 16 scan lines
199
       IMWRITE_EXR_COMPRESSION_PIZ   = 4, //!< piz-based wavelet compression
200
       IMWRITE_EXR_COMPRESSION_PXR24 = 5, //!< lossy 24-bit float compression
201
       IMWRITE_EXR_COMPRESSION_B44   = 6, //!< lossy 4-by-4 pixel block compression, fixed compression rate
202
       IMWRITE_EXR_COMPRESSION_B44A  = 7, //!< lossy 4-by-4 pixel block compression, flat fields are compressed more
203
       IMWRITE_EXR_COMPRESSION_DWAA  = 8, //!< lossy DCT based compression, in blocks of 32 scanlines. More efficient for partial buffer access. Supported since OpenEXR 2.2.0.
204
       IMWRITE_EXR_COMPRESSION_DWAB  = 9, //!< lossy DCT based compression, in blocks of 256 scanlines. More efficient space wise and faster to decode full frames than DWAA_COMPRESSION. Supported since OpenEXR 2.2.0.
205
     };
206
207
//! Imwrite PNG specific flags used to tune the compression algorithm.
208
/** These flags will be modify the way of PNG image compression and will be passed to the underlying zlib processing stage.
209
210
-   The effect of IMWRITE_PNG_STRATEGY_FILTERED is to force more Huffman coding and less string matching; it is somewhat intermediate between IMWRITE_PNG_STRATEGY_DEFAULT and IMWRITE_PNG_STRATEGY_HUFFMAN_ONLY.
211
-   IMWRITE_PNG_STRATEGY_RLE is designed to be almost as fast as IMWRITE_PNG_STRATEGY_HUFFMAN_ONLY, but give better compression for PNG image data.
212
-   The strategy parameter only affects the compression ratio but not the correctness of the compressed output even if it is not set appropriately.
213
-   IMWRITE_PNG_STRATEGY_FIXED prevents the use of dynamic Huffman codes, allowing for a simpler decoder for special applications.
214
*/
215
enum ImwritePNGFlags {
216
       IMWRITE_PNG_STRATEGY_DEFAULT      = 0, //!< Use this value for normal data.
217
       IMWRITE_PNG_STRATEGY_FILTERED     = 1, //!< Use this value for data produced by a filter (or predictor).Filtered data consists mostly of small values with a somewhat random distribution. In this case, the compression algorithm is tuned to compress them better.
218
       IMWRITE_PNG_STRATEGY_HUFFMAN_ONLY = 2, //!< Use this value to force Huffman encoding only (no string match).
219
       IMWRITE_PNG_STRATEGY_RLE          = 3, //!< Use this value to limit match distances to one (run-length encoding).
220
       IMWRITE_PNG_STRATEGY_FIXED        = 4  //!< Using this value prevents the use of dynamic Huffman codes, allowing for a simpler decoder for special applications.
221
     };
222
223
//! Imwrite PNG specific values for IMWRITE_PNG_FILTER parameter key
224
enum ImwritePNGFilterFlags {
225
       IMWRITE_PNG_FILTER_NONE           = 8,   //!< Applies no filter to the PNG image (useful when you want to save the raw pixel data without any compression filter).
226
       IMWRITE_PNG_FILTER_SUB            = 16,  //!< Applies the "sub" filter, which calculates the difference between the current byte and the previous byte in the row.
227
       IMWRITE_PNG_FILTER_UP             = 32,  //!< applies the "up" filter, which calculates the difference between the current byte and the corresponding byte directly above it.
228
       IMWRITE_PNG_FILTER_AVG            = 64,  //!< applies the "average" filter, which calculates the average of the byte to the left and the byte above.
229
       IMWRITE_PNG_FILTER_PAETH          = 128, //!< applies the "Paeth" filter, a more complex filter that predicts the next pixel value based on neighboring pixels.
230
       IMWRITE_PNG_FAST_FILTERS          = (IMWRITE_PNG_FILTER_NONE | IMWRITE_PNG_FILTER_SUB | IMWRITE_PNG_FILTER_UP), //!< This is a combination of IMWRITE_PNG_FILTER_NONE, IMWRITE_PNG_FILTER_SUB, and IMWRITE_PNG_FILTER_UP, typically used for faster compression.
231
       IMWRITE_PNG_ALL_FILTERS           = (IMWRITE_PNG_FAST_FILTERS | IMWRITE_PNG_FILTER_AVG | IMWRITE_PNG_FILTER_PAETH) //!< This combines all available filters (NONE, SUB, UP, AVG, and PAETH), which will attempt to apply all of them for the best possible compression.
232
     };
233
234
//! Imwrite PAM specific tupletype flags used to define the 'TUPLETYPE' field of a PAM file.
235
enum ImwritePAMFlags {
236
       IMWRITE_PAM_FORMAT_NULL            = 0,
237
       IMWRITE_PAM_FORMAT_BLACKANDWHITE   = 1,
238
       IMWRITE_PAM_FORMAT_GRAYSCALE       = 2,
239
       IMWRITE_PAM_FORMAT_GRAYSCALE_ALPHA = 3,
240
       IMWRITE_PAM_FORMAT_RGB             = 4,
241
       IMWRITE_PAM_FORMAT_RGB_ALPHA       = 5
242
     };
243
244
//! Imwrite WEBP specific values for IMWRITE_WEBP_LOSSLESS_MODE parameter key.
245
enum ImwriteWEBPLosslessMode {
246
    IMWRITE_WEBP_LOSSLESS_OFF            = 0, //!< Lossy compression mode. Uses IMWRITE_WEBP_QUALITY to control compression. (Default)
247
                                              //!< @note If IMWRITE_WEBP_QUALITY is not specified, it falls back to IMWRITE_WEBP_LOSSLESS_ON to maintain backward compatibility.
248
    IMWRITE_WEBP_LOSSLESS_ON             = 1, //!< Standard lossless compression. May modify or discard RGB values of fully transparent pixels to improve compression ratio.
249
    IMWRITE_WEBP_LOSSLESS_PRESERVE_COLOR = 2, //!< Exact lossless compression. Preserves all RGB data even for pixels with 0 alpha (equivalent to WebP's exact flag).
250
};
251
252
//! Imwrite HDR specific values for IMWRITE_HDR_COMPRESSION parameter key
253
enum ImwriteHDRCompressionFlags {
254
    IMWRITE_HDR_COMPRESSION_NONE = 0,
255
    IMWRITE_HDR_COMPRESSION_RLE = 1
256
};
257
258
//! Imwrite BMP specific values for IMWRITE_BMP_COMPRESSION parameter key.
259
enum ImwriteBMPCompressionFlags {
260
    IMWRITE_BMP_COMPRESSION_RGB = 0,       //!< Use BI_RGB. OpenCV v4.12.0 or before supports to encode with this compression only.
261
    IMWRITE_BMP_COMPRESSION_BITFIELDS = 3, //!< Use BI_BITFIELDS. OpenCV v4.13.0 or later can support to encode with this compression. (only for 32 BPP images)
262
};
263
264
//! Imwrite GIF specific values for IMWRITE_GIF_QUALITY parameter key, if larger than 3, then its related to the size of the color table.
265
enum ImwriteGIFCompressionFlags {
266
    IMWRITE_GIF_FAST_NO_DITHER       = 1,
267
    IMWRITE_GIF_FAST_FLOYD_DITHER    = 2,
268
    IMWRITE_GIF_COLORTABLE_SIZE_8    = 3,
269
    IMWRITE_GIF_COLORTABLE_SIZE_16   = 4,
270
    IMWRITE_GIF_COLORTABLE_SIZE_32   = 5,
271
    IMWRITE_GIF_COLORTABLE_SIZE_64   = 6,
272
    IMWRITE_GIF_COLORTABLE_SIZE_128  = 7,
273
    IMWRITE_GIF_COLORTABLE_SIZE_256  = 8
274
};
275
276
enum ImageMetadataType
277
{
278
    IMAGE_METADATA_UNKNOWN = -1, // Used when metadata type is unrecognized or not set
279
280
    IMAGE_METADATA_EXIF = 0,     // EXIF metadata (e.g., camera info, GPS, orientation)
281
    IMAGE_METADATA_XMP = 1,      // XMP metadata (eXtensible Metadata Platform - Adobe format)
282
    IMAGE_METADATA_ICCP = 2,     // ICC Profile (color profile for color management)
283
    IMAGE_METADATA_CICP = 3,     // cICP Profile (video signal type)
284
285
    IMAGE_METADATA_MAX = 3       // Highest valid index (usually used for bounds checking)
286
};
287
288
//! @} imgcodecs_flags
289
290
/** @brief Represents an animation with multiple frames.
291
The `Animation` struct is designed to store and manage data for animated sequences such as those from animated formats (e.g., GIF, AVIF, APNG, WebP).
292
It provides support for looping, background color settings, frame timing, and frame storage.
293
*/
294
struct CV_EXPORTS_W_SIMPLE Animation
295
{
296
    //! Number of times the animation should loop. 0 means infinite looping.
297
    /*! @note At some file format, when N is set, whether it is displayed N or N+1 times depends on the implementation of the user application. This loop times behaviour has not been documented clearly.
298
     *  - (GIF) See https://issues.chromium.org/issues/40459899
299
     *    And animated GIF with loop is extended with the Netscape Application Block(NAB), which it not a part of GIF89a specification. See https://en.wikipedia.org/wiki/GIF#Animated_GIF .
300
     *  - (WebP) See https://issues.chromium.org/issues/41276895
301
     */
302
    CV_PROP_RW int loop_count;
303
    //! Background color of the animation in BGRA format.
304
    CV_PROP_RW Scalar bgcolor;
305
    //! Duration for each frame in milliseconds.
306
    /*! @note (GIF) Due to file format limitation
307
     *  - Durations must be multiples of 10 milliseconds. Any provided value will be rounded down to the nearest 10ms (e.g., 88ms → 80ms).
308
     *  - 0ms(or smaller than expected in user application) duration may cause undefined behavior, e.g. it is handled with default duration.
309
     *  - Over 65535 * 10 milliseconds duration is not supported.
310
     */
311
    CV_PROP_RW std::vector<int> durations;
312
    //! Vector of frames, where each Mat represents a single frame.
313
    CV_PROP_RW std::vector<Mat> frames;
314
    //! image that can be used for the format in addition to the animation or if animation is not supported in the reader (like in PNG).
315
    CV_PROP_RW Mat still_image;
316
317
    /** @brief Constructs an Animation object with optional loop count and background color.
318
319
    @param loopCount An integer representing the number of times the animation should loop:
320
    - `0` (default) indicates infinite looping, meaning the animation will replay continuously.
321
    - Positive values denote finite repeat counts, allowing the animation to play a limited number of times.
322
    - If a negative value or a value beyond the maximum of `0xffff` (65535) is provided, it is reset to `0`
323
    (infinite looping) to maintain valid bounds.
324
325
    @param bgColor A `Scalar` object representing the background color in BGR format:
326
    - Defaults to `Scalar()`, indicating an empty color (usually transparent if supported).
327
    - This background color provides a solid fill behind frames that have transparency, ensuring a consistent display appearance.
328
    */
329
    CV_WRAP Animation(int loopCount = 0, Scalar bgColor = Scalar());
330
};
331
332
/** @brief Loads an image from a file.
333
334
@anchor imread
335
336
The `imread` function loads an image from the specified file and returns OpenCV matrix. If the image cannot be
337
read (because of a missing file, improper permissions, or unsupported/invalid format), the function
338
returns an empty matrix.
339
340
Currently, the following file formats are supported:
341
342
-   Windows bitmaps - \*.bmp, \*.dib (always supported)
343
-   GIF files - \*.gif (always supported)
344
-   JPEG files - \*.jpeg, \*.jpg, \*.jpe (see the *Note* section)
345
-   JPEG 2000 files - \*.jp2 (see the *Note* section)
346
-   Portable Network Graphics - \*.png (see the *Note* section)
347
-   WebP - \*.webp (see the *Note* section)
348
-   AVIF - \*.avif (see the *Note* section)
349
-   Portable image format - \*.pbm, \*.pgm, \*.ppm, \*.pxm, \*.pnm (always supported)
350
-   PFM files - \*.pfm (see the *Note* section)
351
-   Sun rasters - \*.sr, \*.ras (always supported)
352
-   TIFF files - \*.tiff, \*.tif (see the *Note* section)
353
-   OpenEXR Image files - \*.exr (see the *Note* section)
354
-   Radiance HDR - \*.hdr, \*.pic (always supported)
355
-   Raster and Vector geospatial data supported by GDAL (see the *Note* section)
356
357
@note
358
-   The function determines the type of an image by its content, not by the file extension.
359
-   In the case of color images, the decoded images will have the channels stored in **B G R** order.
360
-   When using IMREAD_GRAYSCALE, the codec's internal grayscale conversion will be used, if available.
361
    Results may differ from the output of cvtColor().
362
-   On Microsoft Windows\* and Mac OS\*, the codecs shipped with OpenCV (libjpeg, libpng, libtiff,
363
    and libjasper) are used by default. So, OpenCV can always read JPEGs, PNGs, and TIFFs. On Mac OS,
364
    there is also an option to use native Mac OS image readers. However, beware that currently these
365
    native image loaders give images with different pixel values because of the color management embedded
366
    into Mac OS.
367
-   On Linux\*, BSD flavors, and other Unix-like open-source operating systems, OpenCV looks for
368
    codecs supplied with the OS. Ensure the relevant packages are installed (including development
369
    files, such as "libjpeg-dev" in Debian\* and Ubuntu\*) to get codec support, or turn
370
    on the OPENCV_BUILD_3RDPARTY_LIBS flag in CMake.
371
-   If the *WITH_GDAL* flag is set to true in CMake and @ref IMREAD_LOAD_GDAL is used to load the image,
372
    the [GDAL](http://www.gdal.org) driver will be used to decode the image, supporting
373
    [Raster](http://www.gdal.org/formats_list.html) and [Vector](http://www.gdal.org/ogr_formats.html) formats.
374
-   If EXIF information is embedded in the image file, the EXIF orientation will be taken into account,
375
    and thus the image will be rotated accordingly unless the flags @ref IMREAD_IGNORE_ORIENTATION
376
    or @ref IMREAD_UNCHANGED are passed.
377
-   Use the IMREAD_UNCHANGED flag to preserve the floating-point values from PFM images.
378
-   By default, the number of pixels must be less than 2^30. This limit can be changed by setting
379
    the environment variable `OPENCV_IO_MAX_IMAGE_PIXELS`. See @ref tutorial_env_reference.
380
381
@param filename Name of the file to be loaded.
382
@param flags Flag that can take values of cv::ImreadModes, default with cv::IMREAD_COLOR_BGR.
383
*/
384
CV_EXPORTS_W Mat imread( const String& filename, int flags = IMREAD_COLOR_BGR );
385
386
/** @brief Loads an image from a file.
387
388
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts and the return value.
389
@param filename Name of file to be loaded.
390
@param dst object in which the image will be loaded.
391
@param flags Flag that can take values of cv::ImreadModes, default with cv::IMREAD_COLOR_BGR.
392
@note
393
The image passing through the img parameter can be pre-allocated. The memory is reused if the shape and the type match with the load image.
394
 */
395
CV_EXPORTS_W void imread( const String& filename, OutputArray dst, int flags = IMREAD_COLOR_BGR );
396
397
/** @brief Reads an image from a file along with associated metadata.
398
399
This function behaves similarly to cv::imread(), loading an image from the specified file.
400
In addition to the image pixel data, it also attempts to extract any available metadata
401
embedded in the file (such as EXIF, XMP, etc.), depending on file format support.
402
403
@note In the case of color images, the decoded images will have the channels stored in **B G R** order.
404
@param filename Name of the file to be loaded.
405
@param metadataTypes Output vector with types of metadata chunks returned in metadata, see ImageMetadataType.
406
@param metadata Output vector of vectors or vector of matrices to store the retrieved metadata.
407
@param flags Flag that can take values of cv::ImreadModes, default with cv::IMREAD_ANYCOLOR.
408
409
@return The loaded image as a cv::Mat object. If the image cannot be read, the function returns an empty matrix.
410
*/
411
CV_EXPORTS_W Mat imreadWithMetadata( const String& filename, CV_OUT std::vector<int>& metadataTypes,
412
                                     OutputArrayOfArrays metadata, int flags = IMREAD_ANYCOLOR);
413
414
/** @brief Loads a multi-page image from a file.
415
416
The function imreadmulti loads a multi-page image from the specified file into a vector of Mat objects.
417
@param filename Name of file to be loaded.
418
@param mats A vector of Mat objects holding each page.
419
@param flags Flag that can take values of cv::ImreadModes, default with cv::IMREAD_ANYCOLOR.
420
@sa cv::imread
421
*/
422
CV_EXPORTS_W bool imreadmulti(const String& filename, CV_OUT std::vector<Mat>& mats, int flags = IMREAD_ANYCOLOR);
423
424
/** @brief Loads images of a multi-page image from a file.
425
426
The function imreadmulti loads a specified range from a multi-page image from the specified file into a vector of Mat objects.
427
@param filename Name of file to be loaded.
428
@param mats A vector of Mat objects holding each page.
429
@param start Start index of the image to load
430
@param count Count number of images to load
431
@param flags Flag that can take values of cv::ImreadModes, default with cv::IMREAD_ANYCOLOR.
432
@sa cv::imread
433
*/
434
CV_EXPORTS_W bool imreadmulti(const String& filename, CV_OUT std::vector<Mat>& mats, int start, int count, int flags = IMREAD_ANYCOLOR);
435
436
/** @example samples/cpp/tutorial_code/imgcodecs/animations.cpp
437
An example to show usage of cv::imreadanimation and cv::imwriteanimation functions.
438
Check @ref tutorial_animations "the corresponding tutorial" for more details
439
*/
440
441
/** @brief Loads frames from an animated image file into an Animation structure.
442
443
The function imreadanimation loads frames from an animated image file (e.g., GIF, AVIF, APNG, WEBP) into the provided Animation struct.
444
445
@param filename A string containing the path to the file.
446
@param animation A reference to an Animation structure where the loaded frames will be stored. It should be initialized before the function is called.
447
@param start The index of the first frame to load. This is optional and defaults to 0.
448
@param count The number of frames to load. This is optional and defaults to 32767.
449
450
@return Returns true if the file was successfully loaded and frames were extracted; returns false otherwise.
451
*/
452
CV_EXPORTS_W bool imreadanimation(const String& filename, CV_OUT Animation& animation, int start = 0, int count = INT16_MAX);
453
454
/** @brief Loads frames from an animated image buffer into an Animation structure.
455
456
The function imdecodeanimation loads frames from an animated image buffer (e.g., GIF, AVIF, APNG, WEBP) into the provided Animation struct.
457
458
@param buf A reference to an InputArray containing the image buffer.
459
@param animation A reference to an Animation structure where the loaded frames will be stored. It should be initialized before the function is called.
460
@param start The index of the first frame to load. This is optional and defaults to 0.
461
@param count The number of frames to load. This is optional and defaults to 32767.
462
463
@return Returns true if the buffer was successfully loaded and frames were extracted; returns false otherwise.
464
*/
465
CV_EXPORTS_W bool imdecodeanimation(InputArray buf, CV_OUT Animation& animation, int start = 0, int count = INT16_MAX);
466
467
/** @brief Saves an Animation to a specified file.
468
469
The function imwriteanimation saves the provided Animation data to the specified file in an animated format.
470
Supported formats depend on the implementation and may include formats like GIF, AVIF, APNG, or WEBP.
471
472
@param filename The name of the file where the animation will be saved. The file extension determines the format.
473
@param animation A constant reference to an Animation struct containing the frames and metadata to be saved.
474
@param params Optional format-specific parameters encoded as pairs (paramId_1, paramValue_1, paramId_2, paramValue_2, ...).
475
These parameters are used to specify additional options for the encoding process. Refer to `cv::ImwriteFlags` for details on possible parameters.
476
477
@return Returns true if the animation was successfully saved; returns false otherwise.
478
*/
479
CV_EXPORTS_W bool imwriteanimation(const String& filename, const Animation& animation, const std::vector<int>& params = std::vector<int>());
480
481
/** @brief Encodes an Animation to a memory buffer.
482
483
The function imencodeanimation encodes the provided Animation data into a memory
484
buffer in an animated format. Supported formats depend on the implementation and
485
may include formats like GIF, AVIF, APNG, or WEBP.
486
487
@param ext The file extension that determines the format of the encoded data.
488
@param animation A constant reference to an Animation struct containing the
489
frames and metadata to be encoded.
490
@param buf A reference to a vector of unsigned chars where the encoded data will
491
be stored.
492
@param params Optional format-specific parameters encoded as pairs (paramId_1,
493
paramValue_1, paramId_2, paramValue_2, ...). These parameters are used to
494
specify additional options for the encoding process. Refer to `cv::ImwriteFlags`
495
for details on possible parameters.
496
497
@return Returns true if the animation was successfully encoded; returns false otherwise.
498
*/
499
CV_EXPORTS_W bool imencodeanimation(const String& ext, const Animation& animation, CV_OUT std::vector<uchar>& buf, const std::vector<int>& params = std::vector<int>());
500
501
/** @brief Returns the number of images inside the given file
502
503
The function imcount returns the number of pages in a multi-page image (e.g. TIFF), the number of frames in an animation (e.g. AVIF), and 1 otherwise.
504
If the image cannot be decoded, 0 is returned.
505
@param filename Name of file to be loaded.
506
@param flags Flag that can take values of cv::ImreadModes, default with cv::IMREAD_ANYCOLOR.
507
@todo when cv::IMREAD_LOAD_GDAL flag used the return value will be 0 or 1 because OpenCV's GDAL decoder doesn't support multi-page reading yet.
508
*/
509
CV_EXPORTS_W size_t imcount(const String& filename, int flags = IMREAD_ANYCOLOR);
510
511
/** @brief Saves an image to a specified file.
512
513
The function imwrite saves the image to the specified file. The image format is chosen based on the
514
filename extension (see cv::imread for the list of extensions). In general, only 8-bit unsigned (CV_8U)
515
single-channel or 3-channel (with 'BGR' channel order) images
516
can be saved using this function, with these exceptions:
517
518
- With BMP encoder, 8-bit unsigned (CV_8U) images can be saved.
519
  - BMP images with an alpha channel can be saved using this function.
520
    To achieve this, create an 8-bit 4-channel (CV_8UC4) BGRA image, ensuring the alpha channel is the last component.
521
    Fully transparent pixels should have an alpha value of 0, while fully opaque pixels should have an alpha value of 255.
522
    OpenCV v4.13.0 or later use BI_BITFIELDS compression as default. See IMWRITE_BMP_COMPRESSION.
523
- With OpenEXR encoder, only 32-bit float (CV_32F) images can be saved. More than 4 channels can be saved. (imread can load it then.)
524
  - 8-bit unsigned (CV_8U) images are not supported.
525
- With Radiance HDR encoder, non 64-bit float (CV_64F) images can be saved.
526
  - All images will be converted to 32-bit float (CV_32F).
527
- With JPEG 2000 encoder, 8-bit unsigned (CV_8U) and 16-bit unsigned (CV_16U) images can be saved.
528
- With JPEG XL encoder, 8-bit unsigned (CV_8U), 16-bit unsigned (CV_16U) and 32-bit float(CV_32F) images can be saved.
529
  - JPEG XL images with an alpha channel can be saved using this function.
530
    To achieve this, create an 8-bit 4-channel (CV_8UC4) / 16-bit 4-channel (CV_16UC4) / 32-bit float 4-channel (CV_32FC4) BGRA image, ensuring the alpha channel is the last component.
531
    Fully transparent pixels should have an alpha value of 0, while fully opaque pixels should have an alpha value of 255/65535/1.0.
532
- With PAM encoder, 8-bit unsigned (CV_8U) and 16-bit unsigned (CV_16U) images can be saved.
533
- With PNG encoder, 8-bit unsigned (CV_8U) and 16-bit unsigned (CV_16U) images can be saved.
534
  - PNG images with an alpha channel can be saved using this function.
535
    To achieve this, create an 8-bit 4-channel (CV_8UC4) / 16-bit 4-channel (CV_16UC4) BGRA image, ensuring the alpha channel is the last component.
536
    Fully transparent pixels should have an alpha value of 0, while fully opaque pixels should have an alpha value of 255/65535(see the code sample below).
537
- With PGM/PPM encoder, 8-bit unsigned (CV_8U) and 16-bit unsigned (CV_16U) images can be saved.
538
- With TIFF encoder, 8-bit unsigned (CV_8U), 8-bit signed (CV_8S),
539
                     16-bit unsigned (CV_16U), 16-bit signed (CV_16S),
540
                     32-bit signed (CV_32S),
541
                     32-bit float (CV_32F) and 64-bit float (CV_64F) images can be saved.
542
  - Multiple images (vector of Mat) can be saved in TIFF format (see the code sample below).
543
  - 32-bit float 3-channel (CV_32FC3) TIFF images will be saved
544
    using the LogLuv high dynamic range encoding (4 bytes per pixel)
545
- With GIF encoder, 8-bit unsigned (CV_8U) images can be saved.
546
  - GIF images with an alpha channel can be saved using this function.
547
    To achieve this, create an 8-bit 4-channel (CV_8UC4) BGRA image, ensuring the alpha channel is the last component.
548
    Fully transparent pixels should have an alpha value of 0, while fully opaque pixels should have an alpha value of 255.
549
  - 8-bit single-channel images (CV_8UC1) are not supported due to GIF's limitation to indexed color formats.
550
- With AVIF encoder, 8-bit unsigned (CV_8U) and 16-bit unsigned (CV_16U) images can be saved.
551
  - CV_16U images can be saved as only 10-bit or 12-bit (not 16-bit). See IMWRITE_AVIF_DEPTH.
552
  - AVIF images with an alpha channel can be saved using this function.
553
    To achieve this, create an 8-bit 4-channel (CV_8UC4) / 16-bit 4-channel (CV_16UC4) BGRA image, ensuring the alpha channel is the last component.
554
    Fully transparent pixels should have an alpha value of 0, while fully opaque pixels should have an alpha value of 255 (8-bit) / 1023 (10-bit) / 4095 (12-bit) (see the code sample below).
555
556
If the image format is not supported, the image will be converted to 8-bit unsigned (CV_8U) and saved that way.
557
558
If the format, depth or channel order is different, use
559
Mat::convertTo and cv::cvtColor to convert it before saving. Or, use the universal FileStorage I/O
560
functions to save the image to XML or YAML format.
561
562
The sample below shows how to create a BGRA image, how to set custom compression parameters and save it to a PNG file.
563
It also demonstrates how to save multiple images in a TIFF file:
564
@include snippets/imgcodecs_imwrite.cpp
565
@param filename Name of the file.
566
@param img (Mat or vector of Mat) Image or Images to be saved.
567
@param params Format-specific parameters encoded as pairs (paramId_1, paramValue_1, paramId_2, paramValue_2, ... .) see cv::ImwriteFlags
568
@return true if the image is successfully written to the specified file; false otherwise.
569
*/
570
CV_EXPORTS_W bool imwrite( const String& filename, InputArray img,
571
              const std::vector<int>& params = std::vector<int>());
572
573
/** @brief Saves an image to a specified file with metadata
574
575
The function imwriteWithMetadata saves the image to the specified file. It does the same thing as imwrite, but additionally writes metadata if the corresponding format supports it.
576
@param filename Name of the file. As with imwrite, image format is determined by the file extension.
577
@param img (Mat or vector of Mat) Image or Images to be saved.
578
@param metadataTypes Vector with types of metadata chucks stored in metadata to write, see ImageMetadataType.
579
@param metadata Vector of vectors or vector of matrices with chunks of metadata to store into the file
580
@param params Format-specific parameters encoded as pairs (paramId_1, paramValue_1, paramId_2, paramValue_2, ... .) see cv::ImwriteFlags
581
*/
582
CV_EXPORTS_W bool imwriteWithMetadata( const String& filename, InputArray img,
583
                                       const std::vector<int>& metadataTypes,
584
                                       InputArrayOfArrays& metadata,
585
                                       const std::vector<int>& params = std::vector<int>());
586
587
//! @brief multi-image overload for bindings
588
CV_WRAP static inline
589
bool imwritemulti(const String& filename, InputArrayOfArrays img,
590
                  const std::vector<int>& params = std::vector<int>())
591
0
{
592
0
    return imwrite(filename, img, params);
593
0
}
Unexecuted instantiation: generateusergallerycollage_fuzzer.cc:cv::imwritemulti(std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> > const&, cv::_InputArray const&, std::__1::vector<int, std::__1::allocator<int> > const&)
Unexecuted instantiation: imread_fuzzer.cc:cv::imwritemulti(std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> > const&, cv::_InputArray const&, std::__1::vector<int, std::__1::allocator<int> > const&)
Unexecuted instantiation: imdecode_fuzzer.cc:cv::imwritemulti(std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> > const&, cv::_InputArray const&, std::__1::vector<int, std::__1::allocator<int> > const&)
Unexecuted instantiation: filestorage_read_string_fuzzer.cc:cv::imwritemulti(std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> > const&, cv::_InputArray const&, std::__1::vector<int, std::__1::allocator<int> > const&)
Unexecuted instantiation: filestorage_read_file_fuzzer.cc:cv::imwritemulti(std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> > const&, cv::_InputArray const&, std::__1::vector<int, std::__1::allocator<int> > const&)
Unexecuted instantiation: core_fuzzer.cc:cv::imwritemulti(std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> > const&, cv::_InputArray const&, std::__1::vector<int, std::__1::allocator<int> > const&)
Unexecuted instantiation: imencode_fuzzer.cc:cv::imwritemulti(std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> > const&, cv::_InputArray const&, std::__1::vector<int, std::__1::allocator<int> > const&)
Unexecuted instantiation: filestorage_read_filename_fuzzer.cc:cv::imwritemulti(std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> > const&, cv::_InputArray const&, std::__1::vector<int, std::__1::allocator<int> > const&)
594
595
/** @brief Reads an image from a buffer in memory.
596
597
The function imdecode reads an image from the specified buffer in the memory. If the buffer is too short or
598
contains invalid data, the function returns an empty matrix ( Mat::data==NULL ).
599
600
See cv::imread for the list of supported formats and flags description.
601
602
@note In the case of color images, the decoded images will have the channels stored in **B G R** order.
603
@param buf Input array or vector of bytes.
604
@param flags Flag that can take values of cv::ImreadModes.
605
*/
606
CV_EXPORTS_W Mat imdecode( InputArray buf, int flags );
607
608
/** @brief Reads an image from a memory buffer and extracts associated metadata.
609
610
This function decodes an image from the specified memory buffer. If the buffer is too short or
611
contains invalid data, the function returns an empty matrix ( Mat::data==NULL ).
612
613
See cv::imread for the list of supported formats and flags description.
614
615
@note In the case of color images, the decoded images will have the channels stored in **B G R** order.
616
@param buf Input array or vector of bytes containing the encoded image data.
617
@param metadataTypes Output vector with types of metadata chucks returned in metadata, see cv::ImageMetadataType
618
@param metadata Output vector of vectors or vector of matrices to store the retrieved metadata
619
@param flags Flag that can take values of cv::ImreadModes, default with cv::IMREAD_ANYCOLOR.
620
621
@return The decoded image as a cv::Mat object. If decoding fails, the function returns an empty matrix.
622
*/
623
CV_EXPORTS_W Mat imdecodeWithMetadata( InputArray buf, CV_OUT std::vector<int>& metadataTypes,
624
                                       OutputArrayOfArrays metadata, int flags = IMREAD_ANYCOLOR );
625
626
/** @overload
627
@param buf Input array or vector of bytes.
628
@param flags Flag that can take values of cv::ImreadModes, default with cv::IMREAD_ANYCOLOR.
629
@param dst The optional output placeholder for the decoded matrix. It can save the image
630
reallocations when the function is called repeatedly for images of the same size. In case of decoder
631
failure the function returns empty cv::Mat object, but does not release user-provided dst buffer.
632
*/
633
CV_EXPORTS Mat imdecode( InputArray buf, int flags, Mat* dst);
634
635
/** @brief Reads a multi-page image from a buffer in memory.
636
637
The function imdecodemulti reads a multi-page image from the specified buffer in the memory. If the buffer is too short or
638
contains invalid data, the function returns false.
639
640
See cv::imreadmulti for the list of supported formats and flags description.
641
642
@note In the case of color images, the decoded images will have the channels stored in **B G R** order.
643
@param buf Input array or vector of bytes.
644
@param flags Flag that can take values of cv::ImreadModes.
645
@param mats A vector of Mat objects holding each page, if more than one.
646
@param range A continuous selection of pages.
647
*/
648
CV_EXPORTS_W bool imdecodemulti(InputArray buf, int flags, CV_OUT std::vector<Mat>& mats, const cv::Range& range = Range::all());
649
650
/** @brief Encodes an image into a memory buffer.
651
652
The function imencode compresses the image and stores it in the memory buffer that is resized to fit the
653
result. See cv::imwrite for the list of supported formats and flags description.
654
655
@param ext File extension that defines the output format. Must include a leading period.
656
@param img Image to be compressed.
657
@param buf Output buffer resized to fit the compressed image.
658
@param params Format-specific parameters. See cv::imwrite and cv::ImwriteFlags.
659
*/
660
CV_EXPORTS_W bool imencode( const String& ext, InputArray img,
661
                            CV_OUT std::vector<uchar>& buf,
662
                            const std::vector<int>& params = std::vector<int>());
663
664
/** @brief Encodes an image into a memory buffer.
665
666
The function imencode compresses the image and stores it in the memory buffer that is resized to fit the
667
result. See cv::imwrite for the list of supported formats and flags description.
668
669
@param ext File extension that defines the output format. Must include a leading period.
670
@param img Image to be compressed.
671
@param metadataTypes Vector with types of metadata chucks stored in metadata to write, see ImageMetadataType.
672
@param metadata Vector of vectors or vector of matrices with chunks of metadata to store into the file
673
@param buf Output buffer resized to fit the compressed image.
674
@param params Format-specific parameters. See cv::imwrite and cv::ImwriteFlags.
675
*/
676
CV_EXPORTS_W bool imencodeWithMetadata( const String& ext, InputArray img,
677
                                        const std::vector<int>& metadataTypes,
678
                                        InputArrayOfArrays metadata,
679
                                        CV_OUT std::vector<uchar>& buf,
680
                                        const std::vector<int>& params = std::vector<int>());
681
682
/** @brief Encodes array of images into a memory buffer.
683
684
The function is analog to cv::imencode for in-memory multi-page image compression.
685
See cv::imwrite for the list of supported formats and flags description.
686
687
@param ext File extension that defines the output format. Must include a leading period.
688
@param imgs Vector of images to be written.
689
@param buf Output buffer resized to fit the compressed data.
690
@param params Format-specific parameters. See cv::imwrite and cv::ImwriteFlags.
691
*/
692
CV_EXPORTS_W bool imencodemulti( const String& ext, InputArrayOfArrays imgs,
693
                                 CV_OUT std::vector<uchar>& buf,
694
                                 const std::vector<int>& params = std::vector<int>());
695
696
/** @brief Checks if the specified image file can be decoded by OpenCV.
697
698
The function haveImageReader checks if OpenCV is capable of reading the specified file.
699
This can be useful for verifying support for a given image format before attempting to load an image.
700
701
@param filename The name of the file to be checked.
702
@return true if an image reader for the specified file is available and the file can be opened, false otherwise.
703
704
@note The function checks the availability of image codecs that are either built into OpenCV or dynamically loaded.
705
It does not load the image codec implementation and decode data, but uses signature check.
706
If the file cannot be opened or the format is unsupported, the function will return false.
707
708
@sa cv::haveImageWriter, cv::imread, cv::imdecode
709
*/
710
CV_EXPORTS_W bool haveImageReader( const String& filename );
711
712
/** @brief Checks if the specified image file or specified file extension can be encoded by OpenCV.
713
714
The function haveImageWriter checks if OpenCV is capable of writing images with the specified file extension.
715
This can be useful for verifying support for a given image format before attempting to save an image.
716
717
@param filename The name of the file or the file extension (e.g., ".jpg", ".png").
718
It is recommended to provide the file extension rather than the full file name.
719
@return true if an image writer for the specified extension is available, false otherwise.
720
721
@note The function checks the availability of image codecs that are either built into OpenCV or dynamically loaded.
722
It does not check for the actual existence of the file but rather the ability to write files of the given type.
723
724
@sa cv::haveImageReader, cv::imwrite, cv::imencode
725
*/
726
CV_EXPORTS_W bool haveImageWriter( const String& filename );
727
728
/** @brief To read multi-page images on demand
729
730
The ImageCollection class provides iterator API to read multi-page images on demand. Create iterator
731
to the collection of the images and iterate over the collection. Decode the necessary page with operator*.
732
733
The performance of page decoding is O(1) if collection is increment sequentially. If the user wants to access random page,
734
then the time Complexity is O(n) because the collection has to be reinitialized every time in order to go to the correct page.
735
However, the intermediate pages are not decoded during the process, so typically it's quite fast.
736
This is required because multi-page codecs does not support going backwards.
737
After decoding the one page, it is stored inside the collection cache. Hence, trying to get Mat object from already decoded page is O(1).
738
If you need memory, you can use .releaseCache() method to release cached index.
739
The space complexity is O(n) if all pages are decoded into memory. The user is able to decode and release images on demand.
740
*/
741
class CV_EXPORTS ImageCollection {
742
public:
743
    struct CV_EXPORTS iterator {
744
        iterator(ImageCollection* col);
745
        iterator(ImageCollection* col, int end);
746
        Mat& operator*();
747
        Mat* operator->();
748
        iterator& operator++();
749
        iterator operator++(int);
750
0
        friend bool operator== (const iterator& a, const iterator& b) { return a.m_curr == b.m_curr; }
751
0
        friend bool operator!= (const iterator& a, const iterator& b) { return a.m_curr != b.m_curr; }
752
753
    private:
754
        ImageCollection* m_pCollection;
755
        int m_curr;
756
    };
757
758
    ImageCollection();
759
    ImageCollection(const String& filename, int flags);
760
    void init(const String& img, int flags);
761
    size_t size() const;
762
    const Mat& at(int index);
763
    const Mat& operator[](int index);
764
    void releaseCache(int index);
765
    iterator begin();
766
    iterator end();
767
768
    class Impl;
769
    Ptr<Impl> getImpl();
770
protected:
771
    Ptr<Impl> pImpl;
772
};
773
774
//! @} imgcodecs
775
776
} // cv
777
778
#endif //OPENCV_IMGCODECS_HPP