MuseScore/libmscore/spatium.h

111 lines
2.8 KiB
C
Raw Normal View History

2012-05-26 14:26:10 +02:00
//=============================================================================
// 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 __SPATIUM_H__
#define __SPATIUM_H__
2013-05-13 18:49:17 +02:00
namespace Ms {
2012-05-26 14:26:10 +02:00
//---------------------------------------------------------
// Spatium
// - a unit of measure
// - the distance between two note lines
// - used for many layout items
//---------------------------------------------------------
class Spatium {
qreal _val;
public:
Spatium() { _val = 0.0; }
explicit Spatium(qreal v) { _val = v; }
qreal val() const { return _val; }
bool operator>(const Spatium& a) const { return _val > a._val; }
bool operator<(const Spatium& a) const { return _val < a._val; }
bool operator==(const Spatium& a) const { return _val == a._val; }
bool operator!=(const Spatium& a) const { return _val != a._val; }
bool isZero() const { return _val == 0.0; }
Spatium& operator+=(const Spatium& a) {
_val += a._val;
return *this;
}
Spatium& operator-=(const Spatium& a) {
_val -= a._val;
return *this;
}
Spatium& operator/=(qreal d) {
_val /= d;
return *this;
}
qreal operator/(const Spatium& b) {
return _val / b._val;
}
Spatium& operator*=(int d) {
_val *= d;
return *this;
}
Spatium& operator*=(qreal d) {
_val *= d;
return *this;
}
Spatium operator-() const { return Spatium(-_val); }
};
inline Spatium operator+(const Spatium& a, const Spatium& b)
{
Spatium r(a);
r += b;
return r;
}
inline Spatium operator-(const Spatium& a, const Spatium& b)
{
Spatium r(a);
r -= b;
return r;
}
inline Spatium operator/(const Spatium& a, qreal b)
{
Spatium r(a);
r /= b;
return r;
}
inline Spatium operator*(const Spatium& a, int b)
{
Spatium r(a);
r *= b;
return r;
}
inline Spatium operator*(int a, const Spatium& b)
{
Spatium r(b);
r *= a;
return r;
}
inline Spatium operator*(const Spatium& a, qreal b)
{
Spatium r(a);
r *= b;
return r;
}
inline Spatium operator*(qreal a, const Spatium& b)
{
Spatium r(b);
r *= a;
return r;
}
2013-05-13 18:49:17 +02:00
} // namespace Ms
2012-05-26 14:26:10 +02:00
#endif