151 lines
5.9 KiB
C++
151 lines
5.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
|
|
//=============================================================================
|
|
|
|
#ifndef __TIMESIG_H__
|
|
#define __TIMESIG_H__
|
|
|
|
#include "element.h"
|
|
#include "sig.h"
|
|
#include "mscore.h"
|
|
#include "groups.h"
|
|
|
|
namespace Ms {
|
|
|
|
class MuseScoreView;
|
|
class Segment;
|
|
|
|
enum class TimeSigType : char {
|
|
NORMAL, // use sz/sn text
|
|
FOUR_FOUR, // common time (4/4)
|
|
ALLA_BREVE, // cut time (2/2)
|
|
};
|
|
|
|
//---------------------------------------------------------------------------------------
|
|
// @@ TimeSig
|
|
/// This class represents a time signature.
|
|
//
|
|
// @P denominator int (read only)
|
|
// @P denominatorStretch int (read only)
|
|
// @P denominatorString string text of denominator
|
|
// @P groups Groups
|
|
// @P numerator int (read only)
|
|
// @P numeratorStretch int (read only)
|
|
// @P numeratorString string text of numerator
|
|
// @P showCourtesySig bool show courtesy time signature for this sig if appropriate
|
|
//---------------------------------------------------------------------------------------
|
|
|
|
class TimeSig : public Element {
|
|
Q_GADGET
|
|
Q_PROPERTY(int denominator READ denominator)
|
|
Q_PROPERTY(int denominatorStretch READ denominatorStretch)
|
|
Q_PROPERTY(QString denominatorString READ denominatorString WRITE undoSetDenominatorString)
|
|
Q_PROPERTY(Ms::Groups groups READ groups WRITE undoSetGroups)
|
|
Q_PROPERTY(int numerator READ numerator)
|
|
Q_PROPERTY(int numeratorStretch READ numeratorStretch)
|
|
Q_PROPERTY(QString numeratorString READ numeratorString WRITE undoSetNumeratorString)
|
|
Q_PROPERTY(bool showCourtesySig READ showCourtesySig WRITE undoSetShowCourtesySig)
|
|
|
|
TimeSigType _timeSigType;
|
|
QString _numeratorString; // calculated from actualSig() if !customText
|
|
QString _denominatorString;
|
|
QPointF pz, pn, pointLargeLeftParen, pointLargeRightParen;
|
|
Fraction _sig;
|
|
Fraction _stretch; // localSig / globalSig
|
|
bool _showCourtesySig;
|
|
bool customText; // if false, sz and sn are calculated from _sig
|
|
bool _needLayout;
|
|
bool _largeParentheses;
|
|
Groups _groups;
|
|
|
|
void layout1();
|
|
|
|
public:
|
|
TimeSig(Score* = 0);
|
|
|
|
QString ssig() const;
|
|
void setSSig(const QString&);
|
|
|
|
virtual TimeSig* clone() const override;
|
|
virtual ElementType type() const override { return ElementType::TIMESIG; }
|
|
|
|
TimeSigType timeSigType() const { return _timeSigType; }
|
|
|
|
bool operator==(const TimeSig&) const;
|
|
|
|
virtual qreal mag() const override;
|
|
virtual void draw(QPainter*) const override;
|
|
virtual void write(XmlWriter& xml) const override;
|
|
virtual void read(XmlReader&) override;
|
|
virtual void layout() override;
|
|
|
|
Fraction sig() const { return _sig; }
|
|
void setSig(const Fraction& f, TimeSigType st = TimeSigType::NORMAL);
|
|
//@ sets the time signature
|
|
Q_INVOKABLE void setSig(int z, int n, int st = static_cast<int>(TimeSigType::NORMAL)) { setSig(Fraction(z, n), static_cast<TimeSigType>(st)); }
|
|
int numerator() const { return _sig.numerator(); }
|
|
int denominator() const { return _sig.denominator(); }
|
|
|
|
Fraction stretch() const { return _stretch; }
|
|
void setStretch(const Fraction& s) { _stretch = s; }
|
|
int numeratorStretch() const { return _stretch.numerator(); }
|
|
int denominatorStretch() const { return _stretch.denominator(); }
|
|
|
|
bool acceptDrop(const DropData&) const override;
|
|
virtual Element* drop(const DropData&) override;
|
|
|
|
Segment* segment() const { return (Segment*)parent(); }
|
|
Measure* measure() const { return (Measure*)parent()->parent(); }
|
|
|
|
bool showCourtesySig() const { return _showCourtesySig; }
|
|
void setShowCourtesySig(bool v) { _showCourtesySig = v; }
|
|
void undoSetShowCourtesySig(bool v);
|
|
|
|
QString numeratorString() const { return _numeratorString; }
|
|
void setNumeratorString(const QString&);
|
|
void undoSetNumeratorString(const QString&);
|
|
|
|
QString denominatorString() const { return _denominatorString; }
|
|
void setDenominatorString(const QString&);
|
|
void undoSetDenominatorString(const QString&);
|
|
|
|
void setLargeParentheses(bool v) { _largeParentheses = v; }
|
|
|
|
void setFrom(const TimeSig*);
|
|
|
|
virtual QVariant getProperty(P_ID propertyId) const override;
|
|
virtual bool setProperty(P_ID propertyId, const QVariant&) override;
|
|
virtual QVariant propertyDefault(P_ID id) const override;
|
|
|
|
bool hasCustomText() const { return customText; }
|
|
|
|
virtual void spatiumChanged(qreal /*oldValue*/, qreal /*newValue*/) override;
|
|
virtual void localSpatiumChanged(qreal /*oldValue*/, qreal /*newValue*/) override;
|
|
|
|
void setNeedLayout(bool nl) { _needLayout = nl; }
|
|
|
|
const Groups& groups() const { return _groups; }
|
|
void setGroups(const Groups& e) { _groups = e; }
|
|
void undoSetGroups(const Groups& e);
|
|
|
|
Fraction globalSig() const { return (_sig * _stretch).reduced(); }
|
|
void setGlobalSig(const Fraction& f) { _stretch = (_sig / f).reduced(); }
|
|
|
|
bool isLocal() const { return _stretch != Fraction(1,1); }
|
|
|
|
virtual Element* nextElement();
|
|
virtual Element* prevElement();
|
|
virtual QString accessibleInfo() const override;
|
|
};
|
|
|
|
} // namespace Ms
|
|
#endif
|
|
|