Files
Upsilon/apps/shared/interactive_curve_view_range_delegate.cpp

60 lines
1.9 KiB
C++

#include "interactive_curve_view_range_delegate.h"
#include "interactive_curve_view_range.h"
#include <cmath>
#include <float.h>
namespace Shared {
bool InteractiveCurveViewRangeDelegate::didChangeRange(InteractiveCurveViewRange * interactiveCurveViewRange) {
if (!interactiveCurveViewRange->yAuto()) {
return false;
}
Range yRange = computeYRange(interactiveCurveViewRange);
float max = yRange.max;
float min = yRange.min;
float range = max - min;
if (max < min) {
range = 0.0f;
}
if (interactiveCurveViewRange->yMin() == addMargin(min, range, true) && interactiveCurveViewRange->yMax() == addMargin(max, range, false)) {
return false;
}
if (min == max) {
float step = max != 0.0f ? interactiveCurveViewRange->computeGridUnit(CurveViewRange::Axis::Y, max) : 1.0f;
min = min - step;
max = max + step;
}
if (min == FLT_MAX && max == -FLT_MAX) {
min = -1.0f;
max = 1.0f;
}
if (min == FLT_MAX) {
float step = max != 0.0f ? interactiveCurveViewRange->computeGridUnit(CurveViewRange::Axis::Y, std::fabs(max)) : 1.0f;
min = max-step;
}
if (max == -FLT_MAX) {
float step = min != 0.0f ? interactiveCurveViewRange->computeGridUnit(CurveViewRange::Axis::Y, std::fabs(min)) : 1.0f;
max = min+step;
}
range = max - min;
if (range < InteractiveCurveViewRange::k_minFloat) {
max += InteractiveCurveViewRange::k_minFloat;
min -= InteractiveCurveViewRange::k_minFloat;
}
interactiveCurveViewRange->setYMin(addMargin(min, range, true));
interactiveCurveViewRange->setYMax(addMargin(max, range, false));
if (std::isinf(interactiveCurveViewRange->xMin())) {
interactiveCurveViewRange->setYMin(-FLT_MAX);
}
if (std::isinf(interactiveCurveViewRange->xMax())) {
interactiveCurveViewRange->setYMax(FLT_MAX);
}
return true;
}
float InteractiveCurveViewRangeDelegate::interestingXRange() {
return 10.0f;
}
}