blob: c83e904bc6fbfbd6c018bffe6557febed8547371 (
about) (
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
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
|
#include "staffline.hh"
#include "scoreline.hh"
#include "dimen.hh"
#include "spanner.hh"
#include "symbol.hh"
#include "paper.hh"
#include "pcol.hh"
#include "pscore.hh"
static String
make_vbox(Interval i)
{
String s("\\vbox to ");
s += print_dimen(i.length());
s += "{\\vskip "+print_dimen(i.max)+" ";
return s;
}
String
Line_of_staff::TeXstring() const
{
String s("%line_of_staff\n");
s+=make_vbox(height());
// the staff itself: eg lines, accolades
s += "\\hbox{";
{
Symbol sym = pstaff_->get_stafsym(scor->score->paper_->linewidth);
s+=sym.tex;
PCursor<const PCol *> cc(scor->cols);
Real lastpos=cc->hpos;
// all items in the current line & staff.
for (; cc.ok(); cc++) {
Real delta=cc->hpos - lastpos;
lastpos = cc->hpos;
// moveover
if (delta)
s +=String( "\\kern ") + print_dimen(delta);
// now output the items.
for (PCursor<const Item *> ic(cc->its); ic.ok(); ic++) {
if (ic->pstaff_ == pstaff_)
s += ic->TeXstring();
}
// spanners.
for (PCursor<const Spanner *> sc(cc->starters); sc.ok(); sc++)
if (sc->pstaff_ == pstaff_)
s += sc->TeXstring();
}
}
s+="\\hss}\\vss}";
return s;
}
Line_of_staff::Line_of_staff(Line_of_score * sc, PStaff*st)
{
scor=sc;
pstaff_=st;
#if 0
const PCol *linestart = sc->cols.top();
const PCol *linestop = sc->cols.bottom();
for (PCursor<const Spanner*> sp(pstaff_->spans); sp.ok(); sp++) {
const PCol *brokenstart = &MAX(*linestart, *sp->left);
const PCol *brokenstop = &MIN(*linestop, *sp->right);
// if (*brokenstop < *brokenstart)
brokenspans.bottom().add(sp->broken_at(0,0));
}
#endif
for (PCursor<const Spanner*> sp(pstaff_->spans); sp.ok(); sp++) {
brokenspans.bottom().add(sp->broken_at(0,0));
}
}
Interval
Line_of_staff::height() const
{
Interval y;
{
Symbol s = pstaff_->stafsym->eval(scor->score->paper_->linewidth);
y = s.dim.y;
}
PCursor<const PCol *> cc(scor->cols);
// all items in the current line & staff.
for (; cc.ok(); cc++) {
for (PCursor<const Item *> ic(cc->its); ic.ok(); ic++) {
if (ic->pstaff_ == pstaff_) {
y.unite(ic->height());
}
// spanners.
for (PCursor<const Spanner *> sc(cc->starters); sc.ok(); sc++)
if (sc->pstaff_ == pstaff_) {
y.unite(sc->height());
}
}
}
return y;
}
|