Blame view

build4/epsilon-master/apps/home/controller.cpp 5.29 KB
6663b6c9   adorian   projet complet av...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
  #include "controller.h"
  #include "../apps_container.h"
  extern "C" {
  #include <assert.h>
  }
  
  namespace Home {
  
  Controller::ContentView::ContentView(Controller * controller, SelectableTableViewDataSource * selectionDataSource) :
    m_selectableTableView(controller, controller, selectionDataSource, controller)
  {
    m_selectableTableView.setVerticalCellOverlap(0);
    m_selectableTableView.setMargins(0, k_sideMargin, k_bottomMargin, k_sideMargin);
    m_selectableTableView.setColorsBackground(false);
    m_selectableTableView.setIndicatorThickness(k_indicatorThickness);
    m_selectableTableView.verticalScrollIndicator()->setMargin(k_indicatorMargin);
  }
  
  SelectableTableView * Controller::ContentView::selectableTableView() {
    return &m_selectableTableView;
  }
  
  void Controller::ContentView::drawRect(KDContext * ctx, KDRect rect) const {
    ctx->fillRect(bounds(), KDColorWhite);
  }
  
  void Controller::ContentView::reloadBottomRightCorner(SimpleTableViewDataSource * dataSource) {
    /* We mark the bottom right corner (where an empty space can be) as dirty. */
    markRectAsDirty(KDRect(dataSource->cellWidth()*2, dataSource->cellHeight(), dataSource->cellWidth(), dataSource->cellHeight()));
  }
  
  int Controller::ContentView::numberOfSubviews() const {
    return 1;
  }
  
  View * Controller::ContentView::subviewAtIndex(int index) {
    assert(index == 0);
    return &m_selectableTableView;
  }
  
  void Controller::ContentView::layoutSubviews() {
    m_selectableTableView.setFrame(bounds());
  }
  
  Controller::Controller(Responder * parentResponder, ::AppsContainer * container, SelectableTableViewDataSource * selectionDataSource) :
    ViewController(parentResponder),
    m_container(container),
    m_view(this, selectionDataSource),
    m_selectionDataSource(selectionDataSource)
  {
  }
  
  bool Controller::handleEvent(Ion::Events::Event event) {
    if (event == Ion::Events::OK || event == Ion::Events::EXE) {
      m_container->switchTo(m_container->appSnapshotAtIndex(m_selectionDataSource->selectedRow()*k_numberOfColumns+m_selectionDataSource->selectedColumn()+1));
      return true;
    }
  
    if (event == Ion::Events::Home || event == Ion::Events::Back) {
      return m_view.selectableTableView()->selectCellAtLocation(0,0);
    }
  
    if (event == Ion::Events::Right && m_selectionDataSource->selectedRow() < numberOfRows()) {
      return m_view.selectableTableView()->selectCellAtLocation(0, m_selectionDataSource->selectedRow()+1);
    }
    if (event == Ion::Events::Left && m_selectionDataSource->selectedRow() > 0) {
      return m_view.selectableTableView()->selectCellAtLocation(numberOfColumns()-1, m_selectionDataSource->selectedRow()-1);
    }
  
    return false;
  }
  
  void Controller::didBecomeFirstResponder() {
    if (m_selectionDataSource->selectedRow() == -1) {
      m_selectionDataSource->selectCellAtLocation(0, 0);
    } else {
      m_selectionDataSource->selectCellAtLocation(m_selectionDataSource->selectedColumn(), m_selectionDataSource->selectedRow());
    }
    app()->setFirstResponder(m_view.selectableTableView());
  }
  
  void Controller::viewWillAppear() {
  }
  
  View * Controller::view() {
    return &m_view;
  }
  
  int Controller::numberOfRows() {
    return ((numberOfIcons()-1)/k_numberOfColumns)+1;
  }
  
  int Controller::numberOfColumns() {
    return k_numberOfColumns;
  }
  
  KDCoordinate Controller::cellHeight() {
    return k_cellHeight;
  }
  
  KDCoordinate Controller::cellWidth() {
    return k_cellWidth;
  }
  
  HighlightCell * Controller::reusableCell(int index) {
    return &m_cells[index];
  }
  
  int Controller::reusableCellCount() {
    return k_maxNumberOfCells;
  }
  
  void Controller::willDisplayCellAtLocation(HighlightCell * cell, int i, int j) {
    AppCell * appCell = (AppCell *)cell;
    int appIndex = (j*k_numberOfColumns+i)+1;
    if (appIndex >= m_container->numberOfApps()) {
      appCell->setVisible(false);
    } else {
      appCell->setVisible(true);
      ::App::Descriptor * descriptor = m_container->appSnapshotAtIndex(appIndex)->descriptor();
      appCell->setAppDescriptor(descriptor);
    }
  }
  
  int Controller::numberOfIcons() {
    assert(m_container->numberOfApps() > 0);
    return m_container->numberOfApps() - 1;
  }
  
  void Controller::tableViewDidChangeSelection(SelectableTableView * t, int previousSelectedCellX, int previousSelectedCellY) {
    /* If the number of apps (including home) is odd, when we display the
     * rightest icon, the icon below is empty. As no icon is thus redrawn on the
     * previous one, the cell is not cleaned. We need to redraw a white rect on
     * the cell to hide the dirtyness below. Ideally, we would have redrawn all
     * the background in white and then redraw visible cells. However, the
     * redrawing takes time and is visible at scrolling. Here, we avoid the
     * background complete redrawing but the code is a bit
     * clumsy. */
    if (m_container->numberOfApps()%2 == 1 && t->selectedRow() == numberOfRows() -1) {
      m_view.reloadBottomRightCorner(this);
    }
    /* To prevent the selectable table view to select cells that are unvisible,
     * we reselect the previous selected cell as soon as the selected cell is
     * unvisible. This trick does not create an endless loop as we ensure not to
     * stay on a unvisible cell and to initialize the first cell on a visible one
     * (so the previous one is always visible). */
    int appIndex = (t->selectedColumn()+t->selectedRow()*k_numberOfColumns)+1;
    if (appIndex >= m_container->numberOfApps()) {
      t->selectCellAtLocation(previousSelectedCellX, previousSelectedCellY);
    }
  }
  
  }