#include "function_go_to_parameter_controller.h" #include "function_app.h" #include #include namespace Shared { FunctionGoToParameterController::FunctionGoToParameterController(Responder * parentResponder, InputEventHandlerDelegate * inputEventHandlerDelegate, InteractiveCurveViewRange * graphRange, CurveViewCursor * cursor) : GoToParameterController(parentResponder, inputEventHandlerDelegate, graphRange, cursor), m_record() { } const char * FunctionGoToParameterController::title() { return I18n::translate(I18n::Message::Goto); } double FunctionGoToParameterController::parameterAtIndex(int index) { assert(index == 0); return m_cursor->t(); } bool FunctionGoToParameterController::setParameterAtIndex(int parameterIndex, double f) { assert(parameterIndex == 0); FunctionApp * myApp = FunctionApp::app(); ExpiringPointer function = myApp->functionStore()->modelForRecord(m_record); Poincare::Coordinate2D xy = function->evaluateXYAtParameter(f, myApp->localContext()); m_cursor->moveTo(f, xy.x1(), xy.x2()); m_graphRange->centerAxisAround(CurveViewRange::Axis::X, m_cursor->x()); m_graphRange->centerAxisAround(CurveViewRange::Axis::Y, m_cursor->y()); /* The range might have evolved to center around the cursor but we don't want * to reinit the cursor position when displaying the graph controller. To * prevent this, we update the snapshot range version in order to make the * graph controller as if the range has not evolved since last appearance. */ uint32_t * snapshotRangeVersion = static_cast(myApp->snapshot())->rangeVersion(); *snapshotRangeVersion = m_graphRange->rangeChecksum(); return true; } void FunctionGoToParameterController::setRecord(Ion::Storage::Record record) { m_record = record; FunctionApp * myApp = FunctionApp::app(); ExpiringPointer function = myApp->functionStore()->modelForRecord(m_record); setParameterName(function->parameterMessageName()); } }