diff options
author | tpearson <tpearson@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2010-03-01 18:37:05 +0000 |
---|---|---|
committer | tpearson <tpearson@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2010-03-01 18:37:05 +0000 |
commit | 145364a8af6a1fec06556221e66d4b724a62fc9a (patch) | |
tree | 53bd71a544008c518034f208d64c932dc2883f50 /src/base/Equation.h | |
download | rosegarden-145364a8af6a1fec06556221e66d4b724a62fc9a.tar.gz rosegarden-145364a8af6a1fec06556221e66d4b724a62fc9a.zip |
Added old abandoned KDE3 version of the RoseGarden MIDI tool
git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/applications/rosegarden@1097595 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'src/base/Equation.h')
-rw-r--r-- | src/base/Equation.h | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/src/base/Equation.h b/src/base/Equation.h new file mode 100644 index 0000000..61377a5 --- /dev/null +++ b/src/base/Equation.h @@ -0,0 +1,51 @@ +// -*- c-basic-offset: 4 -*- + + +/* + Rosegarden + A sequencer and musical notation editor. + + This program is Copyright 2000-2008 + Guillaume Laurent <glaurent@telegraph-road.org>, + Chris Cannam <cannam@all-day-breakfast.com>, + Richard Bown <bownie@bownie.com> + + The moral right of the authors to claim authorship of this work + has been asserted. + + 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 _EQUATION_H_ +#define _EQUATION_H_ + +namespace Rosegarden { + +/** + * Equation solving helper class + */ +class Equation +{ +public: + enum Unknown { Y, M, X, C }; + + struct Point { + Point(int xx, int yy) : x(xx), y(yy) { } + int x; + int y; + }; + + static void solve(Unknown u, double &y, double &m, double &x, double &c); + static void solve(Unknown u, int &y, double &m, int &x, int &c); + + static void solveForYByEndPoints(Point a, Point b, double x, double &y); + static void solveForYByEndPoints(Point a, Point b, int x, int &y); +}; + +} + +#endif |