mirror of
https://github.com/UpsilonNumworks/Upsilon.git
synced 2026-01-19 00:37:25 +01:00
67 lines
1.4 KiB
C++
67 lines
1.4 KiB
C++
#include "memoized_curve_view_range.h"
|
|
#include <cmath>
|
|
#include <assert.h>
|
|
#include <ion.h>
|
|
|
|
namespace Shared {
|
|
|
|
MemoizedCurveViewRange::MemoizedCurveViewRange() :
|
|
m_xMin(-10.0f),
|
|
m_xMax(10.0f),
|
|
m_yMin(-10.0f),
|
|
m_yMax(10.0f),
|
|
m_xGridUnit(2.0f),
|
|
m_yGridUnit(2.0f)
|
|
{
|
|
}
|
|
|
|
void MemoizedCurveViewRange::setXMin(float xMin) {
|
|
if (std::isnan(xMin)) {
|
|
return;
|
|
}
|
|
m_xMin = xMin;
|
|
if (m_xMin >= m_xMax) {
|
|
m_xMax = xMin + defaultRangeLengthFor(xMin);
|
|
}
|
|
m_xGridUnit = CurveViewRange::xGridUnit();
|
|
}
|
|
|
|
void MemoizedCurveViewRange::setXMax(float xMax) {
|
|
if (std::isnan(xMax)) {
|
|
return;
|
|
}
|
|
m_xMax = xMax;
|
|
if (m_xMin >= m_xMax) {
|
|
m_xMin = xMax - defaultRangeLengthFor(xMax);
|
|
}
|
|
m_xGridUnit = CurveViewRange::xGridUnit();
|
|
}
|
|
|
|
void MemoizedCurveViewRange::setYMin(float yMin) {
|
|
if (std::isnan(yMin)) {
|
|
return;
|
|
}
|
|
m_yMin = yMin;
|
|
if (m_yMin >= m_yMax) {
|
|
m_yMax = yMin + defaultRangeLengthFor(yMin);
|
|
}
|
|
m_yGridUnit = CurveViewRange::yGridUnit();
|
|
}
|
|
|
|
void MemoizedCurveViewRange::setYMax(float yMax) {
|
|
if (std::isnan(yMax)) {
|
|
return;
|
|
}
|
|
m_yMax = yMax;
|
|
if (m_yMin >= m_yMax) {
|
|
m_yMin = yMax - defaultRangeLengthFor(yMax);
|
|
}
|
|
m_yGridUnit = CurveViewRange::yGridUnit();
|
|
}
|
|
|
|
float MemoizedCurveViewRange::defaultRangeLengthFor(float position) const {
|
|
return std::pow(10.0f, std::floor(std::log10(std::fabs(position)))-1.0f);
|
|
}
|
|
|
|
}
|