Zivid C++ API 2.18.0+1b44dbef-1
SettingsInfo.h
Go to the documentation of this file.
1/*******************************************************************************
2 * This file is part of the Zivid API
3 *
4 * Copyright 2015-2026 (C) Zivid AS
5 * All rights reserved.
6 *
7 * Zivid Software License, v1.0
8 *
9 * Redistribution and use in source and binary forms, with or without
10 * modification, are permitted provided that the following conditions are met:
11 *
12 * 1. Redistributions of source code must retain the above copyright notice,
13 * this list of conditions and the following disclaimer.
14 *
15 * 2. Redistributions in binary form must reproduce the above copyright notice,
16 * this list of conditions and the following disclaimer in the documentation
17 * and/or other materials provided with the distribution.
18 *
19 * 3. Neither the name of Zivid AS nor the names of its contributors may be used
20 * to endorse or promote products derived from this software without specific
21 * prior written permission.
22 *
23 * 4. This software, with or without modification, must not be used with any
24 * other 3D camera than from Zivid AS.
25 *
26 * 5. Any software provided in binary form under this license must not be
27 * reverse engineered, decompiled, modified and/or disassembled.
28 *
29 * THIS SOFTWARE IS PROVIDED BY ZIVID AS "AS IS" AND ANY EXPRESS OR IMPLIED
30 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
31 * MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE
32 * DISCLAIMED. IN NO EVENT SHALL ZIVID AS OR CONTRIBUTORS BE LIABLE FOR ANY
33 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
34 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
35 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
36 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
37 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
38 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
39 *
40 * Contact: Zivid Customer Success Team <customersuccess@zivid.com>
41 * Info: http://www.zivid.com
42 ******************************************************************************/
43
44#pragma once
45
46#include <Zivid/CameraInfo.h>
49#include <Zivid/Range.h>
50#include <Zivid/Resolution.h>
51#include <Zivid/Settings.h>
52#include <Zivid/Settings2D.h>
53
54#define ZIVID_DETAIL_CAMERA_DEFAULT_VALUE(T) ZIVID_CORE_EXPORT T defaultValue(Tag<T> tag, const CameraInfo &cameraInfo)
55
56#define ZIVID_DETAIL_CAMERA_VALID_VALUES(T) \
57 ZIVID_DETAIL_CAMERA_DEFAULT_VALUE(T); \
58 ZIVID_CORE_EXPORT std::set<T::ValueType> validValues(Tag<T> tag, const CameraInfo &cameraInfo)
59
60#define ZIVID_DETAIL_CAMERA_VALID_RANGE(T) \
61 ZIVID_DETAIL_CAMERA_DEFAULT_VALUE(T); \
62 ZIVID_CORE_EXPORT Range<T::ValueType> validRange(Tag<T> tag, const CameraInfo &cameraInfo)
63
64namespace Zivid
65{
66#ifndef NO_DOC
68 namespace Detail
69 {
70 template<typename T>
71 using Tag = TypeTraits::TypeIdentity<T>;
72
73 ZIVID_DETAIL_CAMERA_DEFAULT_VALUE(Settings::Color);
74 ZIVID_DETAIL_CAMERA_DEFAULT_VALUE(Settings::Acquisitions);
75 ZIVID_DETAIL_CAMERA_DEFAULT_VALUE(Settings::Processing::Filters::Reflection::Removal::Mode);
76 ZIVID_DETAIL_CAMERA_DEFAULT_VALUE(Settings::RegionOfInterest::Box::Extents);
77 ZIVID_DETAIL_CAMERA_DEFAULT_VALUE(Settings::RegionOfInterest::Box::PointO);
78 ZIVID_DETAIL_CAMERA_DEFAULT_VALUE(Settings::RegionOfInterest::Box::PointA);
79 ZIVID_DETAIL_CAMERA_DEFAULT_VALUE(Settings::RegionOfInterest::Box::PointB);
80 ZIVID_DETAIL_CAMERA_DEFAULT_VALUE(Settings::RegionOfInterest::Depth::Range);
81 ZIVID_DETAIL_CAMERA_DEFAULT_VALUE(Settings2D::Acquisitions);
82
83 ZIVID_DETAIL_CAMERA_VALID_RANGE(Settings::Acquisition::Aperture);
84 ZIVID_DETAIL_CAMERA_VALID_RANGE(Settings::Acquisition::Brightness);
85 ZIVID_DETAIL_CAMERA_VALID_RANGE(Settings::Acquisition::ExposureTime);
86 ZIVID_DETAIL_CAMERA_VALID_RANGE(Settings::Acquisition::Gain);
87 ZIVID_DETAIL_CAMERA_VALID_RANGE(Settings::Processing::Color::Balance::Blue);
88 ZIVID_DETAIL_CAMERA_VALID_RANGE(Settings::Processing::Color::Balance::Green);
89 ZIVID_DETAIL_CAMERA_VALID_RANGE(Settings::Processing::Color::Balance::Red);
90 ZIVID_DETAIL_CAMERA_VALID_RANGE(Settings::Processing::Color::Gamma);
92 Settings::Processing::Filters::Experimental::ContrastDistortion::Correction::Strength);
93 ZIVID_DETAIL_CAMERA_VALID_RANGE(Settings::Processing::Filters::Cluster::Removal::MinArea);
94 ZIVID_DETAIL_CAMERA_VALID_RANGE(Settings::Processing::Filters::Cluster::Removal::MaxNeighborDistance);
96 Settings::Processing::Filters::Experimental::ContrastDistortion::Removal::Threshold);
97 ZIVID_DETAIL_CAMERA_VALID_RANGE(Settings::Processing::Filters::Hole::Repair::Strictness);
98 ZIVID_DETAIL_CAMERA_VALID_RANGE(Settings::Processing::Filters::Hole::Repair::HoleSize);
99 ZIVID_DETAIL_CAMERA_VALID_RANGE(Settings::Processing::Filters::Noise::Removal::Threshold);
100 ZIVID_DETAIL_CAMERA_VALID_RANGE(Settings::Processing::Filters::Outlier::Removal::Threshold);
101 ZIVID_DETAIL_CAMERA_VALID_RANGE(Settings::Processing::Filters::Smoothing::Gaussian::Sigma);
102 ZIVID_DETAIL_CAMERA_VALID_RANGE(Settings2D::Acquisition::Aperture);
103 ZIVID_DETAIL_CAMERA_VALID_RANGE(Settings2D::Acquisition::Brightness);
104 ZIVID_DETAIL_CAMERA_VALID_RANGE(Settings2D::Acquisition::ExposureTime);
105 ZIVID_DETAIL_CAMERA_VALID_RANGE(Settings2D::Sampling::Interval::Duration);
106 ZIVID_DETAIL_CAMERA_VALID_VALUES(Settings2D::Sampling::Interval::Enabled);
107 ZIVID_DETAIL_CAMERA_VALID_RANGE(Settings2D::Acquisition::Gain);
108 ZIVID_DETAIL_CAMERA_VALID_RANGE(Settings2D::Processing::Color::Balance::Blue);
109 ZIVID_DETAIL_CAMERA_VALID_RANGE(Settings2D::Processing::Color::Balance::Green);
110 ZIVID_DETAIL_CAMERA_VALID_RANGE(Settings2D::Processing::Color::Balance::Red);
111 ZIVID_DETAIL_CAMERA_VALID_RANGE(Settings2D::Processing::Color::Gamma);
112 ZIVID_DETAIL_CAMERA_VALID_VALUES(Settings2D::Processing::Color::Experimental::Mode);
113 ZIVID_DETAIL_CAMERA_VALID_VALUES(Settings2D::Sampling::Pixel);
114 ZIVID_DETAIL_CAMERA_VALID_VALUES(Settings2D::Sampling::Color);
115 ZIVID_DETAIL_CAMERA_VALID_VALUES(Settings2D::Diagnostics::Enabled);
116
117 ZIVID_DETAIL_CAMERA_VALID_VALUES(Settings::Diagnostics::Enabled);
118 ZIVID_DETAIL_CAMERA_VALID_VALUES(Settings::Engine);
119 ZIVID_DETAIL_CAMERA_VALID_VALUES(Settings::Sampling::Pixel);
120 ZIVID_DETAIL_CAMERA_VALID_VALUES(Settings::Sampling::Color);
121 ZIVID_DETAIL_CAMERA_VALID_VALUES(Settings::Processing::Resampling::Mode);
122 ZIVID_DETAIL_CAMERA_VALID_VALUES(Settings::Processing::Color::Experimental::Mode);
124 Settings::Processing::Filters::Experimental::ContrastDistortion::Correction::Enabled);
125 ZIVID_DETAIL_CAMERA_VALID_VALUES(Settings::Processing::Filters::Cluster::Removal::Enabled);
127 Settings::Processing::Filters::Experimental::ContrastDistortion::Removal::Enabled);
128 ZIVID_DETAIL_CAMERA_VALID_VALUES(Settings::Processing::Filters::Hole::Repair::Enabled);
129 ZIVID_DETAIL_CAMERA_VALID_VALUES(Settings::Processing::Filters::Noise::Removal::Enabled);
130 ZIVID_DETAIL_CAMERA_VALID_VALUES(Settings::Processing::Filters::Noise::Suppression::Enabled);
131 ZIVID_DETAIL_CAMERA_VALID_VALUES(Settings::Processing::Filters::Noise::Repair::Enabled);
132 ZIVID_DETAIL_CAMERA_VALID_VALUES(Settings::Processing::Filters::Outlier::Removal::Enabled);
133 ZIVID_DETAIL_CAMERA_VALID_VALUES(Settings::Processing::Filters::Reflection::Removal::Enabled);
134 ZIVID_DETAIL_CAMERA_VALID_VALUES(Settings::Processing::Filters::Reflection::Removal::Mode);
135 ZIVID_DETAIL_CAMERA_VALID_VALUES(Settings::Processing::Filters::Smoothing::Gaussian::Enabled);
136 ZIVID_DETAIL_CAMERA_VALID_VALUES(Settings::RegionOfInterest::Depth::Enabled);
137 ZIVID_DETAIL_CAMERA_VALID_VALUES(Settings::RegionOfInterest::Box::Enabled);
138
139 class DefaultDataModelSetter
140 {
141 const CameraInfo &m_cameraInfo;
142
143 public:
144 DefaultDataModelSetter(const CameraInfo &cameraInfo)
145 : m_cameraInfo(cameraInfo)
146 {}
147
148 DefaultDataModelSetter(const DefaultDataModelSetter &) = delete;
149 DefaultDataModelSetter(DefaultDataModelSetter &&) = delete;
150 DefaultDataModelSetter &operator=(const DefaultDataModelSetter &) = delete;
151 DefaultDataModelSetter &operator=(DefaultDataModelSetter &&) = delete;
152
153 template<typename T>
154 void operator()(T &dataModelNode) const;
155 };
156
157 template<typename T, typename std::enable_if_t<T::nodeType == DataModel::NodeType::group, bool> = true>
158 T defaultValue(Tag<T> /* tag */, const CameraInfo &cameraInfo)
159 {
160 T group;
161 group.forEach(DefaultDataModelSetter(cameraInfo));
162 return group;
163 }
164
165 template<typename T>
166 void DefaultDataModelSetter::operator()(T &dataModelNode) const
167 {
168 dataModelNode = defaultValue(Tag<T>{}, m_cameraInfo);
169 }
170
171 ZIVID_CORE_EXPORT void validateSettings(const Settings &settings, const CameraInfo &cameraInfo);
172 ZIVID_CORE_EXPORT void validateSettings(const Settings2D &settings, const CameraInfo &cameraInfo);
173
174 template<typename SettingNode>
175 constexpr bool settingIsReprocessable()
176 {
177 static_assert(DataModel::Detail::IsDataModelType<SettingNode>::value);
178 return std::is_same_v<SettingNode, Settings::Processing>
179 || std::is_same_v<SettingNode, Settings2D::Processing>
180 || TypeTraits::IsInTuple<SettingNode, Settings::Processing::Descendants>::value
181 || TypeTraits::IsInTuple<SettingNode, Settings2D::Processing::Descendants>::value;
182 }
183
184 } // namespace Detail
185#endif
186
187 namespace Experimental
188 {
189 namespace SettingsInfo
190 {
191 template<typename T>
192 T defaultValue(const CameraInfo &cameraInfo)
193 {
194 return Zivid::Detail::defaultValue(Zivid::Detail::Tag<T>{}, cameraInfo);
195 }
196
197 template<typename T>
198 std::set<typename T::ValueType> validValues(const CameraInfo &cameraInfo)
199 {
200 return Zivid::Detail::validValues(Zivid::Detail::Tag<T>{}, cameraInfo);
201 }
202
203 template<typename T, typename Ret = Range<typename T::ValueType>>
204 Ret validRange(const CameraInfo &cameraInfo)
205 {
206 return Zivid::Detail::validRange(Zivid::Detail::Tag<T>{}, cameraInfo);
207 }
208
221 ZIVID_CORE_EXPORT Resolution resolution(const CameraInfo &cameraInfo, const Settings &settings);
222
237 ZIVID_CORE_EXPORT Resolution resolution2D(const CameraInfo &cameraInfo, const Settings &settings);
238
245 ZIVID_CORE_EXPORT Resolution resolution2D(const CameraInfo &cameraInfo, const Settings2D &settings);
246 } // namespace SettingsInfo
247 } // namespace Experimental
248} // namespace Zivid
#define ZIVID_CORE_EXPORT
Definition CoreExport.h:56
#define ZIVID_DETAIL_CAMERA_VALID_RANGE(T)
Definition SettingsInfo.h:60
#define ZIVID_DETAIL_CAMERA_DEFAULT_VALUE(T)
Definition SettingsInfo.h:54
#define ZIVID_DETAIL_CAMERA_VALID_VALUES(T)
Definition SettingsInfo.h:56
Information about camera model, serial number etc.
Definition CameraInfo.h:78
Class describing a resolution with a width and a height.
Definition Resolution.h:56
Settings used when capturing 2D images with a Zivid camera.
Definition Settings2D.h:79
Settings used when capturing a 3D capture or 2D+3D capture with a Zivid camera.
Definition Settings.h:81
Definition SettingsInfo.h:190
ZIVID_CORE_EXPORT Resolution resolution2D(const CameraInfo &cameraInfo, const Settings &settings)
Returns the resolution of a 2D frame according to the provided camera information and settings.
T defaultValue(const CameraInfo &cameraInfo)
Definition SettingsInfo.h:192
ZIVID_CORE_EXPORT Resolution resolution(const CameraInfo &cameraInfo, const Settings &settings)
Returns the resolution of captured frames according to the provided camera information and settings.
Ret validRange(const CameraInfo &cameraInfo)
Definition SettingsInfo.h:204
std::set< typename T::ValueType > validValues(const CameraInfo &cameraInfo)
Definition SettingsInfo.h:198
The main Zivid namespace. All Zivid code is found here.
Definition Application.h:85