MuseScore Plugins 3.3
Plugins API for MuseScore
Loading...
Searching...
No Matches
score.h
1//=============================================================================
2// MuseScore
3// Music Composition & Notation
4//
5// Copyright (C) 2019 Werner Schweer and others
6//
7// This program is free software; you can redistribute it and/or modify
8// it under the terms of the GNU General Public License version 2
9// as published by the Free Software Foundation and appearing in
10// the file LICENCE.GPL
11//=============================================================================
12
13#ifndef __PLUGIN_API_SCORE_H__
14#define __PLUGIN_API_SCORE_H__
15
16#include "scoreelement.h"
17#include "part.h"
18#include "style.h"
19#include "excerpt.h"
20#include "libmscore/score.h"
21
22namespace Ms {
23
24class InstrumentTemplate;
25
26namespace PluginAPI {
27
28class Cursor;
29class Segment;
30class Measure;
31class Selection;
32class Score;
33class Staff;
34
35extern Selection* selectionWrap(Ms::Selection* select);
36
37//---------------------------------------------------------
38// Score
39//---------------------------------------------------------
40
42 Q_OBJECT
44 Q_PROPERTY(QString composer READ composer)
46 Q_PROPERTY(int duration READ duration)
48 Q_PROPERTY(QQmlListProperty<Ms::PluginAPI::Excerpt> excerpts READ excerpts)
58 Q_PROPERTY(int harmonyCount READ harmonyCount)
60 Q_PROPERTY(bool hasHarmonies READ hasHarmonies)
62 Q_PROPERTY(bool hasLyrics READ hasLyrics)
65 Q_PROPERTY(int keysig READ keysig)
75 Q_PROPERTY(Ms::PluginAPI::Segment* lastSegment READ lastSegment) // TODO: make it function? Was property in 2.X, but firstSegment is a function...
77 Q_PROPERTY(int lyricCount READ lyricCount)
79 Q_PROPERTY(QString scoreName READ name WRITE setName)
81 Q_PROPERTY(int nmeasures READ nmeasures)
83 Q_PROPERTY(int npages READ npages)
85 Q_PROPERTY(int nstaves READ nstaves)
87 Q_PROPERTY(int ntracks READ ntracks)
88// Q_PROPERTY(Ms::PageFormat* pageFormat READ pageFormat WRITE undoChangePageFormat)
90 Q_PROPERTY(QQmlListProperty<Ms::PluginAPI::Part> parts READ parts)
92 Q_PROPERTY(QString lyricist READ lyricist)
93// Q_PROPERTY(QString subtitle READ subtitle)
95 Q_PROPERTY(QString title READ title)
97 Q_PROPERTY(QString mscoreVersion READ mscoreVersion)
99 Q_PROPERTY(QString mscoreRevision READ mscoreRevision)
103 Q_PROPERTY(Ms::PluginAPI::MStyle* style READ style)
112 Q_PROPERTY(int pageNumberOffset READ pageNumberOffset WRITE setPageNumberOffset)
113
118 Q_PROPERTY(QQmlListProperty<Ms::PluginAPI::Staff> staves READ staves)
119
125 Q_PROPERTY(QString path READ path)
126
127
128 public:
130 Score(Ms::Score* s = nullptr, Ownership o = Ownership::SCORE)
131 : ScoreElement(s, o) {}
132
133 Ms::Score* score() { return toScore(e); }
134 const Ms::Score* score() const { return toScore(e); }
135
136 QString composer() { return score()->metaTag("composer"); }
137 int duration() { return score()->duration(); }
138 int harmonyCount() { return score()->harmonyCount(); }
139 bool hasHarmonies() { return score()->hasHarmonies(); }
140 bool hasLyrics() { return score()->hasLyrics(); }
141 int keysig() { return score()->keysig(); }
142 int lyricCount() { return score()->lyricCount(); }
143 QString lyricist() { return score()->metaTag("lyricist"); } // not the meanwhile obsolete "poet"
144 QString title() { return score()->metaTag("workTitle"); }
145 Ms::PluginAPI::Selection* selection() { return selectionWrap(&score()->selection()); }
146 MStyle* style() { return wrap(&score()->style(), score()); }
147 QString path() { return score()->importedFilePath(); }
148
149 int pageNumberOffset() const { return score()->pageNumberOffset(); }
150 void setPageNumberOffset(int offset) { score()->undoChangePageNumberOffset(offset); }
151
153
155 Q_INVOKABLE QString metaTag(const QString& tag) const { return score()->metaTag(tag); }
157 Q_INVOKABLE void setMetaTag(const QString& tag, const QString& val) { score()->setMetaTag(tag, val); }
158
167 Q_INVOKABLE void appendPart(const QString& instrumentId);
177 Q_INVOKABLE void appendPartByMusicXmlId(const QString& instrumentMusicXmlId);
178
180 Q_INVOKABLE void appendMeasures(int n) { score()->appendMeasures(n); }
181 Q_INVOKABLE void addText(const QString& type, const QString& text);
183 Q_INVOKABLE Ms::PluginAPI::Cursor* newCursor();
184
185 Q_INVOKABLE Ms::PluginAPI::Segment* firstSegment(); // TODO: segment type
188
193
194 QString name() const { return score()->masterScore()->title(); }
195 void setName(const QString& name) { score()->masterScore()->setName(name); }
197
198 Q_INVOKABLE QString extractLyrics() { return score()->extractLyrics(); }
199
200// //@ ??
201// Q_INVOKABLE void updateRepeatList(bool expandRepeats) { score()->updateRepeatList(); } // TODO: needed?
202
204 int nmeasures() const { return score()->nmeasures(); }
205 int npages() const { return score()->npages(); }
206 int nstaves() const { return score()->nstaves(); }
207 int ntracks() const { return score()->ntracks(); }
209
218 Q_INVOKABLE void startCmd();
228 Q_INVOKABLE void endCmd(bool rollback = false) { score()->endCmd(rollback); }
229
237 Q_INVOKABLE void createPlayEvents() { score()->createPlayEvents(); }
238
240 QString mscoreVersion() { return score()->mscoreVersion(); }
241 QString mscoreRevision() { return QString::number(score()->mscoreRevision(), /* base */ 16); }
242
243 QQmlListProperty<Part> parts() { return wrapContainerProperty<Part>(this, score()->parts()); }
244 QQmlListProperty<Excerpt> excerpts() { return wrapExcerptsContainerProperty<Excerpt>(this, score()->excerpts()); }
245 QQmlListProperty<Staff> staves();
246
247 static const Ms::InstrumentTemplate* instrTemplateFromName(const QString& name); // used by PluginAPI::newScore()
249 };
250} // namespace PluginAPI
251} // namespace Ms
252#endif
Cursor can be used by plugins to manipulate the score.
Definition cursor.h:53
Definition excerpt.h:35
Provides an access to score style settings.
Definition style.h:47
Definition elements.h:781
Definition part.h:42
Main class of the plugins framework. Named as MuseScore in QML.
Definition qmlpluginapi.h:62
Base class for most of object wrappers exposed to QML.
Definition scoreelement.h:42
QString name
Name of this element's type, not localized.
Definition scoreelement.h:54
int type
Type of this element.
Definition scoreelement.h:48
Definition score.h:41
Ms::PluginAPI::Measure * firstMeasureMM
First multimeasure rest measure of the score (read only).
Definition score.h:56
QString scoreName
Name of the score, without path leading to it and extension.
Definition score.h:79
Ms::PluginAPI::Measure * lastMeasureMM
Last multimeasure rest measure of the score (read only).
Definition score.h:73
Q_INVOKABLE Ms::PluginAPI::Cursor * newCursor()
Creates and returns a cursor to be used to navigate in the score.
Definition score.cpp:32
bool hasHarmonies
Whether score has harmonies (chord symbols) (read only).
Definition score.h:60
int lyricCount
Number of lyrics items (syllables) in the score (read only).
Definition score.h:77
int npages
Number of pages (read only)
Definition score.h:83
QString path
Returns the path to the file from which the score was imported, or empty.
Definition score.h:125
Q_INVOKABLE void appendPart(const QString &instrumentId)
Appends a part with the instrument defined by instrumentId to this score.
Definition score.cpp:110
QQmlListProperty< Ms::PluginAPI::Excerpt > excerpts
List of the excerpts (linked parts) (read only)
Definition score.h:48
QString composer
Composer of the score, as taken from the score properties (read only).
Definition score.h:44
Q_INVOKABLE void addText(const QString &type, const QString &text)
Adds a header text to the score.
Definition score.cpp:49
Ms::PluginAPI::Segment * lastSegment
Last score segment (read only)
Definition score.h:75
int ntracks
Number of tracks (nstaves * 4) (read only)
Definition score.h:87
Q_INVOKABLE void setMetaTag(const QString &tag, const QString &val)
Sets the metatag named tag to val.
Definition score.h:157
Q_INVOKABLE void appendMeasures(int n)
Appends a number of measures to this score.
Definition score.h:180
Ms::PluginAPI::Selection * selection
Current selections for the score.
Definition score.h:101
int nmeasures
Number of measures (read only)
Definition score.h:81
Ms::PluginAPI::MStyle * style
Style settings for this score.
Definition score.h:103
QString lyricist
Lyricist of score, as taken from the score properties.
Definition score.h:92
Q_INVOKABLE void createPlayEvents()
Create PlayEvents for all notes based on ornamentation.
Definition score.h:237
Q_INVOKABLE void startCmd()
For "dock" type plugins: to be used before score modifications to make them undoable.
Definition score.cpp:204
Q_INVOKABLE void endCmd(bool rollback=false)
For "dock" type plugins: to be used after score modifications to make them undoable.
Definition score.h:228
Q_INVOKABLE QString metaTag(const QString &tag) const
Returns as a string the metatag named tag.
Definition score.h:155
QQmlListProperty< Ms::PluginAPI::Staff > staves
List of staves in this score.
Definition score.h:118
QString title
Title of score, as taken from the score properties' workTitle (read only).
Definition score.h:95
Ms::PluginAPI::Measure * firstMeasure
First measure of the score (read only)
Definition score.h:50
Ms::PluginAPI::Measure * lastMeasure
Last measure of the score (read only)
Definition score.h:67
QQmlListProperty< Ms::PluginAPI::Part > parts
The list of parts.
Definition score.h:90
int nstaves
Number of staves (read only)
Definition score.h:85
Q_INVOKABLE void appendPartByMusicXmlId(const QString &instrumentMusicXmlId)
Appends a part with the instrument defined by the given MusicXML ID to this score.
Definition score.cpp:126
int duration
Duration of score in seconds (read only).
Definition score.h:46
int harmonyCount
Number of harmony items (chord symbols) in the score (read only).
Definition score.h:58
QString mscoreRevision
MuseScore revision the score has been last saved with (includes autosave) (read only)
Definition score.h:99
int keysig
Key signature at the start of the score, in number of accidentals, negative for flats,...
Definition score.h:65
int pageNumberOffset
Page numbering offset.
Definition score.h:112
QString mscoreVersion
MuseScore version the score has been last saved with (includes autosave) (read only)
Definition score.h:97
bool hasLyrics
Whether score has lyrics (read only).
Definition score.h:62
Definition elements.h:715
Definition selection.h:28
Definition elements.h:873
Definition cursor.cpp:30