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
|
// -*- c-basic-offset: 4 -*-
/*
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 NOTATION_QUANTIZER_H_
#define NOTATION_QUANTIZER_H_
#include "Quantizer.h"
namespace Rosegarden {
class NotationQuantizer : public Quantizer
{
public:
NotationQuantizer();
NotationQuantizer(std::string source, std::string target);
NotationQuantizer(const NotationQuantizer &);
~NotationQuantizer();
/**
* Set the absolute time minimum unit. Default is demisemiquaver.
*/
void setUnit(timeT);
timeT getUnit() const;
/**
* Set the simplicity factor. This controls the relative "pull"
* towards larger units and more obvious beats in placing notes.
* The value 10 means no pull to larger units, lower values mean
* an active pull away from them. Default is 13.
*/
void setSimplicityFactor(int);
int getSimplicityFactor() const;
/**
* Set the maximum size of tuplet group. 2 = two-in-the-time-of-three
* groupings, 3 = triplets, etc. Default is 3. Set <2 to switch off
* tuplets altogether.
*/
void setMaxTuplet(int);
int getMaxTuplet() const;
/**
* Set whether we assume the music may be contrapuntal -- that is,
* may have notes that overlap rather than simply a sequence of
* individual notes and chords.
*/
void setContrapuntal(bool);
bool getContrapuntal() const;
/**
* Set whether to add articulations (staccato, tenuto, slurs).
* Default is true. Doesn't affect quantization, only the marks
* that are added to quantized notes.
*/
void setArticulate(bool);
bool getArticulate() const;
protected:
virtual void quantizeRange(Segment *,
Segment::iterator,
Segment::iterator) const;
protected:
// avoid having to rebuild absolutely everything each time we
// tweak the implementation
class Impl;
Impl *m_impl;
private:
NotationQuantizer &operator=(const NotationQuantizer &); // not provided
};
}
#endif
|