[apps/reg] Display the regression controller from the graph view

This commit is contained in:
Léa Saviot
2018-06-07 16:31:15 +02:00
committed by Émilie Feral
parent 01698a650d
commit 799bbfbf05
7 changed files with 112 additions and 34 deletions

View File

@@ -57,7 +57,8 @@ App::App(Container * container, Snapshot * snapshot) :
m_storeController(&m_storeHeader, snapshot->store(), &m_storeHeader),
m_storeHeader(&m_storeStackViewController, &m_storeController, &m_storeController),
m_storeStackViewController(&m_tabViewController, &m_storeHeader),
m_tabViewController(&m_modalViewController, snapshot, &m_storeStackViewController, &m_graphStackViewController, &m_calculationHeader)
m_tabViewController(&m_modalViewController, snapshot, &m_storeStackViewController, &m_graphStackViewController, &m_calculationHeader),
m_regressionController(nullptr, snapshot->store())
{
}

View File

@@ -3,10 +3,11 @@
#include <escher.h>
#include "../shared/text_field_delegate_app.h"
#include "calculation_controller.h"
#include "graph_controller.h"
#include "regression_controller.h"
#include "store.h"
#include "store_controller.h"
#include "graph_controller.h"
#include "calculation_controller.h"
namespace Regression {
@@ -37,7 +38,8 @@ public:
uint32_t m_modelVersion;
uint32_t m_rangeVersion;
int m_selectedSeriesIndex;
};
};
RegressionController * regressionController() { return &m_regressionController; }
private:
App(Container * container, Snapshot * snapshot);
CalculationController m_calculationController;
@@ -51,6 +53,7 @@ private:
ButtonRowController m_storeHeader;
StackViewController m_storeStackViewController;
TabViewController m_tabViewController;
RegressionController m_regressionController;
};
}

View File

