File: stringdata.h

package info (click to toggle)
musescore3 3.2.3%2Bdfsg2-11
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 210,672 kB
  • sloc: cpp: 291,093; xml: 200,238; sh: 3,779; ansic: 1,447; python: 393; makefile: 240; perl: 82; pascal: 79
file content (71 lines) | stat: -rw-r--r-- 2,922 bytes parent folder | download | duplicates (5)
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
//=============================================================================
//  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 __TABLATURE_H__
#define __TABLATURE_H__

#include "xml.h"

namespace Ms {

class Chord;
class Note;

//---------------------------------------------------------
//   StringData
//---------------------------------------------------------

// defines the string of an instrument
struct instrString {
      int   pitch;      // the pitch of the string
      bool  open;       // true: string is open | false: string is fretted

      bool operator==(const instrString& d) const { return d.pitch == pitch && d.open == open; }
      };

class StringData {
//      QList<int>  stringTable { 40, 45, 50, 55, 59, 64 };   // guitar is default
//      int         _frets = 19;
      QList<instrString>  stringTable {  };                   // no strings by default
      int         _frets = 0;

      static bool bFretting;

      bool        convertPitch(int pitch, int pitchOffset, int* string, int* fret) const;
      int         fret(int pitch, int string, int pitchOffset) const;
      int         getPitch(int string, int fret, int pitchOffset) const;
      void        sortChordNotes(QMap<int, Note *>& sortedNotes, const Chord* chord, int pitchOffset, int* count) const;

public:
      StringData() {}
      StringData(int numFrets, int numStrings, int strings[]);
      StringData(int numFrets, QList<instrString>& strings);
      bool        convertPitch(int pitch, Staff* staff, const Fraction& tick, int* string, int* fret) const;
      int         fret(int pitch, int string, Staff* staff, const Fraction& tick) const;
      void        fretChords(Chord * chord) const;
      int         getPitch(int string, int fret, Staff* staff, const Fraction& tick) const;
      static int  pitchOffsetAt(Staff* staff, const Fraction& tick);
      int         strings() const                   { return stringTable.size(); }
      int         frettedStrings() const;
      const QList<instrString>&  stringList() const { return stringTable; }
      QList<instrString>&  stringList()         { return stringTable; }
      int         frets() const                 { return _frets; }
      void        setFrets(int val)             { _frets = val; }
      void        read(XmlReader&);
      void        write(XmlWriter&) const;
      void        writeMusicXML(XmlWriter& xml) const;
      bool operator==(const StringData& d) const { return d._frets == _frets && d.stringTable == stringTable; }
      };

}     // namespace Ms
#endif