MuseScore/libmscore/fret.h

101 lines
2.9 KiB
C
Raw Normal View History

2012-05-26 14:26:10 +02:00
//=============================================================================
// MuseScore
// Music Composition & Notation
//
// Copyright (C) 2010-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 __FRET_H__
#define __FRET_H__
#include "element.h"
2013-05-13 18:49:17 +02:00
namespace Ms {
class StringData;
2012-05-26 14:26:10 +02:00
class Chord;
class Harmony;
//---------------------------------------------------------
2012-07-25 11:49:34 +02:00
// @@ FretDiagram
/// Fretboard diagram
2012-05-26 14:26:10 +02:00
//---------------------------------------------------------
class FretDiagram : public Element {
Q_OBJECT
2012-05-26 14:26:10 +02:00
int _strings;
int maxStrings;
int _frets;
int _fretOffset;
int _maxFrets;
2012-05-26 14:26:10 +02:00
char* _dots;
char* _marker;
char* _fingering;
2012-05-26 14:26:10 +02:00
Harmony* _harmony;
qreal lw1;
qreal lw2; // top line
qreal stringDist;
qreal fretDist;
QFont font;
public:
FretDiagram(Score* s);
FretDiagram(const FretDiagram&);
~FretDiagram();
virtual void draw(QPainter*) const;
virtual FretDiagram* clone() const { return new FretDiagram(*this); }
virtual Element::Type type() const { return Element::Type::FRET_DIAGRAM; }
2012-05-26 14:26:10 +02:00
virtual void layout();
virtual void write(Xml& xml) const;
2013-01-11 18:10:18 +01:00
virtual void read(XmlReader&);
2012-05-26 14:26:10 +02:00
virtual QLineF dragAnchor() const;
virtual QPointF pagePos() const;
// read / write MusicXML
2013-01-11 18:10:18 +01:00
void readMusicXML(XmlReader& de);
2012-05-26 14:26:10 +02:00
void writeMusicXML(Xml& xml) const;
int strings() const { return _strings; }
int frets() const { return _frets; }
void setOffset(int offset);
2012-05-26 14:26:10 +02:00
void setStrings(int n);
void setFrets(int n) { _frets = n; }
void setDot(int string, int fret);
void setMarker(int string, int marker);
void setFingering(int string, int finger);
int fretOffset() const { return _fretOffset; }
void setFretOffset(int val) { _fretOffset = val; }
int maxFrets() const { return _maxFrets; }
void setMaxFrets(int val) { _maxFrets = val; }
2014-08-12 12:55:38 +02:00
char dot(int s) const { return _dots ? _dots[s] : 0; }
char marker(int s) const { return _marker ? _marker[s] : 0; }
char fingering(int s) const { return _fingering ? _fingering[s] : 0; }
2012-12-10 21:15:28 +01:00
Harmony* harmony() const { return _harmony; }
void init(Ms::StringData *, Chord*);
2012-05-26 14:26:10 +02:00
virtual void add(Element*);
virtual void remove(Element*);
2014-08-13 21:01:21 +02:00
virtual bool acceptDrop(const DropData&) const override;
2012-05-26 14:26:10 +02:00
virtual Element* drop(const DropData&);
virtual void scanElements(void* data, void (*func)(void*, Element*), bool all=true);
};
2013-05-13 18:49:17 +02:00
} // namespace Ms
2012-05-26 14:26:10 +02:00
#endif