@@ -1,4 +1,7 @@
#include "graph_options_controller.h"
#include "app.h"
#include "graph_controller.h"
#include "regression_controller.h"
#include <assert.h>
using namespace Shared;
@@ -7,9 +10,13 @@ namespace Regression {
GraphOptionsController::GraphOptionsController(Responder * parentResponder, Store * store, CurveViewCursor * cursor, GraphController * graphController) :
ViewController(parentResponder),
m_changeRegressionCell(I18n::Message::ChangeRegression),
m_selectableTableView(this),
m_goToParameterController(this, store, cursor, graphController)
m_goToParameterController(this, store, cursor, graphController),
m_store(store),
m_graphController(graphController)
{
static_cast<ExpressionView *>(m_changeRegressionCell.subAccessoryView())->setHorizontalMargin(Metric::ExpressionViewHorizontalMargin);
}
const char * GraphOptionsController::title() {
@@ -27,38 +34,93 @@ void GraphOptionsController::didBecomeFirstResponder() {
app()->setFirstResponder(&m_selectableTableView);
}
void GraphOptionsController::viewWillAppear() {
m_selectableTableView.reloadData();
}
bool GraphOptionsController::handleEvent(Ion::Events::Event event) {
if (event == Ion::Events::OK || event == Ion::Events::EXE || event == Ion::Events::Right) {
m_goToParameterController.setXPrediction(selectedRow() == 0);
StackViewController * stack = (StackViewController *)parentResponder();
stack->push(&m_goToParameterController);
if (selectedRow() == numberOfRows() -1) {
RegressionController * regressionController = static_cast<Regression::App *>(app())->regressionController();
regressionController->setSeries(m_graphController->selectedSeriesIndex());
StackViewController * stack = static_cast<StackViewController *>(parentResponder());
stack->push(regressionController);
} else {
m_goToParameterController.setXPrediction(selectedRow() == 0);
StackViewController * stack = (StackViewController *)parentResponder();
stack->push(&m_goToParameterController);
}
return true;
}
return false;
}
int GraphOptionsController::numberOfRows() {
return k_totalNumberOfCells;
};
HighlightCell * GraphOptionsController::reusableCell(int index) {
assert(index >= 0);
assert(index < k_totalNumberOfCells);
return &m_cells[index];
return k_numberOfParameterCells + 1;
}
int GraphOptionsController::reusableCellCount() {
return k_totalNumberOfCells;
}
KDCoordinate GraphOptionsController::cellHeight() {
KDCoordinate GraphOptionsController::rowHeight(int j) {
if ((j == numberOfRows() - 1) &&
(static_cast<Store *>(m_store)->seriesRegressionType(m_graphController->selectedSeriesIndex()) == Model::Type::Logistic))
{
return RegressionController::k_logisticCellHeight;
}
return Metric::ParameterCellHeight;
}
KDCoordinate GraphOptionsController::cumulatedHeightFromIndex(int j) {
assert (j >= 0 && j <= numberOfRows());
KDCoordinate result = 0;
for (int i = 0; i < j; i++) {
result+= rowHeight(i);
}
return result;
}
int GraphOptionsController::indexFromCumulatedHeight(KDCoordinate offsetY) {
int result = 0;
int j = 0;
while (result < offsetY && j < numberOfRows()) {
result += rowHeight(j++);
}
return (result < offsetY || offsetY == 0) ? j : j - 1;
}
HighlightCell * GraphOptionsController::reusableCell(int index, int type) {
assert(index >= 0);
assert(index < reusableCellCount(type));
if (type == k_regressionCellType) {
return &m_changeRegressionCell;
}
assert(type == k_parameterCelltype);
return &m_parameterCells[index];
}
int GraphOptionsController::reusableCellCount(int type) {
if (type == k_regressionCellType) {
return 1;
}
assert(type == k_parameterCelltype);
return k_numberOfParameterCells;
}
int GraphOptionsController::typeAtLocation(int i, int j) {
assert(i == 0);
if (j == numberOfRows() -1) {
return k_regressionCellType;
}
return k_parameterCelltype;
}
void GraphOptionsController::willDisplayCellForIndex(HighlightCell * cell, int index) {
MessageTableCellWithChevron * myCell = (MessageTableCellWithChevron *)cell;
I18n::Message titles[2] = {I18n::Message::XPrediction, I18n::Message::YPrediction};
myCell->setMessage(titles[index]);
if (index < k_numberOfParameterCells) {
MessageTableCellWithChevron * myCell = (MessageTableCellWithChevron *)cell;
I18n::Message titles[k_numberOfParameterCells] = {I18n::Message::XPrediction, I18n::Message::YPrediction};
myCell->setMessage(titles[index]);
} else {
assert(index == numberOfRows() - 1);
m_changeRegressionCell.setExpressionLayout(static_cast<Store *>(m_store)->modelForSeries(m_graphController->selectedSeriesIndex())->layout());
}
}
}

View File

@@ -10,23 +10,34 @@ namespace Regression {
class GraphController;
class GraphOptionsController : public ViewController, public SimpleListViewDataSource, public SelectableTableViewDataSource {
class GraphOptionsController : public ViewController, public ListViewDataSource, public SelectableTableViewDataSource {
public:
GraphOptionsController(Responder * parentResponder, Store * store, Shared::CurveViewCursor * cursor, GraphController * graphController);
View * view() override;
const char * title() override;
bool handleEvent(Ion::Events::Event event) override;
void didBecomeFirstResponder() override;
void viewWillAppear() override;
//ListViewDataSource
int numberOfRows() override;
KDCoordinate cellHeight() override;
HighlightCell * reusableCell(int index) override;
int reusableCellCount() override;
KDCoordinate rowHeight(int j) override;
KDCoordinate cumulatedHeightFromIndex(int j) override;
int indexFromCumulatedHeight(KDCoordinate offsetY) override;
HighlightCell * reusableCell(int index, int type) override;
int reusableCellCount(int type) override;
int typeAtLocation(int i, int j) override;
void willDisplayCellForIndex(HighlightCell * cell, int index) override;
private:
constexpr static int k_totalNumberOfCells = 2;
MessageTableCellWithChevron m_cells[2];
constexpr static int k_regressionCellType = 0;
constexpr static int k_parameterCelltype = 1;
constexpr static int k_numberOfParameterCells = 2;
MessageTableCellWithChevron m_parameterCells[k_numberOfParameterCells];
MessageTableCellWithChevronAndExpression m_changeRegressionCell;
SelectableTableView m_selectableTableView;
GoToParameterController m_goToParameterController;
Store * m_store;
GraphController * m_graphController;
};
}

View File

@@ -1,4 +1,5 @@
#include "store_parameter_controller.h"
#include "app.h"
#include "store_controller.h"
#include <assert.h>
@@ -7,10 +8,9 @@ namespace Regression {
StoreParameterController::StoreParameterController(Responder * parentResponder, Store * store, StoreController * storeController) :
Shared::StoreParameterController(parentResponder, store, storeController),
m_changeRegressionCell(I18n::Message::ChangeRegression),
m_regressionController(this, store),
m_lastSelectionIsRegression(false)
{
static_cast<ExpressionView *>(m_changeRegressionCell.subAccessoryView())->setHorizontalMargin(5);
static_cast<ExpressionView *>(m_changeRegressionCell.subAccessoryView())->setHorizontalMargin(Metric::ExpressionViewHorizontalMargin);
}
void StoreParameterController::viewWillAppear() {
@@ -20,9 +20,10 @@ void StoreParameterController::viewWillAppear() {
bool StoreParameterController::handleEvent(Ion::Events::Event event) {
if ((event == Ion::Events::OK || event == Ion::Events::EXE || event == Ion::Events::Right) && selectedRow() == numberOfRows() - 1) {
m_regressionController.setSeries(m_series);
RegressionController * regressionController = static_cast<Regression::App *>(app())->regressionController();
regressionController->setSeries(m_series);
StackViewController * stack = static_cast<StackViewController *>(parentResponder());
stack->push(&m_regressionController);
stack->push(regressionController);
m_lastSelectionIsRegression = true;
return true;
}

View File

@@ -25,7 +25,6 @@ public:
private:
static constexpr int k_regressionCellType = 1;
MessageTableCellWithChevronAndExpression m_changeRegressionCell;
RegressionController m_regressionController;
bool m_lastSelectionIsRegression;
};

View File

@@ -30,6 +30,7 @@ public:
constexpr static KDCoordinate FractionAndConjugateHorizontalMargin = 2;
constexpr static KDCoordinate MinimalBracketAndParenthesisHeight = 18;
constexpr static KDCoordinate TableSeparatorThickness = 2;
constexpr static KDCoordinate ExpressionViewHorizontalMargin = 5;
};
#endif