Files
Upsilon/apps/graph/graph/curve_parameter_controller.cpp
Émilie Feral 2e16365100 [escher] Reorganize all cells'name and factorize their layouts
Change-Id: I69900ee98ff6a6868f96d70a0e335a589ef16c3f
2017-02-20 10:54:02 +01:00

90 lines
2.6 KiB
C++

#include "curve_parameter_controller.h"
#include <assert.h>
using namespace Shared;
namespace Graph {
CurveParameterController::CurveParameterController(InteractiveCurveViewRange * graphRange, BannerView * bannerView, CurveViewCursor * cursor) :
ViewController(nullptr),
m_bannerView(bannerView),
m_function(nullptr),
m_calculationCell(PointerTableCellWithChevron((char*)"Calculer")),
m_goToCell(PointerTableCellWithChevron((char*)"Aller a")),
m_derivativeCell(PointerTableCellWithSwitch((char*)"Nombre derivee")),
m_selectableTableView(SelectableTableView(this, this, Metric::TopMargin, Metric::RightMargin,
Metric::BottomMargin, Metric::LeftMargin)),
m_goToParameterController(GoToParameterController(this, graphRange, cursor))
{
}
const char * CurveParameterController::title() const {
return "Options de la courbe";
}
View * CurveParameterController::view() {
return &m_selectableTableView;
}
void CurveParameterController::didBecomeFirstResponder() {
m_selectableTableView.selectCellAtLocation(0, 0);
app()->setFirstResponder(&m_selectableTableView);
}
void CurveParameterController::willDisplayCellForIndex(HighlightCell * cell, int index) {
if (cell == &m_derivativeCell) {
SwitchView * switchView = (SwitchView *)m_derivativeCell.accessoryView();
switchView->setState(m_bannerView->displayDerivative());
}
}
bool CurveParameterController::handleEvent(Ion::Events::Event event) {
if (event == Ion::Events::OK) {
switch (m_selectableTableView.selectedRow()) {
case 0:
return true;
case 1:
{
m_goToParameterController.setFunction(m_function);
StackViewController * stack = (StackViewController *)parentResponder();
stack->push(&m_goToParameterController);
return true;
}
case 2:
{
m_bannerView->setDisplayDerivative(!m_bannerView->displayDerivative());
m_selectableTableView.reloadData();
return true;
}
default:
return false;
}
}
return false;
}
int CurveParameterController::numberOfRows() {
return k_totalNumberOfCells;
};
HighlightCell * CurveParameterController::reusableCell(int index) {
assert(index >= 0);
assert(index < k_totalNumberOfCells);
HighlightCell * cells[] = {&m_calculationCell, &m_goToCell, &m_derivativeCell};
return cells[index];
}
int CurveParameterController::reusableCellCount() {
return k_totalNumberOfCells;
}
KDCoordinate CurveParameterController::cellHeight() {
return Metric::ParameterCellHeight;
}
void CurveParameterController::setFunction(CartesianFunction * function) {
m_function = function;
}
}