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
|
/* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
/*
Sonic Visualiser
An audio file viewer and annotation editor.
Centre for Digital Music, Queen Mary, University of London.
This file copyright 2006 Chris Cannam.
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License as
published by the Free Software Foundation; either version 2 of the
License, or (at your option) any later version. See the file
COPYING included with this distribution for more information.
*/
#ifndef SV_SELECTION_H
#define SV_SELECTION_H
#include <cstddef>
#include <set>
#include "XmlExportable.h"
#include "BaseTypes.h"
namespace sv {
/**
* A selection object simply represents a range in time, via start and
* end frame.
*
* The end frame is the index of the frame just *after* the end of the
* selection. For example a selection of length 10 frames starting at
* time 0 will have start frame 0 and end frame 10. This will be
* contiguous with (rather than overlapping with) a selection that
* starts at frame 10.
*
* Any selection with equal start and end frames is empty,
* representing "no selection". All empty selections are equal under
* the comparison operators. The default constructor makes an empty
* selection with start and end frames equal to zero.
*/
class Selection
{
public:
Selection();
Selection(sv_frame_t startFrame, sv_frame_t endFrame);
Selection(const Selection &);
Selection &operator=(const Selection &);
virtual ~Selection();
bool isEmpty() const;
sv_frame_t getStartFrame() const;
sv_frame_t getEndFrame() const;
sv_frame_t getDuration() const { return getEndFrame() - getStartFrame(); }
bool contains(sv_frame_t frame) const;
bool operator<(const Selection &) const;
bool operator==(const Selection &) const;
protected:
sv_frame_t m_startFrame;
sv_frame_t m_endFrame;
};
class MultiSelection : public XmlExportable
{
public:
MultiSelection();
virtual ~MultiSelection();
typedef std::set<Selection> SelectionList;
const SelectionList &getSelections() const;
void setSelection(const Selection &selection);
void addSelection(const Selection &selection);
void removeSelection(const Selection &selection);
void clearSelections();
void getExtents(sv_frame_t &startFrame, sv_frame_t &endFrame) const;
/**
* Return the selection that contains a given frame.
* If defaultToFollowing is true, and if the frame is not in a
* selected area, return the next selection after the given frame.
* Return the empty selection if no appropriate selection is found.
*/
Selection getContainingSelection(sv_frame_t frame,
bool defaultToFollowing) const;
void toXml(QTextStream &stream, QString indent = "",
QString extraAttributes = "") const override;
// Debug only, not interop
QString toString() const;
protected:
SelectionList m_selections;
};
} // end namespace sv
#endif
|