mirror of
https://github.com/subsurface/subsurface.git
synced 2025-02-19 22:16:15 +00:00
statistics: implement shift-selection of ranges
For all the series but the scatter series (which supports lasso selection), implement a range-selection using shift. The code is fairly similar for all series and one might think about factoring it out. But why bother? Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
This commit is contained in:
parent
43b0ccca3e
commit
2943b1cbde
6 changed files with 80 additions and 6 deletions
|
@ -31,6 +31,21 @@ bool BarSeries::Index::operator==(const Index &i2) const
|
|||
return std::tie(bar, subitem) == std::tie(i2.bar, i2.subitem);
|
||||
}
|
||||
|
||||
// Note: only defined for valid indices.
|
||||
bool BarSeries::Index::operator<=(const Index &i2) const
|
||||
{
|
||||
return std::tie(bar, subitem) <= std::tie(i2.bar, i2.subitem);
|
||||
}
|
||||
|
||||
// Note: only defined for valid indices.
|
||||
void BarSeries::inc(Index &index)
|
||||
{
|
||||
if (++index.subitem < binCount())
|
||||
return;
|
||||
++index.bar;
|
||||
index.subitem = 0;
|
||||
}
|
||||
|
||||
BarSeries::BarSeries(StatsView &view, StatsAxis *xAxis, StatsAxis *yAxis,
|
||||
bool horizontal, bool stacked, const QString &categoryName,
|
||||
const StatsVariable *valueVariable, std::vector<QString> valueBinNames) :
|
||||
|
@ -415,9 +430,25 @@ bool BarSeries::selectItemsUnderMouse(const QPointF &pos, SelectionModifier modi
|
|||
{
|
||||
Index index = getItemUnderMouse(pos);
|
||||
|
||||
if (modifier.shift && index.bar < 0)
|
||||
return false;
|
||||
|
||||
if (!modifier.shift || lastClicked.bar < 0)
|
||||
lastClicked = index;
|
||||
|
||||
std::vector<dive *> divesUnderMouse;
|
||||
if (index.bar >= 0)
|
||||
if (modifier.shift && lastClicked.bar >= 0 && index.bar >= 0) {
|
||||
Index first = lastClicked;
|
||||
Index last = index;
|
||||
if (last <= first)
|
||||
std::swap(first, last);
|
||||
for (Index idx = first; idx <= last; inc(idx)) {
|
||||
const std::vector<dive *> &dives = items[idx.bar].subitems[idx.subitem].dives;
|
||||
divesUnderMouse.insert(divesUnderMouse.end(), dives.begin(), dives.end());
|
||||
}
|
||||
} else if (index.bar >= 0) {
|
||||
divesUnderMouse = items[index.bar].subitems[index.subitem].dives;
|
||||
}
|
||||
processSelection(std::move(divesUnderMouse), modifier);
|
||||
|
||||
return index.bar >= 0;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue