Revision 317f0cb78e56aaaa51c961b4b450b1f5d7ec82d6 authored by Dmitri Naumov on 18 September 2022, 21:24:19 UTC, committed by Dmitri Naumov on 18 September 2022, 21:25:09 UTC
- Avoid shadowing, - Unify declaration/definition name.
1 parent 4895a54
CoordinateSystem.h
/**
* \file
* \copyright
* Copyright (c) 2012-2022, OpenGeoSys Community (http://www.opengeosys.org)
* Distributed under a Modified BSD License.
* See accompanying file LICENSE.txt or
* http://www.opengeosys.org/project/license
*/
#pragma once
#include <cmath>
#include "GeoLib/AABB.h"
namespace MeshLib
{
class Element;
/**
* \brief Coordinate system type
*/
struct CoordinateSystemType final
{
enum type
{
X = 0x01,
Y = 0x02,
Z = 0x04
};
};
/**
* \brief Coordinate systems
*
*
*/
class CoordinateSystem final
{
public:
/// User provided coordinate system
explicit CoordinateSystem(unsigned char coord) : _type(coord) {}
/// Decides for a given element
explicit CoordinateSystem(const Element& ele);
/// Decides a coordinate system from a bounding box
explicit CoordinateSystem(const GeoLib::AABB& bbox)
: _type(getCoordinateSystem(bbox))
{
}
/// get this coordinate type
unsigned char getType() const { return _type; }
/// get dimension size
unsigned getDimension() const
{
if (hasZ())
{
return 3;
}
if (hasY())
{
return 2;
}
return 1;
}
/// has X dimension
bool hasX() const { return (_type & CoordinateSystemType::type::X) != 0; }
/// has Y dimension
bool hasY() const { return (_type & CoordinateSystemType::type::Y) != 0; }
/// has z dimension
bool hasZ() const { return (_type & CoordinateSystemType::type::Z) != 0; }
private:
unsigned char getCoordinateSystem(const GeoLib::AABB& bbox) const;
unsigned char _type;
};
} // namespace MeshLib
Computing file changes ...