mirror of
https://github.com/UpsilonNumworks/Upsilon.git
synced 2026-01-19 00:37:25 +01:00
88 lines
1.8 KiB
C++
88 lines
1.8 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)
|
|
{
|
|
}
|
|
|
|
float MemoizedCurveViewRange::xMin() {
|
|
return m_xMin;
|
|
}
|
|
|
|
float MemoizedCurveViewRange::xMax() {
|
|
return m_xMax;
|
|
}
|
|
|
|
float MemoizedCurveViewRange::yMin() {
|
|
return m_yMin;
|
|
}
|
|
|
|
float MemoizedCurveViewRange::yMax() {
|
|
return m_yMax;
|
|
}
|
|
|
|
float MemoizedCurveViewRange::xGridUnit() {
|
|
return m_xGridUnit;
|
|
}
|
|
|
|
float MemoizedCurveViewRange::yGridUnit() {
|
|
return m_yGridUnit;
|
|
}
|
|
|
|
void MemoizedCurveViewRange::setXMin(float xMin) {
|
|
if (std::isnan(xMin)) {
|
|
return;
|
|
}
|
|
m_xMin = xMin;
|
|
if (m_xMin >= m_xMax) {
|
|
m_xMax = xMin + std::pow(10.0f, std::floor(std::log10(std::fabs(xMin)))-1.0f);
|
|
}
|
|
m_xGridUnit = computeGridUnit(Axis::X, m_xMax - m_xMin);
|
|
}
|
|
|
|
void MemoizedCurveViewRange::setXMax(float xMax) {
|
|
if (std::isnan(xMax)) {
|
|
return;
|
|
}
|
|
m_xMax = xMax;
|
|
if (m_xMin >= m_xMax) {
|
|
m_xMin = xMax - std::pow(10.0f, std::floor(std::log10(std::fabs(xMax)))-1.0f);
|
|
}
|
|
m_xGridUnit = computeGridUnit(Axis::X, m_xMax - m_xMin);
|
|
}
|
|
|
|
void MemoizedCurveViewRange::setYMin(float yMin) {
|
|
if (std::isnan(yMin)) {
|
|
return;
|
|
}
|
|
m_yMin = yMin;
|
|
if (m_yMin >= m_yMax) {
|
|
m_yMax = yMin + std::pow(10.0f, std::floor(std::log10(std::fabs(yMin)))-1.0f);
|
|
}
|
|
m_yGridUnit = computeGridUnit(Axis::Y, m_yMax - m_yMin);
|
|
}
|
|
|
|
void MemoizedCurveViewRange::setYMax(float yMax) {
|
|
if (std::isnan(yMax)) {
|
|
return;
|
|
}
|
|
m_yMax = yMax;
|
|
if (m_yMin >= m_yMax) {
|
|
m_yMin = yMax - + std::pow(10.0f, std::floor(std::log10(std::fabs(yMax)))-1.0f);
|
|
|
|
}
|
|
m_yGridUnit = computeGridUnit(Axis::Y, m_yMax - m_yMin);
|
|
}
|
|
|
|
}
|