Zivid C++ API 2.18.0+1b44dbef-1
Application.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// Warning: Enabling ZIVID_ALLOW_UNSAFE_MT is very likely to cause problems such as crashes and is not recommended.
47#ifndef ZIVID_ALLOW_UNSAFE_MT
48# if defined _WIN32 && !defined _DLL
49# error "Zivid SDK only supports the DLL version of the Visual Studio runtime library. \
50To switch from static runtime linkage to dynamic, use the /MD or /MDd flags \
51instead of /MT or /MTd in your project's C/C++ Code Generation settings."
52# endif
53#endif
54
55// Warning: Enabling ZIVID_ALLOW_UNSUPPORTED_MSVC_COMPILER is very likely to cause problems such as crashes and is not
56// recommended.
57#ifndef ZIVID_ALLOW_UNSUPPORTED_MSVC_COMPILER
58# if defined _MSC_VER && _MSC_VER < 1920
59# error "Zivid SDK only supports compiling with Visual Studio 2019 and later versions. \
60Please upgrade your local build tools accordingly."
61# endif
62#endif
63
64#ifdef _MSC_VER
65# if _MSVC_LANG < 201703L
66# error "Zivid C++ API requires that you use C++17 or newer. The C++ version you are using is too old. \
67For Visual Studio you may need to set a newer C++ version in the Project Settings, or via the /std compiler option."
68# endif
69#elif __cplusplus < 201703L
70# error "Zivid C++ API requires that you use C++17 or newer. The C++ version you are using is too old. \
71If you are using CMake, you can configure C++17 by adding `set(CMAKE_CXX_STANDARD 17)` to your CMakeLists.txt file."
72#endif
73
74#include "Zivid/Camera.h"
75#include "Zivid/CameraAddress.h"
76#include "Zivid/ComputeDevice.h"
79#include "Zivid/Detail/Pimpl.h"
81#include "Zivid/Version.h"
82
84namespace Zivid
85{
86 class SerialNumber;
87
99 class Application
100 {
102
103 private:
104 ZIVID_CORE_EXPORT Application(const std::string &headerVersion);
106 const std::string &headerVersion,
109 OpenCLContextPtr openclContext = {},
110 CUDAContextPtr cudaContext = {});
111
115 OpenCLContextPtr openclContext,
116 CUDAContextPtr cudaContext);
117
119 : Application(ZIVID_CORE_VERSION, Detail::detectToolchain(), wrapper)
120 {}
121
122 public:
151 : Application{ Detail::EnvironmentInfo::Wrapper{ Detail::EnvironmentInfo::Wrapper::ValueType::none } }
152 {}
153
164 explicit Application(OpenCLContextPtr openclContext)
165 : Application(
167 Detail::detectToolchain(),
168 Detail::EnvironmentInfo::Wrapper{ Detail::EnvironmentInfo::Wrapper::ValueType::none },
169 openclContext,
170 {})
171 {}
172
183 explicit Application(CUDAContextPtr cudaContext)
184 : Application(
186 Detail::detectToolchain(),
187 Detail::EnvironmentInfo::Wrapper{ Detail::EnvironmentInfo::Wrapper::ValueType::none },
188 {},
189 cudaContext)
190 {}
191
198
203
215
250 ZIVID_CORE_EXPORT Camera createFileCamera(const Frame &frameWithDiagnostics);
251
261 ZIVID_CORE_EXPORT Camera createFileCamera(const std::string &cameraFile);
262
271 ZIVID_CORE_EXPORT std::vector<Camera> cameras();
272
276
279 ZIVID_CORE_EXPORT std::string toString() const;
280 };
281
282} // namespace Zivid
283
#define ZIVID_CORE_EXPORT
Definition CoreExport.h:56
#define ZIVID_PIMPL_MOVE_ONLY(ClassName, Attributes)
Definition Pimpl.h:110
#define ZIVID_CORE_VERSION
Zivid version string.
Definition VersionConstants.h:59
ZIVID_CORE_EXPORT Camera createFileCamera(const std::string &cameraFile)
Create a virtual camera to simulate Zivid measurements by reading data from a file.
ZIVID_CORE_EXPORT Camera connectCamera()
Connect to the next available Zivid camera.
ZIVID_CORE_EXPORT Camera connectCamera(const CameraAddress &address)
Connect to the Zivid camera at the specified network address.
friend Application Detail::createApplicationForWrapper(Zivid::Detail::EnvironmentInfo::Wrapper wrapper)
Application(CUDAContextPtr cudaContext)
Constructor with user-provided CUDA context.
Definition Application.h:183
ZIVID_CORE_EXPORT Camera createFileCamera(const Frame &frameWithDiagnostics)
Create a file camera from a captured frame.
ZIVID_CORE_EXPORT ComputeDevice computeDevice() const
The default compute device, used when connecting to new cameras.
ZIVID_CORE_EXPORT Camera connectCamera(const CameraInfo::SerialNumber &serialNumber)
Connect to the Zivid camera with the specified serial number.
ZIVID_CORE_EXPORT std::string toString() const
Get string representation of the application.
Application()
Constructor.
Definition Application.h:150
Application(OpenCLContextPtr openclContext)
Constructor with user-provided OpenCL context.
Definition Application.h:164
ZIVID_CORE_EXPORT std::vector< Camera > cameras()
Get a list of all cameras.
A hostname or IPv4 address identifying a specific Zivid camera for direct connection.
Definition CameraAddress.h:55
The serial number of the camera.
Definition CameraInfo.h:975
Interface to one Zivid camera.
Definition Camera.h:71
Contains information about the compute device used by Zivid::Application.
Definition ComputeDevice.h:60
Information about the current toolchain.
Definition EnvironmentInfo.h:1289
The wrapper being used, if any.
Definition EnvironmentInfo.h:2633
A frame captured by a Zivid camera.
Definition Frame.h:70
Definition EnvironmentInfo.h:74
The main Zivid namespace. All Zivid code is found here.
Definition Application.h:85
Wrapper for user-provided CUDA context pointer (CUcontext)
Definition ComputeWrappers.h:65
Wrapper for user-provided OpenCL context pointer (cl_context)
Definition ComputeWrappers.h:59