gucoordinates
CartesianCoordinate.hpp
Go to the documentation of this file.
1/*
2 * CartesianCoordinate.hpp
3 * gucoordinates
4 *
5 * Created by Callum McColl on 21/06/2020.
6 * Copyright © 2020 Callum McColl. All rights reserved.
7 *
8 * Redistribution and use in source and binary forms, with or without
9 * modification, are permitted provided that the following conditions
10 * are met:
11 *
12 * 1. Redistributions of source code must retain the above copyright
13 * notice, this list of conditions and the following disclaimer.
14 *
15 * 2. Redistributions in binary form must reproduce the above
16 * copyright notice, this list of conditions and the following
17 * disclaimer in the documentation and/or other materials
18 * provided with the distribution.
19 *
20 * 3. All advertising materials mentioning features or use of this
21 * software must display the following acknowledgement:
22 *
23 * This product includes software developed by Callum McColl.
24 *
25 * 4. Neither the name of the author nor the names of contributors
26 * may be used to endorse or promote products derived from this
27 * software without specific prior written permission.
28 *
29 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
30 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
31 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
32 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER
33 * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
34 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
35 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES NOEXCEPT; LOSS OF USE, DATA, OR
36 * PROFITS NOEXCEPT; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
37 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
38 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
39 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
40 *
41 * -----------------------------------------------------------------------
42 * This program is free software NOEXCEPT; you can redistribute it and/or
43 * modify it under the above terms or under the terms of the GNU
44 * General Public License as published by the Free Software Foundation NOEXCEPT;
45 * either version 2 of the License, or (at your option) any later version.
46 *
47 * This program is distributed in the hope that it will be useful,
48 * but WITHOUT ANY WARRANTY NOEXCEPT; without even the implied warranty of
49 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
50 * GNU General Public License for more details.
51 *
52 * You should have received a copy of the GNU General Public License
53 * along with this program NOEXCEPT; if not, see http://www.gnu.org/licenses/
54 * or write to the Free Software Foundation, Inc., 51 Franklin Street,
55 * Fifth Floor, Boston, MA 02110-1301, USA.
56 *
57 */
58
59#ifndef CARTESIANCOORDINATE_HPP
60#define CARTESIANCOORDINATE_HPP
61
63
64#include <cstdlib>
65#include <guunits/guunits.h>
66#include "CameraCoordinate.hpp"
67#include "PixelCoordinate.hpp"
68#include "PercentCoordinate.hpp"
70#include "FieldCoordinate.hpp"
71#include "CameraPivot.hpp"
72
78
79#if __cplusplus >= 201703L
80#include <optional>
81#endif
82
83#include <gu_util.h>
84
85namespace GU {
86
87 struct CameraCoordinate;
88 struct PixelCoordinate;
89 struct PercentCoordinate;
90 struct RelativeCoordinate;
91 struct FieldCoordinate;
92
94
95 CartesianCoordinate() NOEXCEPT;
96 CartesianCoordinate(centimetres_t, centimetres_t) NOEXCEPT;
97 CartesianCoordinate(const CartesianCoordinate& other) NOEXCEPT;
98 CartesianCoordinate(const gu_cartesian_coordinate& other) NOEXCEPT;
99#if __cplusplus >= 201103L
100#pragma clang diagnostic push
101#pragma clang diagnostic ignored "-Wc++98-compat"
104#pragma clang diagnostic pop
105#endif
106 ~CartesianCoordinate() NOEXCEPT;
107 CartesianCoordinate& operator=(const CartesianCoordinate& other) NOEXCEPT;
109#if __cplusplus >= 201103L
110#pragma clang diagnostic push
111#pragma clang diagnostic ignored "-Wc++98-compat"
114#pragma clang diagnostic pop
115#endif
116
120
121 CartesianCoordinate cartesianCoordinateAt(const GU::CameraCoordinate &, const GU::CameraPivot &, const int) const NOEXCEPT;
122 CartesianCoordinate cartesianCoordinateAt(const GU::PixelCoordinate &, const GU::CameraPivot &, const int) const NOEXCEPT;
123 CartesianCoordinate cartesianCoordinateAt(const GU::PercentCoordinate &, const GU::CameraPivot &, const int) const NOEXCEPT;
124
125 CameraCoordinate cameraCoordinateTo(const GU::CartesianCoordinate &, const GU::CameraPivot &, const int, const pixels_u, const pixels_u) const NOEXCEPT;
126 CameraCoordinate cameraCoordinateTo(const GU::FieldCoordinate &, const GU::CameraPivot &, const int, const pixels_u, const pixels_u) const NOEXCEPT;
127 PixelCoordinate pixelCoordinateTo(const GU::CartesianCoordinate &, const GU::CameraPivot &, const int, const pixels_u, const pixels_u) const NOEXCEPT;
128 PixelCoordinate pixelCoordinateTo(const GU::FieldCoordinate &, const GU::CameraPivot &, const int, const pixels_u, const pixels_u) const NOEXCEPT;
129 PercentCoordinate percentCoordinateTo(const GU::CartesianCoordinate &, const GU::CameraPivot &, const int) const NOEXCEPT;
130 PercentCoordinate percentCoordinateTo(const GU::FieldCoordinate &, const GU::CameraPivot &, const int) const NOEXCEPT;
131
132 CameraCoordinate clampedCameraCoordinateTo(const GU::CartesianCoordinate &, const GU::CameraPivot &, const int, const pixels_u, const pixels_u) const NOEXCEPT;
133 CameraCoordinate clampedCameraCoordinateTo(const GU::FieldCoordinate &, const GU::CameraPivot &, const int, const pixels_u, const pixels_u) const NOEXCEPT;
134 PixelCoordinate clampedPixelCoordinateTo(const GU::CartesianCoordinate &, const GU::CameraPivot &, const int, const pixels_u, const pixels_u) const NOEXCEPT;
135 PixelCoordinate clampedPixelCoordinateTo(const GU::FieldCoordinate &, const GU::CameraPivot &, const int, const pixels_u, const pixels_u) const NOEXCEPT;
137 PercentCoordinate clampedPercentCoordinateTo(const GU::FieldCoordinate &, const GU::CameraPivot &, const int) const NOEXCEPT;
138
139 centimetres_t x() const NOEXCEPT;
140 void set_x(const centimetres_t) NOEXCEPT;
141
142 centimetres_t y() const NOEXCEPT;
143 void set_y(const centimetres_t) NOEXCEPT;
144
145 bool operator ==(const CartesianCoordinate &other) const NOEXCEPT;
146 bool operator !=(const CartesianCoordinate &other) const NOEXCEPT;
147 bool operator ==(const gu_cartesian_coordinate &other) const NOEXCEPT;
148 bool operator !=(const gu_cartesian_coordinate &other) const NOEXCEPT;
149
150 };
151
152}
153
154#endif /* CARTESIANCOORDINATE_HPP */
Definition: Camera.hpp:66
PercentCoordinate clampedPercentCoordinateTo(const GU::CartesianCoordinate &, const GU::CameraPivot &, const int) const NOEXCEPT
bool operator!=(const CartesianCoordinate &other) const NOEXCEPT
centimetres_t x() const NOEXCEPT
CartesianCoordinate cartesianCoordinateAt(const GU::RelativeCoordinate &) const NOEXCEPT
bool operator==(const CartesianCoordinate &other) const NOEXCEPT
PixelCoordinate clampedPixelCoordinateTo(const GU::CartesianCoordinate &, const GU::CameraPivot &, const int, const pixels_u, const pixels_u) const NOEXCEPT
CartesianCoordinate & operator=(const CartesianCoordinate &other) NOEXCEPT
centimetres_t y() const NOEXCEPT
PercentCoordinate percentCoordinateTo(const GU::CartesianCoordinate &, const GU::CameraPivot &, const int) const NOEXCEPT
CameraCoordinate cameraCoordinateTo(const GU::CartesianCoordinate &, const GU::CameraPivot &, const int, const pixels_u, const pixels_u) const NOEXCEPT
CameraCoordinate clampedCameraCoordinateTo(const GU::CartesianCoordinate &, const GU::CameraPivot &, const int, const pixels_u, const pixels_u) const NOEXCEPT
RelativeCoordinate relativeCoordinateTo(const GU::CartesianCoordinate &) const NOEXCEPT
void set_y(const centimetres_t) NOEXCEPT
PixelCoordinate pixelCoordinateTo(const GU::CartesianCoordinate &, const GU::CameraPivot &, const int, const pixels_u, const pixels_u) const NOEXCEPT
void set_x(const centimetres_t) NOEXCEPT
A cartesian_coordinate is a general coordinate for representing positions on a tow dimensional plane.