MuseScore/libmscore/breath.cpp
2013-05-13 19:43:59 +02:00

110 lines
2.9 KiB
C++

//=============================================================================
// MuseScore
// Music Composition & Notation
//
// Copyright (C) 2002-2011 Werner Schweer
//
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License version 2
// as published by the Free Software Foundation and appearing in
// the file LICENCE.GPL
//=============================================================================
#include "breath.h"
#include "sym.h"
#include "system.h"
#include "segment.h"
#include "measure.h"
#include "score.h"
namespace Ms {
int Breath::symList[Breath::breathSymbols] = {
rcommaSym,
lcommaSym,
caesuraCurvedSym,
caesuraStraight
};
//---------------------------------------------------------
// Breath
//---------------------------------------------------------
Breath::Breath(Score* s)
: Element(s)
{
_breathType = 0;
setFlags(ELEMENT_MOVABLE | ELEMENT_SELECTABLE);
}
//---------------------------------------------------------
// layout
//---------------------------------------------------------
void Breath::layout()
{
setbbox(symbols[score()->symIdx()][symList[breathType()]].bbox(magS()));
}
//---------------------------------------------------------
// write
//---------------------------------------------------------
void Breath::write(Xml& xml) const
{
xml.stag("Breath");
xml.tag("subtype", _breathType);
Element::writeProperties(xml);
xml.etag();
}
//---------------------------------------------------------
// read
//---------------------------------------------------------
void Breath::read(XmlReader& e)
{
while (e.readNextStartElement()) {
if (e.name() == "subtype")
_breathType = e.readInt();
else if (!Element::readProperties(e))
e.unknown();
}
}
//---------------------------------------------------------
// draw
//---------------------------------------------------------
void Breath::draw(QPainter* p) const
{
p->setPen(curColor());
symbols[score()->symIdx()][symList[breathType()]].draw(p, magS());
}
//---------------------------------------------------------
// space
//---------------------------------------------------------
Space Breath::space() const
{
return Space(0.0, spatium() * 1.5);
}
//---------------------------------------------------------
// pagePos
//---------------------------------------------------------
QPointF Breath::pagePos() const
{
if (parent() == 0)
return pos();
System* system = segment()->measure()->system();
qreal yp = y();
if (system)
yp += system->staff(staffIdx())->y() + system->y();
return QPointF(pageX(), yp);
}
}