Zivid C++ API 2.18.0+1b44dbef-1
BoundingBox.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
47
48#include <ostream>
49#include <string>
50
51namespace Zivid
52{
57 {
59 using ValueType = int;
60
62 BoundingBox() = default;
63
65 constexpr BoundingBox(int xCoord, int yCoord, int boxWidth, int boxHeight)
66 : x{ xCoord }
67 , y{ yCoord }
68 , width{ boxWidth }
69 , height{ boxHeight }
70 {}
71
80
82 ZIVID_UTILS_EXPORT std::string toString() const;
83
86
89 };
90
92 ZIVID_UTILS_EXPORT std::ostream &operator<<(std::ostream &stream, const BoundingBox &boundingBox);
93
94} // namespace Zivid
#define ZIVID_UTILS_EXPORT
Definition UtilsExport.h:56
The main Zivid namespace. All Zivid code is found here.
Definition Application.h:85
std::ostream & operator<<(std::ostream &stream, const Array1D< T > &array)
Serialize array information to a stream.
Definition Array1D.h:183
Defines a 2D rectangular bounding box in image coordinates.
Definition BoundingBox.h:57
ZIVID_UTILS_EXPORT std::string toString() const
Get string representation.
constexpr BoundingBox(int xCoord, int yCoord, int boxWidth, int boxHeight)
Constructor.
Definition BoundingBox.h:65
int ValueType
The type of the coordinate values.
Definition BoundingBox.h:59
ValueType width
Width of the bounding box.
Definition BoundingBox.h:77
ValueType x
Top-left corner x coordinate.
Definition BoundingBox.h:73
ValueType y
Top-left corner y coordinate.
Definition BoundingBox.h:75
ValueType height
Height of the bounding box.
Definition BoundingBox.h:79
BoundingBox()=default
ZIVID_UTILS_EXPORT bool operator==(const BoundingBox &rhs) const
Check for equality.
ZIVID_UTILS_EXPORT bool operator!=(const BoundingBox &rhs) const
Check for inequality.