[solver] Equation List: Hide brace margin when it is not displayed

This commit is contained in:
Émilie Feral
2018-06-08 10:51:40 +02:00
parent ed74c4e6e2
commit 6ca93a5f35
2 changed files with 18 additions and 29 deletions

View File

@@ -7,6 +7,7 @@ namespace Solver {
EquationListView::EquationListView(Responder * parentResponder, TableViewDataSource * dataSource, SelectableTableViewDataSource * selectionDataSource) :
Responder(parentResponder),
View(),
m_displayBrace(false),
m_listView(this, dataSource, selectionDataSource),
m_braceView(),
m_scrollBraceView(&m_braceView, this)
@@ -20,6 +21,13 @@ EquationListView::EquationListView(Responder * parentResponder, TableViewDataSou
m_scrollBraceView.setBackgroundColor(KDColorWhite);
}
void EquationListView::displayBrace(bool displayBrace) {
if (m_displayBrace != displayBrace) {
m_displayBrace = displayBrace;
layoutSubviews();
}
}
void EquationListView::scrollViewDidChangeOffset(ScrollViewDataSource * scrollViewDataSource) {
m_scrollBraceView.setContentOffset(KDPoint(0, scrollViewDataSource->offset().y()));
layoutSubviews();
@@ -39,33 +47,20 @@ void EquationListView::didBecomeFirstResponder() {
}
void EquationListView::layoutSubviews() {
KDCoordinate braceWidth = m_braceView.minimalSizeForOptimalDisplay().width();
m_braceView.setSize(KDSize(braceWidth, m_listView.minimalSizeForOptimalDisplay().height()-Metric::StoreRowHeight-2*k_margin));
m_listView.setFrame(KDRect(0, 0, bounds().width(), bounds().height()));
m_scrollBraceView.setFrame(KDRect(0, 0, k_braceTotalWidth, m_listView.minimalSizeForOptimalDisplay().height()-Metric::StoreRowHeight-offset().y()));
if (m_displayBrace) {
KDCoordinate braceWidth = m_braceView.minimalSizeForOptimalDisplay().width();
m_braceView.setSize(KDSize(braceWidth, m_listView.minimalSizeForOptimalDisplay().height()-Metric::StoreRowHeight-2*k_margin));
m_scrollBraceView.setFrame(KDRect(0, 0, k_braceTotalWidth, m_listView.minimalSizeForOptimalDisplay().height()-Metric::StoreRowHeight-offset().y()));
} else {
m_scrollBraceView.setFrame(KDRectZero);
}
}
/* EquationListView::BraceWidth */
EquationListView::BraceView::BraceView() :
View(),
m_displayBrace(false)
{
}
void EquationListView::BraceView::displayBrace(bool displayBrace) {
if (m_displayBrace != displayBrace) {
m_displayBrace = displayBrace;
markRectAsDirty(bounds());
}
}
void EquationListView::BraceView::drawRect(KDContext * ctx, KDRect rect) const {
if (m_displayBrace) {
ctx->fillRect(bounds(), KDColorRed);
} else {
ctx->fillRect(bounds(), KDColorWhite);
}
ctx->fillRect(bounds(), KDColorRed);
}
KDSize EquationListView::BraceView::minimalSizeForOptimalDisplay() const {

View File

@@ -8,9 +8,7 @@ namespace Solver {
class EquationListView : public Responder, public View, public ScrollViewDelegate, public ScrollViewDataSource {
public:
EquationListView(Responder * parentResponder, TableViewDataSource * dataSource, SelectableTableViewDataSource * selectionDataSource);
void displayBrace(bool displayBrace) {
m_braceView.displayBrace(displayBrace);
}
void displayBrace(bool displayBrace);
void scrollViewDidChangeOffset(ScrollViewDataSource * scrollViewDataSource) override;
void didBecomeFirstResponder() override;
SelectableTableView * selectableTableView() {
@@ -25,15 +23,11 @@ private:
class BraceView : public View {
public:
BraceView();
void drawRect(KDContext * ctx, KDRect rect) const override;
KDSize minimalSizeForOptimalDisplay() const override;
void displayBrace(bool displayBrace);
constexpr static KDCoordinate k_braceWidth = 10;
private:
bool m_displayBrace;
};
bool m_displayBrace;
SelectableTableView m_listView;
BraceView m_braceView;
ScrollView m_scrollBraceView;