mirror of
https://github.com/OpenSpace/OpenSpace.git
synced 2026-05-18 01:56:26 -05:00
4952f8f977
* Make height map fallback layer work again * Add documentation to joystick button bindings * Removed grouped property headers * Add new version number constant generated by CMake * Make Joystick deadzone work properly * Change the startup date on Earth to today * Fix key modifier handling * Add debugging indices for TreeNodeDebugging * Fix script schedule for OsirisRex * Do not open Mission schedule automatically * Upload default projection texture automatically * General code cleanup * Fix check_style_guide warnings * Remove .clang-format * MacOS compile fixes * Clang analyzer fixes
206 lines
7.1 KiB
C++
206 lines
7.1 KiB
C++
/*****************************************************************************************
|
|
* *
|
|
* OpenSpace *
|
|
* *
|
|
* Copyright (c) 2014-2018 *
|
|
* *
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy of this *
|
|
* software and associated documentation files (the "Software"), to deal in the Software *
|
|
* without restriction, including without limitation the rights to use, copy, modify, *
|
|
* merge, publish, distribute, sublicense, and/or sell copies of the Software, and to *
|
|
* permit persons to whom the Software is furnished to do so, subject to the following *
|
|
* conditions: *
|
|
* *
|
|
* The above copyright notice and this permission notice shall be included in all copies *
|
|
* or substantial portions of the Software. *
|
|
* *
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, *
|
|
* INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A *
|
|
* PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT *
|
|
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF *
|
|
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE *
|
|
* OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. *
|
|
****************************************************************************************/
|
|
|
|
#include <modules/globebrowsing/geometry/angle.h>
|
|
|
|
namespace openspace::globebrowsing {
|
|
|
|
//////////////////////////////////////////////////////////////////////////////////////////
|
|
// STATIC CONSTANTS //
|
|
//////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
template <typename T>
|
|
const Angle<T> Angle<T>::ZERO = Angle<T>(T(0));
|
|
|
|
template <typename T>
|
|
const Angle<T> Angle<T>::QUARTER = Angle<T>(glm::half_pi<T>());
|
|
|
|
template <typename T>
|
|
const Angle<T> Angle<T>::HALF = Angle<T>(glm::pi<T>());
|
|
|
|
template <typename T>
|
|
const Angle<T> Angle<T>::FULL = Angle<T>(glm::two_pi<T>());
|
|
|
|
//////////////////////////////////////////////////////////////////////////////////////////
|
|
// Constructors //
|
|
//////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
template <typename T>
|
|
Angle<T>::Angle(const Angle<T>& other)
|
|
: _radians(other._radians)
|
|
{}
|
|
|
|
template <typename T>
|
|
Angle<T>::Angle(T radians)
|
|
: _radians(radians)
|
|
{}
|
|
|
|
//////////////////////////////////////////////////////////////////////////////////////////
|
|
// Factory Methods //
|
|
//////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
template <typename T>
|
|
Angle<T> Angle<T>::fromRadians(T rads) {
|
|
return Angle<T>(rads);
|
|
}
|
|
|
|
template <typename T>
|
|
Angle<T> Angle<T>::fromDegrees(T degrees) {
|
|
return Angle<T>(glm::radians(degrees));
|
|
}
|
|
|
|
//////////////////////////////////////////////////////////////////////////////////////////
|
|
// Conversions //
|
|
//////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
template <typename T>
|
|
T Angle<T>::asRadians() const {
|
|
return _radians;
|
|
}
|
|
|
|
template <typename T>
|
|
T Angle<T>::asDegrees() const {
|
|
return glm::degrees(_radians);
|
|
}
|
|
|
|
//////////////////////////////////////////////////////////////////////////////////////////
|
|
// Operators //
|
|
//////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
template <typename T>
|
|
Angle<T> Angle<T>::operator+(const Angle<T>& rhs) const{
|
|
return Angle<T>(_radians + rhs._radians);
|
|
}
|
|
|
|
template <typename T>
|
|
Angle<T> Angle<T>::operator-(const Angle<T>& rhs) const{
|
|
return Angle<T>(_radians - rhs._radians);
|
|
}
|
|
|
|
template <typename T>
|
|
Angle<T> Angle<T>::operator*(T multiplier) const{
|
|
return Angle<T>(_radians * multiplier);
|
|
}
|
|
|
|
template <typename T>
|
|
Angle<T> Angle<T>::operator/(T divisor) const{
|
|
return Angle<T>(_radians / divisor);
|
|
}
|
|
|
|
template <typename T>
|
|
Angle<T> Angle<T>::operator-() const {
|
|
return Angle<T>(-_radians);
|
|
}
|
|
|
|
template <typename T>
|
|
void Angle<T>::operator+=(const Angle<T>& rhs){
|
|
_radians += rhs._radians;
|
|
}
|
|
|
|
template <typename T>
|
|
void Angle<T>::operator-=(const Angle<T>& rhs){
|
|
_radians -= rhs._radians;
|
|
}
|
|
|
|
template <typename T>
|
|
void Angle<T>::operator*=(T multiplier){
|
|
_radians *= multiplier;
|
|
}
|
|
|
|
template <typename T>
|
|
void Angle<T>::operator/=(T divisor){
|
|
_radians /= divisor;
|
|
}
|
|
|
|
template <typename T>
|
|
bool Angle<T>::operator<(const Angle<T>& rhs) const{
|
|
return _radians < rhs._radians;
|
|
}
|
|
|
|
template <typename T>
|
|
bool Angle<T>::operator<=(const Angle<T>& rhs) const{
|
|
return _radians <= rhs._radians;
|
|
}
|
|
|
|
template <typename T>
|
|
bool Angle<T>::operator>(const Angle<T>& rhs) const{
|
|
return _radians > rhs._radians;
|
|
}
|
|
|
|
template <typename T>
|
|
bool Angle<T>::operator>=(const Angle<T>& rhs) const{
|
|
return _radians >= rhs._radians;
|
|
}
|
|
|
|
template <typename T>
|
|
bool Angle<T>::operator==(const Angle<T>& rhs) const{
|
|
return _radians == rhs._radians;
|
|
}
|
|
|
|
template <typename T>
|
|
bool Angle<T>::operator!=(const Angle<T>& rhs) const{
|
|
return _radians != rhs._radians;
|
|
}
|
|
|
|
//////////////////////////////////////////////////////////////////////////////////////////
|
|
// Chainable Relative Mutators //
|
|
//////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
template <typename T>
|
|
Angle<T>& Angle<T>::normalize() {
|
|
// this will cause _radians to be in value range ]-2pi, 2pi[
|
|
_radians = fmod(_radians, glm::two_pi<T>());
|
|
|
|
// ensure _radians are positive, ie in value range [0, 2pi[
|
|
if (_radians < T(0)) {
|
|
_radians += glm::two_pi<T>();
|
|
}
|
|
|
|
return *this;
|
|
}
|
|
|
|
template <typename T>
|
|
Angle<T>& Angle<T>::normalizeAround(const Angle<T>& center) {
|
|
_radians -= center._radians + glm::pi<T>();
|
|
normalize();
|
|
_radians += center._radians - glm::pi<T>();
|
|
return *this;
|
|
}
|
|
|
|
template <typename T>
|
|
Angle<T>& Angle<T>::clamp(const Angle<T>& min, const Angle<T>& max) {
|
|
const T& minRad = min._radians;
|
|
const T& maxRad = max._radians;
|
|
|
|
_radians = glm::clamp(_radians, minRad, maxRad);
|
|
return *this;
|
|
}
|
|
|
|
template <typename T>
|
|
Angle<T> Angle<T>::abs() const {
|
|
return Angle<T>::fromRadians(glm::abs(_radians));
|
|
}
|
|
|
|
} // namespace openspace::globebrowsing
|