Zivid C++ API 2.10.1+50b274e8-7
Defining the Future of 3D Machine Vision
Image.h
Go to the documentation of this file.
1
2
3/*******************************************************************************
4
5 * This file is part of the Zivid 3D Camera API
6
7 *
8
9 * Copyright 2015-2023 (C) Zivid AS
10
11 * All rights reserved.
12
13 *
14
15 * Zivid Software License, v1.0
16
17 *
18
19 * Redistribution and use in source and binary forms, with or without
20
21 * modification, are permitted provided that the following conditions are met:
22
23 *
24
25 * 1. Redistributions of source code must retain the above copyright notice,
26
27 * this list of conditions and the following disclaimer.
28
29 *
30
31 * 2. Redistributions in binary form must reproduce the above copyright notice,
32
33 * this list of conditions and the following disclaimer in the documentation
34
35 * and/or other materials provided with the distribution.
36
37 *
38
39 * 3. Neither the name of Zivid AS nor the names of its contributors may be used
40
41 * to endorse or promote products derived from this software without specific
42
43 * prior written permission.
44
45 *
46
47 * 4. This software, with or without modification, must not be used with any
48
49 * other 3D camera than from Zivid AS.
50
51 *
52
53 * 5. Any software provided in binary form under this license must not be
54
55 * reverse engineered, decompiled, modified and/or disassembled.
56
57 *
58
59 * THIS SOFTWARE IS PROVIDED BY ZIVID AS "AS IS" AND ANY EXPRESS OR IMPLIED
60
61 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
62
63 * MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE
64
65 * DISCLAIMED. IN NO EVENT SHALL ZIVID AS OR CONTRIBUTORS BE LIABLE FOR ANY
66
67 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
68
69 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
70
71 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
72
73 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
74
75 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
76
77 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
78
79 *
80
81 * Contact: Zivid Customer Success Team <customersuccess@zivid.com>
82
83 * Info: http://www.zivid.com
84
85 ******************************************************************************/
86
87
88
89#pragma once
90
91#include "Zivid/Array2D.h"
92#include "Zivid/Color.h"
94
95#include <string>
96#include <type_traits>
97
98namespace Zivid
99{
100#ifndef NO_DOC
102 namespace Detail
103 {
104 ZIVID_CORE_EXPORT void saveImageImpl(const Zivid::Array2D<ColorRGBA> &img, const std::string &fileName);
105 ZIVID_CORE_EXPORT void saveImageImpl(const Zivid::Array2D<ColorBGRA> &img, const std::string &fileName);
106 } // namespace Detail
107#endif
113 template<class PixelFormat>
114 class Image : public Array2D<PixelFormat>
115 {
116 public:
117 static_assert(
118 std::is_same<PixelFormat, Zivid::ColorRGBA>::value || std::is_same<PixelFormat, Zivid::ColorBGRA>::value,
119 "PixelFormat must be Zivid::ColorRGBA or Zivid::ColorBGRA.");
120
122 Image() = default;
123
125 template<typename Iterator>
126 Image(const Resolution &resolution, Iterator beginIt, Iterator endIt)
127 : Array2D<PixelFormat>(resolution, beginIt, endIt)
128 {}
129
143 Image(const Resolution &resolution, const unsigned char *begin, const unsigned char *end)
144 : Array2D<PixelFormat>{ resolution, begin, end }
145 {}
146
149 void save(const std::string &fileName) const
150 {
151 return Detail::saveImageImpl(*this, fileName);
152 }
153
154#ifndef NO_DOC
155 explicit Image(Array2D<PixelFormat> &&a)
156 : Array2D<PixelFormat>(std::move(a))
157 {}
158#endif
159 };
160} // namespace Zivid
#define ZIVID_CORE_EXPORT
Definition: CoreExport.h:101
Two-dimensional container of data
Definition: Array2D.h:128
ConstIterator end() const
Iterator to the end of the array
Definition: Array2D.h:208
ConstIterator begin() const
Iterator to the beginning of the array
Definition: Array2D.h:202
A 2-dimensional image
Definition: Image.h:115
void save(const std::string &fileName) const
Save the image to a file. The supported file types are PNG (.png), JPEG (.jpg, .jpeg) and BMP (....
Definition: Image.h:149
Image(const Resolution &resolution, const unsigned char *begin, const unsigned char *end)
Create an image from an unsigned char byte buffer
Definition: Image.h:143
Image()=default
Create an empty image
Image(const Resolution &resolution, Iterator beginIt, Iterator endIt)
Create an image from a buffer of elements by copy
Definition: Image.h:126
Class describing a given resolution
Definition: Resolution.h:101
ZIVID_CORE_EXPORT Resolution resolution(const CameraInfo &cameraInfo, const Settings &settings)
The main Zivid namespace. All Zivid code is found here
Definition: Application.h:99