blob: 3c7221fdbf353104043005e7405b69d40411c8ac (
plain)
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
|
/*
Rosegarden
A sequencer and musical notation editor.
This program is Copyright 2000-2008
Guillaume Laurent <glaurent@telegraph-road.org>,
Chris Cannam <cannam@all-day-breakfast.com>,
Richard Bown <bownie@bownie.com>
The moral right of the authors to claim authorship of this work
has been asserted.
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 LEGATO_QUANTIZER_H
#define LEGATO_QUANTIZER_H
#include "Quantizer.h"
namespace Rosegarden {
class BasicQuantizer;
class LegatoQuantizer : public Quantizer
{
public:
// The default unit is the shortest note type. A unit of
// zero means do no quantization -- unlike for BasicQuantizer
// this does have a purpose, as it still does the legato step
LegatoQuantizer(timeT unit = -1);
LegatoQuantizer(std::string source, std::string target, timeT unit = -1);
LegatoQuantizer(const LegatoQuantizer &);
virtual ~LegatoQuantizer();
void setUnit(timeT unit) { m_unit = unit; }
timeT getUnit() const { return m_unit; }
virtual void quantizeRange(Segment *,
Segment::iterator,
Segment::iterator) const;
protected:
virtual void quantizeSingle(Segment *, Segment::iterator,
Segment::iterator &) const;
timeT quantizeTime(timeT) const;
private:
LegatoQuantizer &operator=(const BasicQuantizer &); // not provided
timeT m_unit;
};
}
#endif
|