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
|
/* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
/*
Rosegarden
A MIDI and audio sequencer and musical notation editor.
This program is Copyright 2000-2008
Guillaume Laurent <[email protected]>,
Chris Cannam <[email protected]>,
Richard Bown <[email protected]>
The moral rights of Guillaume Laurent, Chris Cannam, and Richard
Bown to claim authorship of this work have been asserted.
Other copyrights also apply to some parts of this work. Please
see the AUTHORS file and individual file headers for details.
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 _RG_MATRIXHLAYOUT_H_
#define _RG_MATRIXHLAYOUT_H_
#include "base/FastVector.h"
#include "base/LayoutEngine.h"
#include <utility>
#include "base/Event.h"
#include "gui/general/HZoomable.h"
namespace Rosegarden
{
class TimeSignature;
class Staff;
class Composition;
class MatrixHLayout : public HorizontalLayoutEngine
{
public:
MatrixHLayout(Composition *c);
virtual ~MatrixHLayout();
/**
* Resets internal data stores for all staffs
*/
virtual void reset();
/**
* Resets internal data stores for a specific staff
*/
virtual void resetStaff(Staff &staff,
timeT = 0,
timeT = 0);
/**
* Returns the total length of all elements once layout is done.
* This is the x-coord of the end of the last element on the
* longest staff
*/
virtual double getTotalWidth() const;
/**
* Returns the number of the first visible bar line
*/
virtual int getFirstVisibleBar() const;
/**
* Returns the number of the first visible bar line
*/
virtual int getLastVisibleBar() const;
/**
* Returns the x-coordinate of the given bar number
*/
virtual double getBarPosition(int barNo) const;
/**
* Precomputes layout data for a single staff, updating any
* internal data stores associated with that staff and updating
* any layout-related properties in the events on the staff's
* segment.
*/
virtual void scanStaff(Staff&,
timeT = 0,
timeT = 0);
/**
* Computes any layout data that may depend on the results of
* scanning more than one staff. This may mean doing most of
* the layout (likely for horizontal layout) or nothing at all
* (likely for vertical layout).
*/
virtual void finishLayout(timeT = 0,
timeT = 0);
/**
* Returns true if there is a new time signature in the given bar,
* setting timeSignature appropriately and setting timeSigX to its
* x-coord
*/
virtual bool getTimeSignaturePosition(Staff &staff,
int barNo,
TimeSignature &timeSig,
double &timeSigX);
protected:
//--------------- Data members ---------------------------------
// pair of has-time-sig and time-sig
typedef std::pair<bool, TimeSignature> TimeSigData;
// pair of layout-x and time-signature if there is one
typedef std::pair<double, TimeSigData> BarData;
typedef FastVector<BarData> BarDataList;
BarDataList m_barData;
double m_totalWidth;
int m_firstBar;
};
/**
* "zoomable" version of the above, used in the MatrixView
* to properly scale Tempo and Chord rulers.
*
*/
class ZoomableMatrixHLayoutRulerScale : public RulerScale, public HZoomable {
public:
ZoomableMatrixHLayoutRulerScale(MatrixHLayout& layout) : RulerScale(layout.getComposition()), m_referenceHLayout(layout) {};
virtual double getBarPosition(int n) const { return m_referenceHLayout.getBarPosition(n) * getHScaleFactor(); }
virtual double getXForTime(timeT time) const { return m_referenceHLayout.getXForTime(time) * getHScaleFactor(); }
virtual timeT getTimeForX(double x) const { return m_referenceHLayout.getTimeForX(x / getHScaleFactor()); }
virtual double getBarWidth(int n) const { return m_referenceHLayout.getBarWidth(n) * getHScaleFactor(); }
virtual int getLastVisibleBar() const { return m_referenceHLayout.getLastVisibleBar(); }
protected:
MatrixHLayout& m_referenceHLayout;
};
}
#endif
|