9843867331
Semi realtime midi - simplify rhythms
1242 lines
51 KiB
C++
1242 lines
51 KiB
C++
//=============================================================================
|
|
// MuseScore
|
|
// Music Composition & Notation
|
|
//
|
|
// Copyright (C) 2002-2012 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 __SCORE_H__
|
|
#define __SCORE_H__
|
|
|
|
/**
|
|
\file
|
|
Definition of Score class.
|
|
*/
|
|
|
|
#include "config.h"
|
|
#include "input.h"
|
|
#include "select.h"
|
|
#include "synthesizerstate.h"
|
|
#include "mscoreview.h"
|
|
#include "segment.h"
|
|
#include "ottava.h"
|
|
#include "spannermap.h"
|
|
#include "rehearsalmark.h"
|
|
|
|
class QPainter;
|
|
|
|
namespace Ms {
|
|
|
|
class Articulation;
|
|
class Audio;
|
|
class BarLine;
|
|
class Beam;
|
|
class Bracket;
|
|
class BSymbol;
|
|
class Chord;
|
|
class ChordRest;
|
|
class Clef;
|
|
class Cursor;
|
|
class Dynamic;
|
|
class ElementList;
|
|
class EventMap;
|
|
class Excerpt;
|
|
class FiguredBass;
|
|
class Fingering;
|
|
class Hairpin;
|
|
class Harmony;
|
|
class Instrument;
|
|
class KeyList;
|
|
class KeySig;
|
|
class KeySigEvent;
|
|
class LinkedElements;
|
|
class Lyrics;
|
|
class Measure;
|
|
class MeasureBase;
|
|
class MuseScoreView;
|
|
class Note;
|
|
class Omr;
|
|
class Page;
|
|
class PageFormat;
|
|
class Parameter;
|
|
class Part;
|
|
class RepeatList;
|
|
class Rest;
|
|
class Revisions;
|
|
class ScoreFont;
|
|
class Segment;
|
|
class Selection;
|
|
class SigEvent;
|
|
class Slur;
|
|
class Spanner;
|
|
class Staff;
|
|
class System;
|
|
class TempoMap;
|
|
class Text;
|
|
class TextStyle;
|
|
class TimeSig;
|
|
class TimeSigMap;
|
|
class Tuplet;
|
|
class Undo;
|
|
class UndoCommand;
|
|
class UndoStack;
|
|
class Volta;
|
|
class Xml;
|
|
struct Channel;
|
|
struct Interval;
|
|
struct TEvent;
|
|
struct LayoutContext;
|
|
|
|
enum class ClefType : signed char;
|
|
enum class BeatType : char;
|
|
enum class SymId;
|
|
enum class Key;
|
|
|
|
extern bool showRubberBand;
|
|
|
|
enum class POS : char { CURRENT, LEFT, RIGHT };
|
|
|
|
enum class Pad : char {
|
|
NOTE00,
|
|
NOTE0,
|
|
NOTE1,
|
|
NOTE2,
|
|
NOTE4,
|
|
NOTE8,
|
|
NOTE16,
|
|
NOTE32,
|
|
NOTE64,
|
|
NOTE128,
|
|
//--------------------
|
|
REST,
|
|
DOT,
|
|
DOTDOT,
|
|
DOT3,
|
|
DOT4
|
|
};
|
|
|
|
//---------------------------------------------------------
|
|
// LayoutMode
|
|
// PAGE The normal page view, honors page and line breaks.
|
|
// LINE The panoramic view, one long system
|
|
// FLOAT The "reflow" mode, ignore page and line breaks
|
|
// SYSTEM The "never ending page", page break are turned into line break
|
|
//---------------------------------------------------------
|
|
|
|
enum class LayoutMode : char {
|
|
PAGE, FLOAT, LINE, SYSTEM
|
|
};
|
|
|
|
//---------------------------------------------------------
|
|
// MeasureBaseList
|
|
//---------------------------------------------------------
|
|
|
|
class MeasureBaseList {
|
|
int _size;
|
|
MeasureBase* _first;
|
|
MeasureBase* _last;
|
|
|
|
void push_back(MeasureBase* e);
|
|
void push_front(MeasureBase* e);
|
|
|
|
public:
|
|
MeasureBaseList();
|
|
MeasureBase* first() const { return _first; }
|
|
MeasureBase* last() const { return _last; }
|
|
void clear() { _first = _last = 0; _size = 0; }
|
|
void add(MeasureBase*);
|
|
void remove(MeasureBase*);
|
|
void insert(MeasureBase*, MeasureBase*);
|
|
void remove(MeasureBase*, MeasureBase*);
|
|
void change(MeasureBase* o, MeasureBase* n);
|
|
int size() const { return _size; }
|
|
};
|
|
|
|
//---------------------------------------------------------
|
|
// MidiMapping
|
|
//---------------------------------------------------------
|
|
|
|
struct MidiMapping {
|
|
Part* part;
|
|
Channel* articulation;
|
|
signed char port;
|
|
signed char channel;
|
|
};
|
|
|
|
//---------------------------------------------------------
|
|
// MidiInputEvent
|
|
//---------------------------------------------------------
|
|
|
|
struct MidiInputEvent {
|
|
int pitch;
|
|
bool chord;
|
|
int velocity;
|
|
};
|
|
|
|
//---------------------------------------------------------
|
|
// Position
|
|
//---------------------------------------------------------
|
|
|
|
struct Position {
|
|
Segment* segment { 0 };
|
|
int staffIdx { -1 };
|
|
int line { 0 };
|
|
int fret { FRET_NONE };
|
|
QPointF pos;
|
|
};
|
|
|
|
//---------------------------------------------------------
|
|
// LayoutFlag bits
|
|
//---------------------------------------------------------
|
|
|
|
enum class LayoutFlag : char {
|
|
NO_FLAGS = 0,
|
|
FIX_PITCH_VELO = 1,
|
|
PLAY_EVENTS = 2
|
|
};
|
|
|
|
typedef QFlags<LayoutFlag> LayoutFlags;
|
|
|
|
//---------------------------------------------------------
|
|
// PlayMode
|
|
//---------------------------------------------------------
|
|
|
|
enum class PlayMode : char {
|
|
SYNTHESIZER,
|
|
AUDIO
|
|
};
|
|
|
|
//---------------------------------------------------------
|
|
// Layer
|
|
//---------------------------------------------------------
|
|
|
|
struct Layer {
|
|
QString name;
|
|
uint tags;
|
|
};
|
|
|
|
//---------------------------------------------------------
|
|
// PasteState
|
|
//---------------------------------------------------------
|
|
|
|
enum class PasteState : char {
|
|
PS_NO_ERROR,
|
|
NO_MIME,
|
|
NO_DEST,
|
|
DEST_TUPLET,
|
|
DEST_NO_CR,
|
|
TUPLET_CROSSES_BAR,
|
|
DEST_LOCAL_TIME_SIGNATURE,
|
|
DEST_TREMOLO
|
|
};
|
|
|
|
//---------------------------------------------------------
|
|
// UpdateMode
|
|
// There is an implied order from least invasive update
|
|
// to most invasive update. LayoutAll is fallback and
|
|
// recreates all.
|
|
//---------------------------------------------------------
|
|
|
|
enum class UpdateMode {
|
|
DoNothing,
|
|
Update, // do screen refresh of QRectF "refresh"
|
|
UpdateAll, // do complete screen refresh
|
|
LayoutRange, // do partial layout for tick range
|
|
LayoutAll, // do complete layout
|
|
};
|
|
|
|
//---------------------------------------------------------
|
|
// CmdState
|
|
//
|
|
// the following variables are reset on startCmd()
|
|
// modified during cmd processing and used in endCmd() to
|
|
// determine what to layout and what to repaint:
|
|
//---------------------------------------------------------
|
|
|
|
class CmdState {
|
|
UpdateMode _updateMode { UpdateMode::DoNothing };
|
|
int _startTick {-1}; // start tick for mode LayoutTick
|
|
int _endTick {-1}; // end tick for mode LayoutTick
|
|
|
|
public:
|
|
LayoutFlags layoutFlags;
|
|
|
|
bool _excerptsChanged { false };
|
|
bool _instrumentsChanged { false };
|
|
|
|
void reset();
|
|
UpdateMode updateMode() const { return _updateMode; }
|
|
void setUpdateMode(UpdateMode m);
|
|
void _setUpdateMode(UpdateMode m) { _updateMode = m; }
|
|
bool layoutAll() const { return _updateMode == UpdateMode::LayoutAll; }
|
|
bool layoutRange() const { return _updateMode == UpdateMode::LayoutRange; }
|
|
bool updateAll() const { return int(_updateMode) >= int(UpdateMode::UpdateAll); }
|
|
bool updateRange() const { return _updateMode == UpdateMode::Update; }
|
|
void setTick(int t);
|
|
int startTick() const { return _startTick; }
|
|
int endTick() const { return _endTick; }
|
|
};
|
|
|
|
class UpdateState {
|
|
public:
|
|
QRectF refresh; ///< area to update, canvas coordinates
|
|
bool _playNote { false }; ///< play selected note after command
|
|
bool _playChord { false }; ///< play whole chord for the selected note
|
|
bool _selectionChanged { false };
|
|
};
|
|
|
|
|
|
class MasterScore;
|
|
|
|
//---------------------------------------------------------------------------------------
|
|
// @@ Score
|
|
// @P composer string composer of the score (read only)
|
|
// @P duration int duration of score in seconds (read only)
|
|
// @P excerpts array[Excerpt] the list of the excerpts (linked parts)
|
|
// @P firstMeasure Measure the first measure of the score (read only)
|
|
// @P firstMeasureMM Measure the first multi-measure rest measure of the score (read only)
|
|
// @P harmonyCount int number of harmony items (read only)
|
|
// @P hasHarmonies bool score has chord symbols (read only)
|
|
// @P hasLyrics bool score has lyrics (read only)
|
|
// @P keysig int key signature at the start of the score (read only)
|
|
// @P lastMeasure Measure the last measure of the score (read only)
|
|
// @P lastMeasureMM Measure the last multi-measure rest measure of the score (read only)
|
|
// @P lastSegment Segment the last score segment (read-only)
|
|
// @P lyricCount int number of lyric items (read only)
|
|
// @P name string name of the score
|
|
// @P nmeasures int number of measures (read only)
|
|
// @P npages int number of pages (read only)
|
|
// @P nstaves int number of staves (read only)
|
|
// @P ntracks int number of tracks (staves * 4) (read only)
|
|
// not to be documented?
|
|
// @ pageFormat PageFormat the page format for the score
|
|
// @P parts array[Part] the list of parts (read only)
|
|
// @P poet string poet of the score (read only)
|
|
// @P subtitle string subtitle of the score (read only)
|
|
// @P title string title of the score (read only)
|
|
//
|
|
// a Score has always an associated MasterScore
|
|
//---------------------------------------------------------------------------------------
|
|
|
|
class Score : public QObject, public ScoreElement {
|
|
Q_OBJECT
|
|
Q_PROPERTY(QString composer READ composer)
|
|
Q_PROPERTY(int duration READ duration)
|
|
Q_PROPERTY(QQmlListProperty<Ms::Excerpt> excerpts READ qmlExcerpts)
|
|
Q_PROPERTY(Ms::Measure* firstMeasure READ firstMeasure)
|
|
Q_PROPERTY(Ms::Measure* firstMeasureMM READ firstMeasureMM)
|
|
Q_PROPERTY(int harmonyCount READ harmonyCount)
|
|
Q_PROPERTY(bool hasHarmonies READ hasHarmonies)
|
|
Q_PROPERTY(bool hasLyrics READ hasLyrics)
|
|
Q_PROPERTY(int keysig READ keysig)
|
|
Q_PROPERTY(Ms::Measure* lastMeasure READ lastMeasure)
|
|
Q_PROPERTY(Ms::Measure* lastMeasureMM READ lastMeasureMM)
|
|
Q_PROPERTY(Ms::Segment* lastSegment READ lastSegment)
|
|
Q_PROPERTY(int lyricCount READ lyricCount)
|
|
//TODO-ws Q_PROPERTY(QString name READ name WRITE setName)
|
|
Q_PROPERTY(int nmeasures READ nmeasures)
|
|
Q_PROPERTY(int npages READ npages)
|
|
Q_PROPERTY(int nstaves READ nstaves)
|
|
Q_PROPERTY(int ntracks READ ntracks)
|
|
Q_PROPERTY(Ms::PageFormat* pageFormat READ pageFormat WRITE undoChangePageFormat)
|
|
Q_PROPERTY(QQmlListProperty<Ms::Part> parts READ qmlParts)
|
|
Q_PROPERTY(QString poet READ poet)
|
|
Q_PROPERTY(QString subtitle READ subtitle)
|
|
Q_PROPERTY(QString title READ title)
|
|
|
|
public:
|
|
enum class FileError : char {
|
|
FILE_NO_ERROR,
|
|
FILE_ERROR,
|
|
FILE_NOT_FOUND,
|
|
FILE_OPEN_ERROR,
|
|
FILE_BAD_FORMAT,
|
|
FILE_UNKNOWN_TYPE,
|
|
FILE_NO_ROOTFILE,
|
|
FILE_TOO_OLD,
|
|
FILE_TOO_NEW,
|
|
FILE_CORRUPTED,
|
|
FILE_USER_ABORT,
|
|
FILE_IGNORE_ERROR
|
|
};
|
|
|
|
private:
|
|
int _linkId { 0 };
|
|
MasterScore* _masterScore;
|
|
QList<MuseScoreView*> viewer;
|
|
|
|
QString _mscoreVersion;
|
|
int _mscoreRevision;
|
|
|
|
QString _layerTags[32];
|
|
QString _layerTagComments[32];
|
|
QList<Layer> _layer;
|
|
int _currentLayer { 0 };
|
|
|
|
ScoreFont* _scoreFont;
|
|
int _pageNumberOffset { 0 }; ///< Offset for page numbers.
|
|
|
|
MeasureBaseList _measures; // here are the notes
|
|
SpannerMap _spanner;
|
|
// https://github.com/musescore/MuseScore/commit/c69d2a9262051be314768e24686d14913c45da47
|
|
std::set<Spanner*> _unmanagedSpanner;
|
|
|
|
UpdateState _updateState;
|
|
|
|
//
|
|
// objects generated by layout:
|
|
//
|
|
QList<Page*> _pages; // pages are build from systems
|
|
QList<System*> _systems; // measures are akkumulated to systems
|
|
|
|
InputState _is;
|
|
MStyle _style;
|
|
|
|
bool _created { false }; ///< file is never saved, has generated name
|
|
QString _tmpName; ///< auto saved with this name if not empty
|
|
QString _importedFilePath; // file from which the score was imported, or empty
|
|
|
|
|
|
bool _showInvisible { true };
|
|
bool _showUnprintable { true };
|
|
bool _showFrames { true };
|
|
bool _showPageborders { false };
|
|
bool _markIrregularMeasures { true };
|
|
bool _showInstrumentNames { true };
|
|
bool _showVBox { true };
|
|
bool _printing { false }; ///< True if we are drawing to a printer
|
|
bool _playlistDirty { true };
|
|
bool _autosaveDirty { true };
|
|
bool _saved { false }; ///< True if project was already saved; only on first
|
|
///< save a backup file will be created, subsequent
|
|
///< saves will not overwrite the backup file.
|
|
bool _defaultsRead { false }; ///< defaults were read at MusicXML import, allow export of defaults in convertermode
|
|
|
|
|
|
|
|
QList<Part*> _parts;
|
|
QList<Staff*> _staves;
|
|
|
|
int _pos[3]; ///< 0 - current, 1 - left loop, 2 - right loop
|
|
|
|
bool _foundPlayPosAfterRepeats; ///< Temporary used during playback rendering
|
|
///< indicating if playPos after expanded repeats
|
|
///< has been calculated.
|
|
|
|
int _mscVersion { MSCVERSION }; ///< version of current loading *.msc file
|
|
|
|
QMap<QString, QString> _metaTags;
|
|
|
|
|
|
Selection _selection;
|
|
SelectionFilter _selectionFilter;
|
|
Audio* _audio { 0 };
|
|
PlayMode _playMode { PlayMode::SYNTHESIZER };
|
|
|
|
qreal _noteHeadWidth { 0.0 }; // cached value
|
|
QString accInfo; ///< information used by the screen-reader
|
|
|
|
//------------------
|
|
|
|
ChordRest* nextMeasure(ChordRest* element, bool selectBehavior = false, bool mmRest = false);
|
|
ChordRest* prevMeasure(ChordRest* element, bool mmRest = false);
|
|
void cmdSetBeamMode(Beam::Mode);
|
|
void cmdFlip();
|
|
Note* getSelectedNote();
|
|
ChordRest* upStaff(ChordRest* cr);
|
|
ChordRest* downStaff(ChordRest* cr);
|
|
ChordRest* nextTrack(ChordRest* cr);
|
|
ChordRest* prevTrack(ChordRest* cr);
|
|
|
|
void padToggle(Pad n);
|
|
void addTempo();
|
|
void addMetronome();
|
|
|
|
void cmdResetBeamMode();
|
|
|
|
void cmdInsertClef(ClefType);
|
|
void cmdAddGrace(NoteType, int);
|
|
void removeChordRest(ChordRest* cr, bool clearSegment);
|
|
void cmdMoveRest(Rest*, Direction);
|
|
void cmdMoveLyrics(Lyrics*, Direction);
|
|
void cmdHalfDuration();
|
|
void cmdDoubleDuration();
|
|
void cmdAddBracket();
|
|
void resetUserStretch();
|
|
|
|
Page* addPage();
|
|
bool layoutSystem(qreal& minWidth, qreal w, bool, bool);
|
|
void createMMRest(Measure*, Measure*, const Fraction&);
|
|
bool layoutSystem1(qreal& minWidth, bool, bool);
|
|
QList<System*> layoutSystemRow(qreal w, bool, bool);
|
|
void addSystemHeader(Measure* m, bool);
|
|
System* getNextSystem(LayoutContext&);
|
|
bool doReLayout();
|
|
|
|
void beamGraceNotes(Chord*, bool);
|
|
|
|
void hideEmptyStaves(System* system, bool isFirstSystem);
|
|
|
|
void checkSlurs();
|
|
void checkScore();
|
|
|
|
bool rewriteMeasures(Measure* fm, Measure* lm, const Fraction&, int staffIdx);
|
|
bool rewriteMeasures(Measure* fm, const Fraction& ns, int staffIdx);
|
|
void updateVelo();
|
|
void swingAdjustParams(Chord*, int&, int&, int, int);
|
|
bool isSubdivided(ChordRest*, int);
|
|
void addAudioTrack();
|
|
QList<Fraction> splitGapToMeasureBoundaries(ChordRest*, Fraction);
|
|
void pasteChordRest(ChordRest* cr, int tick, const Interval&);
|
|
qreal cautionaryWidth(Measure* m, bool& hasCourtesy);
|
|
|
|
void selectSingle(Element* e, int staffIdx);
|
|
void selectAdd(Element* e);
|
|
void selectRange(Element* e, int staffIdx);
|
|
|
|
QQmlListProperty<Ms::Part> qmlParts() { return QmlListAccess<Ms::Part>(this, _parts); }
|
|
|
|
void getNextMeasure(LayoutContext&); // get next measure for layout
|
|
bool collectPage(LayoutContext&);
|
|
System* collectSystem(LayoutContext&);
|
|
void createBeams(Measure*);
|
|
|
|
protected:
|
|
QFileInfo info;
|
|
int _fileDivision; ///< division of current loading *.msc file
|
|
LayoutMode _layoutMode { LayoutMode::PAGE };
|
|
SynthesizerState _synthesizerState;
|
|
|
|
void createPlayEvents(Chord*);
|
|
void createGraceNotesPlayEvents(int tick, Chord* chord, int& ontime, int& trailtime);
|
|
|
|
signals:
|
|
void posChanged(POS, unsigned);
|
|
void playlistChanged();
|
|
|
|
public:
|
|
Score();
|
|
Score(MasterScore*);
|
|
Score(MasterScore*, const MStyle*);
|
|
virtual ~Score();
|
|
|
|
virtual bool isMaster() const { return false; }
|
|
|
|
virtual inline QList<Excerpt*>& excerpts();
|
|
virtual inline const QList<Excerpt*>& excerpts() const;
|
|
|
|
QQmlListProperty<Ms::Excerpt> qmlExcerpts() { return QmlListAccess<Ms::Excerpt>(this, excerpts()); }
|
|
|
|
virtual const char* name() const override { return "Score"; }
|
|
|
|
void rebuildBspTree();
|
|
bool noStaves() const { return _staves.empty(); }
|
|
void insertPart(Part*, int);
|
|
void removePart(Part*);
|
|
void insertStaff(Staff*, int);
|
|
void cmdRemoveStaff(int staffIdx);
|
|
void removeStaff(Staff*);
|
|
void addMeasure(MeasureBase*, MeasureBase*);
|
|
void readStaff(XmlReader&);
|
|
bool read(XmlReader&);
|
|
|
|
void cmdRemovePart(Part*);
|
|
void cmdAddTie();
|
|
void cmdAddHairpin(bool);
|
|
void cmdAddOttava(Ottava::Type);
|
|
void cmdAddStretch(qreal);
|
|
void cmdResetNoteAndRestGroupings();
|
|
|
|
void addRemoveBreaks(int interval, bool lock);
|
|
|
|
bool transpose(Note* n, Interval, bool useSharpsFlats);
|
|
void transposeKeys(int staffStart, int staffEnd, int tickStart, int tickEnd, const Interval&, bool useInstrument = false, bool flip = false);
|
|
bool transpose(TransposeMode mode, TransposeDirection, Key transposeKey, int transposeInterval,
|
|
bool trKeys, bool transposeChordNames, bool useDoubleSharpsFlats);
|
|
|
|
bool appendScore(Score*, bool addPageBreak = false, bool addSectionBreak = true);
|
|
|
|
int pageIdx(Page* page) const { return _pages.indexOf(page); }
|
|
|
|
void write(Xml&, bool onlySelection);
|
|
|
|
QList<Staff*>& staves() { return _staves; }
|
|
const QList<Staff*>& staves() const { return _staves; }
|
|
int nstaves() const { return _staves.size(); }
|
|
int ntracks() const { return _staves.size() * VOICES; }
|
|
int npages() const { return _pages.size(); }
|
|
|
|
int staffIdx(const Part*) const;
|
|
int staffIdx(const Staff* staff) const { return _staves.indexOf((Staff*)staff, 0); }
|
|
Staff* staff(int n) const { return (n < _staves.size()) ? _staves.at(n) : 0; }
|
|
|
|
|
|
MeasureBase* pos2measure(const QPointF&, int* staffIdx, int* pitch,
|
|
Segment**, QPointF* offset) const;
|
|
void dragPosition(const QPointF&, int* staffIdx, Segment**) const;
|
|
|
|
void undoAddElement(Element* element);
|
|
void undoAddCR(ChordRest* element, Measure*, int tick);
|
|
void undoRemoveElement(Element* element);
|
|
void undoChangeElement(Element* oldElement, Element* newElement);
|
|
void undoChangePitch(Note* note, int pitch, int tpc1, int tpc2);
|
|
void undoChangeFretting(Note* note, int pitch, int string, int fret, int tpc1, int tpc2);
|
|
void spellNotelist(std::vector<Note*>& notes);
|
|
void undoChangeTpc(Note* note, int tpc);
|
|
void undoChangeChordRestLen(ChordRest* cr, const TDuration&);
|
|
void undoChangeSingleBarLineSpan(BarLine* barLine, int span, int spanFrom, int spanTo);
|
|
void undoTransposeHarmony(Harmony*, int, int);
|
|
void undoExchangeVoice(Measure* measure, int val1, int val2, int staff1, int staff2);
|
|
void undoRemovePart(Part* part, int idx);
|
|
void undoInsertPart(Part* part, int idx);
|
|
void undoRemoveStaff(Staff* staff);
|
|
void undoInsertStaff(Staff* staff, int idx, bool createRests=true);
|
|
void undoChangeInvisible(Element*, bool);
|
|
void undoChangeBracketSpan(Staff* staff, int column, int span);
|
|
void undoChangeTuning(Note*, qreal);
|
|
void undoChangePageFormat(PageFormat*);
|
|
void undoChangePageFormat(PageFormat*, qreal spatium, int);
|
|
void undoChangeUserMirror(Note*, MScore::DirectionH);
|
|
void undoChangeKeySig(Staff* ostaff, int tick, KeySigEvent);
|
|
void undoChangeClef(Staff* ostaff, Segment*, ClefType st);
|
|
void undoChangeProperty(ScoreElement*, P_ID, const QVariant&, PropertyStyle ps = PropertyStyle::NOSTYLE);
|
|
void undoPropertyChanged(Element*, P_ID, const QVariant& v);
|
|
void undoPropertyChanged(ScoreElement*, P_ID, const QVariant& v);
|
|
inline virtual UndoStack* undoStack() const;
|
|
void undo(UndoCommand* cmd) const;
|
|
void undoRemoveMeasures(Measure*, Measure*);
|
|
void undoAddBracket(Staff* staff, int level, BracketType type, int span);
|
|
void undoRemoveBracket(Bracket*);
|
|
void undoInsertTime(int tick, int len);
|
|
void undoChangeBarLine(Measure*, BarLineType);
|
|
|
|
void setGraceNote(Chord*, int pitch, NoteType type, int len);
|
|
|
|
Segment* setNoteRest(Segment*, int track, NoteVal nval, Fraction, Direction stemDirection = Direction::AUTO);
|
|
void changeCRlen(ChordRest* cr, const TDuration&);
|
|
void changeCRlen(ChordRest* cr, const Fraction&, bool fillWithRest=true);
|
|
void createCRSequence(Fraction f, ChordRest* cr, int tick);
|
|
|
|
Fraction makeGap(Segment*, int track, const Fraction&, Tuplet*, bool keepChord = false);
|
|
bool makeGap1(int baseTick, int staffIdx, Fraction len, int voiceOffset[VOICES]);
|
|
bool makeGapVoice(Segment* seg, int track, Fraction len, int tick);
|
|
|
|
Rest* addRest(int tick, int track, TDuration, Tuplet*);
|
|
Rest* addRest(Segment* seg, int track, TDuration d, Tuplet*);
|
|
Chord* addChord(int tick, TDuration d, Chord* oc, bool genTie, Tuplet* tuplet);
|
|
|
|
ChordRest* addClone(ChordRest* cr, int tick, const TDuration& d);
|
|
Rest* setRest(int tick, int track, Fraction, bool useDots, Tuplet* tuplet, bool useFullMeasureRest = true);
|
|
|
|
void upDown(bool up, UpDownMode);
|
|
ChordRest* searchNote(int tick, int track) const;
|
|
|
|
// undo/redo ops
|
|
void addArticulation(ArticulationType);
|
|
void changeAccidental(AccidentalType);
|
|
void changeAccidental(Note* oNote, Ms::AccidentalType);
|
|
|
|
void addElement(Element*);
|
|
void removeElement(Element*);
|
|
|
|
Note* addPitch(NoteVal&, bool addFlag);
|
|
void addPitch(int pitch, bool addFlag, bool insert);
|
|
Note* addTiedMidiPitch(int pitch, bool addFlag, Chord* prevChord);
|
|
Note* addMidiPitch(int pitch, bool addFlag);
|
|
Note* addNote(Chord*, NoteVal& noteVal);
|
|
|
|
NoteVal noteValForPosition(Position pos, bool &error);
|
|
|
|
void deleteItem(Element*);
|
|
void deleteMeasures(MeasureBase* firstMeasure, MeasureBase* lastMeasure);
|
|
void cmdDeleteSelection();
|
|
void cmdFullMeasureRest();
|
|
|
|
void putNote(const QPointF&, bool replace, bool insert);
|
|
void putNote(const Position&, bool replace, bool insert);
|
|
void putNoteInsert(const Position&);
|
|
|
|
void repitchNote(const Position& pos, bool replace);
|
|
void regroupNotesAndRests(int startTick, int endTick, int track);
|
|
void cmdAddPitch(int pitch, bool addFlag, bool insert);
|
|
void cmdTimeDelete();
|
|
void timeDelete(Measure*, Segment*, const Fraction&);
|
|
|
|
void startCmd(); // start undoable command
|
|
void endCmd(bool rollback = false); // end undoable command
|
|
void update();
|
|
void undoRedo(bool undo);
|
|
|
|
void cmdRemoveTimeSig(TimeSig*);
|
|
void cmdAddTimeSig(Measure*, int staffIdx, TimeSig*, bool local);
|
|
|
|
virtual inline void setUpdateAll();
|
|
virtual inline void setLayoutAll();
|
|
virtual inline void setLayout(int);
|
|
virtual inline CmdState& cmdState();
|
|
virtual inline void addLayoutFlags(LayoutFlags);
|
|
virtual inline void setInstrumentsChanged(bool);
|
|
|
|
bool playNote() const { return _updateState._playNote; }
|
|
void setPlayNote(bool v) { _updateState._playNote = v; }
|
|
bool playChord() const { return _updateState._playChord; }
|
|
void setPlayChord(bool v) { _updateState._playChord = v; }
|
|
bool selectionChanged() const { return _updateState._selectionChanged; }
|
|
void setSelectionChanged(bool val) { _updateState._selectionChanged = val; }
|
|
|
|
void addRefresh(const QRectF&);
|
|
// const QRectF& getRefresh() const { return _updateState.refresh; }
|
|
|
|
void changeVoice(int);
|
|
|
|
void colorItem(Element*);
|
|
QList<Part*>& parts() { return _parts; }
|
|
const QList<Part*>& parts() const { return _parts; }
|
|
|
|
void appendPart(Part* p);
|
|
void updateStaffIndex();
|
|
void sortStaves(QList<int>& dst);
|
|
|
|
bool showInvisible() const { return _showInvisible; }
|
|
bool showUnprintable() const { return _showUnprintable; }
|
|
bool showFrames() const { return _showFrames; }
|
|
bool showPageborders() const { return _showPageborders; }
|
|
bool markIrregularMeasures() const { return _markIrregularMeasures; }
|
|
bool showInstrumentNames() const { return _showInstrumentNames; }
|
|
bool showVBox() const { return _showVBox; }
|
|
void setShowInvisible(bool v);
|
|
void setShowUnprintable(bool v);
|
|
void setShowFrames(bool v);
|
|
void setShowPageborders(bool v);
|
|
void setMarkIrregularMeasures(bool v);
|
|
void setShowInstrumentNames(bool v) { _showInstrumentNames = v; }
|
|
void setShowVBox(bool v) { _showVBox = v; }
|
|
|
|
bool saveFile(QFileInfo& info);
|
|
void saveFile(QIODevice* f, bool msczFormat, bool onlySelection = false);
|
|
void saveCompressedFile(QFileInfo&, bool onlySelection);
|
|
void saveCompressedFile(QIODevice*, QFileInfo&, bool onlySelection);
|
|
bool exportFile();
|
|
|
|
void print(QPainter* printer, int page);
|
|
ChordRest* getSelectedChordRest() const;
|
|
void getSelectedChordRest2(ChordRest** cr1, ChordRest** cr2) const;
|
|
|
|
void select(Element* obj, SelectType = SelectType::SINGLE, int staff = 0);
|
|
void selectSimilar(Element* e, bool sameStaff);
|
|
void selectSimilarInRange(Element* e);
|
|
static void collectMatch(void* data, Element* e);
|
|
void deselect(Element* obj);
|
|
void deselectAll() { _selection.deselectAll(); }
|
|
void updateSelection() { _selection.update(); }
|
|
Element* getSelectedElement() const { return _selection.element(); }
|
|
const Selection& selection() const { return _selection; }
|
|
Selection& selection() { return _selection; }
|
|
SelectionFilter& selectionFilter() { return _selectionFilter; }
|
|
void setSelection(const Selection& s);
|
|
|
|
int pos();
|
|
Measure* tick2measure(int tick) const;
|
|
Measure* tick2measureMM(int tick) const;
|
|
MeasureBase* tick2measureBase(int tick) const;
|
|
Segment* tick2segment(int tick, bool first = false, Segment::Type st = Segment::Type::All,bool useMMrest = false ) const;
|
|
Segment* tick2segmentMM(int tick, bool first = false, Segment::Type st = Segment::Type::All) const;
|
|
Segment* tick2segmentEnd(int track, int tick) const;
|
|
Segment* tick2leftSegment(int tick) const;
|
|
Segment* tick2rightSegment(int tick) const;
|
|
void fixTicks();
|
|
bool addArticulation(Element*, Articulation* atr);
|
|
|
|
void cmd(const QAction*);
|
|
int fileDivision(int t) const { return ((qint64)t * MScore::division + _fileDivision/2) / _fileDivision; }
|
|
|
|
QString importedFilePath() const { return _importedFilePath; }
|
|
void setImportedFilePath(const QString& filePath);
|
|
|
|
bool dirty() const;
|
|
void setCreated(bool val) { _created = val; }
|
|
bool created() const { return _created; }
|
|
bool saved() const { return _saved; }
|
|
void setSaved(bool v) { _saved = v; }
|
|
bool printing() const { return _printing; }
|
|
void setPrinting(bool val) { _printing = val; }
|
|
void setAutosaveDirty(bool v) { _autosaveDirty = v; }
|
|
bool autosaveDirty() const { return _autosaveDirty; }
|
|
bool playlistDirty() { return _playlistDirty; }
|
|
void setPlaylistDirty() { _playlistDirty = true; }
|
|
|
|
void spell();
|
|
void spell(int startStaff, int endStaff, Segment* startSegment, Segment* endSegment);
|
|
void spell(Note*);
|
|
int nextSeg(int tick, int track);
|
|
|
|
MStyle* style() { return &_style; }
|
|
const MStyle* style() const { return &_style; }
|
|
void setStyle(const MStyle& s);
|
|
bool loadStyle(const QString&);
|
|
bool saveStyle(const QString&);
|
|
|
|
QVariant style(StyleIdx idx) const { return _style.value(idx); }
|
|
Spatium styleS(StyleIdx idx) const { Q_ASSERT(!strcmp(MStyle::valueType(idx),"Ms::Spatium")); return _style.value(idx).value<Spatium>(); }
|
|
qreal styleP(StyleIdx idx) const { Q_ASSERT(!strcmp(MStyle::valueType(idx),"Ms::Spatium")); return _style.pvalue(idx); }
|
|
QString styleSt(StyleIdx idx) const { Q_ASSERT(!strcmp(MStyle::valueType(idx),"QString")); return _style.value(idx).toString(); }
|
|
bool styleB(StyleIdx idx) const { Q_ASSERT(!strcmp(MStyle::valueType(idx),"bool")); return _style.value(idx).toBool(); }
|
|
qreal styleD(StyleIdx idx) const { Q_ASSERT(!strcmp(MStyle::valueType(idx),"double")); return _style.value(idx).toDouble(); }
|
|
int styleI(StyleIdx idx) const { Q_ASSERT(!strcmp(MStyle::valueType(idx),"int")); return _style.value(idx).toInt(); }
|
|
|
|
const TextStyle& textStyle(TextStyleType idx) const { return _style.textStyle(idx); }
|
|
const TextStyle& textStyle(const QString& s) const { return _style.textStyle(s); }
|
|
|
|
qreal spatium() const { return styleD(StyleIdx::spatium); }
|
|
void setSpatium(qreal v) { style()->set(StyleIdx::spatium, v); }
|
|
PageFormat* pageFormat() { return style()->pageFormat(); }
|
|
const PageFormat* pageFormat() const { return style()->pageFormat(); }
|
|
void setPageFormat(const PageFormat& pf) { style()->setPageFormat(pf); }
|
|
|
|
// These position are in ticks and not uticks
|
|
int playPos() const { return pos(POS::CURRENT); }
|
|
void setPlayPos(int tick) { setPos(POS::CURRENT, tick); }
|
|
int loopInTick() const { return pos(POS::LEFT); }
|
|
int loopOutTick() const { return pos(POS::RIGHT); }
|
|
void setLoopInTick(int tick) { setPos(POS::LEFT, tick); }
|
|
void setLoopOutTick(int tick) { setPos(POS::RIGHT, tick); }
|
|
|
|
int pos(POS pos) const { return _pos[int(pos)]; }
|
|
void setPos(POS pos, int tick);
|
|
|
|
bool noteEntryMode() const { return inputState().noteEntryMode(); }
|
|
void setNoteEntryMode(bool val) { inputState().setNoteEntryMode(val); }
|
|
NoteEntryMethod noteEntryMethod() const { return inputState().noteEntryMethod(); }
|
|
void setNoteEntryMethod(NoteEntryMethod m) { inputState().setNoteEntryMethod(m); }
|
|
bool usingNoteEntryMethod(NoteEntryMethod m) { return inputState().usingNoteEntryMethod(m); }
|
|
int inputPos() const;
|
|
int inputTrack() const { return inputState().track(); }
|
|
const InputState& inputState() const { return _is; }
|
|
InputState& inputState() { return _is; }
|
|
void setInputState(const InputState& st) { _is = st; }
|
|
void setInputTrack(int t) { inputState().setTrack(t); }
|
|
|
|
void spatiumChanged(qreal oldValue, qreal newValue);
|
|
|
|
PasteState cmdPaste(const QMimeData* ms, MuseScoreView* view);
|
|
PasteState pasteStaff(XmlReader&, Segment* dst, int staffIdx);
|
|
void pasteSymbols(XmlReader& e, ChordRest* dst);
|
|
void renderMidi(EventMap* events);
|
|
void renderStaff(EventMap* events, Staff*);
|
|
void renderSpanners(EventMap* events, int staffIdx);
|
|
void renderMetronome(EventMap* events, Measure* m, int tickOffset);
|
|
|
|
BeatType tick2beatType(int tick);
|
|
|
|
int mscVersion() const { return _mscVersion; }
|
|
void setMscVersion(int v) { _mscVersion = v; }
|
|
|
|
void addLyrics(int tick, int staffIdx, const QString&);
|
|
|
|
void updateSwing();
|
|
void createPlayEvents();
|
|
|
|
void cmdConcertPitchChanged(bool, bool /*useSharpsFlats*/);
|
|
|
|
virtual inline TempoMap* tempomap() const;
|
|
virtual inline TimeSigMap* sigmap() const;
|
|
|
|
void setTempo(Segment*, qreal);
|
|
void setTempo(int tick, qreal bps);
|
|
void removeTempo(int tick);
|
|
void setPause(int tick, qreal seconds);
|
|
qreal tempo(int tick) const;
|
|
|
|
bool defaultsRead() const { return _defaultsRead; }
|
|
void setDefaultsRead(bool b) { _defaultsRead = b; }
|
|
Text* getText(TextStyleType subtype);
|
|
|
|
void lassoSelect(const QRectF&);
|
|
void lassoSelectEnd();
|
|
|
|
Page* searchPage(const QPointF&) const;
|
|
QList<System*> searchSystem(const QPointF& p) const;
|
|
Measure* searchMeasure(const QPointF& p) const;
|
|
|
|
bool getPosition(Position* pos, const QPointF&, int voice) const;
|
|
|
|
void cmdDeleteTuplet(Tuplet*, bool replaceWithRest);
|
|
|
|
void moveBracket(int staffIdx, int srcCol, int dstCol);
|
|
Measure* getCreateMeasure(int tick);
|
|
|
|
void adjustBracketsDel(int sidx, int eidx);
|
|
void adjustBracketsIns(int sidx, int eidx);
|
|
void adjustKeySigs(int sidx, int eidx, KeyList km);
|
|
|
|
Measure* searchLabel(const QString& s);
|
|
Measure* searchLabelWithinSectionFirst(const QString& s, Measure* sectionStartMeasure, Measure* sectionEndMeasure);
|
|
virtual inline RepeatList* repeatList() const;
|
|
qreal utick2utime(int tick) const;
|
|
int utime2utick(qreal utime) const;
|
|
//@ ??
|
|
Q_INVOKABLE void updateRepeatList(bool expandRepeats);
|
|
|
|
void nextInputPos(ChordRest* cr, bool);
|
|
void cmdMirrorNoteHead();
|
|
|
|
qreal loWidth() const;
|
|
qreal loHeight() const;
|
|
|
|
const QList<Page*>& pages() const { return _pages; }
|
|
const QList<System*>& systems() const { return _systems; }
|
|
QList<System*>& systems() { return _systems; }
|
|
|
|
MeasureBaseList* measures() { return &_measures; }
|
|
bool checkHasMeasures() const;
|
|
MeasureBase* first() const;
|
|
MeasureBase* firstMM() const;
|
|
MeasureBase* last() const;
|
|
Ms::Measure* firstMeasure() const;
|
|
Ms::Measure* firstMeasureMM() const;
|
|
Ms::Measure* lastMeasure() const;
|
|
Ms::Measure* lastMeasureMM() const;
|
|
MeasureBase* measure(int idx) const;
|
|
|
|
Ms::Segment* firstSegment(Segment::Type s) const;
|
|
//@ returns the first segment of the score of the given type (use Segment.Clef, ... enum)
|
|
Q_INVOKABLE Ms::Segment* firstSegment(int segType = static_cast<int>(Segment::Type::All)) const;
|
|
Ms::Segment* firstSegmentMM(Segment::Type s = Segment::Type::All) const;
|
|
Ms::Segment* lastSegment() const;
|
|
|
|
void connectTies(bool silent=false);
|
|
|
|
qreal point(const Spatium sp) const { return sp.val() * spatium(); }
|
|
|
|
void scanElements(void* data, void (*func)(void*, Element*), bool all=true);
|
|
void scanElementsInRange(void* data, void (*func)(void*, Element*), bool all = true);
|
|
QByteArray buildCanonical(int track);
|
|
int fileDivision() const { return _fileDivision; } ///< division of current loading *.msc file
|
|
void splitStaff(int staffIdx, int splitPoint);
|
|
QString tmpName() const { return _tmpName; }
|
|
void setTmpName(const QString& s) { _tmpName = s; }
|
|
bool processMidiInput();
|
|
Lyrics* addLyrics();
|
|
FiguredBass* addFiguredBass();
|
|
void expandVoice(Segment* s, int track);
|
|
void expandVoice();
|
|
|
|
Element* selectMove(const QString& cmd);
|
|
Element* move(const QString& cmd);
|
|
void cmdEnterRest(const TDuration& d);
|
|
void cmdAddInterval(int, const std::vector<Note*>&);
|
|
void cmdCreateTuplet(ChordRest*, Tuplet*);
|
|
void removeAudio();
|
|
|
|
void doLayout();
|
|
void doLayoutRange(int, int);
|
|
void layoutLinear(LayoutContext& lc);
|
|
|
|
void layoutSystemsUndoRedo();
|
|
void layoutPagesUndoRedo();
|
|
Page* getEmptyPage(LayoutContext&);
|
|
|
|
void layoutChords1(Segment* segment, int staffIdx);
|
|
qreal layoutChords2(std::vector<Note*>& notes, bool up);
|
|
void layoutChords3(std::vector<Note*>&, Staff*, Segment*);
|
|
|
|
SynthesizerState& synthesizerState() { return _synthesizerState; }
|
|
void setSynthesizerState(const SynthesizerState& s);
|
|
|
|
void updateHairpin(Hairpin*); // add/modify hairpin to pitchOffset list
|
|
void removeHairpin(Hairpin*); // remove hairpin from pitchOffset list
|
|
Volta* searchVolta(int tick) const;
|
|
MasterScore* masterScore() const { return _masterScore; }
|
|
void setMasterScore(MasterScore* s) { _masterScore = s; }
|
|
void createRevision();
|
|
void writeSegments(Xml& xml, int strack, int etrack, Segment* first, Segment* last, bool, bool, bool);
|
|
|
|
const QMap<QString, QString>& metaTags() const { return _metaTags; }
|
|
QMap<QString, QString>& metaTags() { return _metaTags; }
|
|
void setMetaTags(const QMap<QString,QString>& t) { _metaTags = t; }
|
|
|
|
//@ returns as a string the metatag named 'tag'
|
|
Q_INVOKABLE QString metaTag(const QString& tag) const;
|
|
//@ sets the metatag named 'tag' to 'val'
|
|
Q_INVOKABLE void setMetaTag(const QString& tag, const QString& val);
|
|
|
|
void layoutFingering(Fingering*);
|
|
void cmdSplitMeasure(ChordRest*);
|
|
void splitMeasure(ChordRest*);
|
|
void cmdJoinMeasure(Measure*, Measure*);
|
|
int pageNumberOffset() const { return _pageNumberOffset; }
|
|
void setPageNumberOffset(int v) { _pageNumberOffset = v; }
|
|
|
|
QString mscoreVersion() const { return _mscoreVersion; }
|
|
int mscoreRevision() const { return _mscoreRevision; }
|
|
void setMscoreVersion(const QString& val) { _mscoreVersion = val; }
|
|
void setMscoreRevision(int val) { _mscoreRevision = val; }
|
|
|
|
uint currentLayerMask() const { return _layer[_currentLayer].tags; }
|
|
void setCurrentLayer(int val) { _currentLayer = val; }
|
|
int currentLayer() const { return _currentLayer; }
|
|
QString* layerTags() { return _layerTags; }
|
|
QString* layerTagComments() { return _layerTagComments; }
|
|
QList<Layer>& layer() { return _layer; }
|
|
const QList<Layer>& layer() const { return _layer; }
|
|
bool tagIsValid(uint tag) const { return tag & _layer[_currentLayer].tags; }
|
|
|
|
void addViewer(MuseScoreView* v) { viewer.append(v); }
|
|
void removeViewer(MuseScoreView* v) { viewer.removeAll(v); }
|
|
const QList<MuseScoreView*>& getViewer() const { return viewer; }
|
|
|
|
LayoutMode layoutMode() const { return _layoutMode; }
|
|
void setLayoutMode(LayoutMode lm) { _layoutMode = lm; }
|
|
|
|
Tuplet* searchTuplet(XmlReader& e, int id);
|
|
void cmdSelectAll();
|
|
void cmdSelectSection();
|
|
void respace(std::vector<ChordRest*>* elements);
|
|
void transposeSemitone(int semitone);
|
|
MeasureBase* insertMeasure(Element::Type type, MeasureBase*,
|
|
bool createEmptyMeasures = false);
|
|
Audio* audio() const { return _audio; }
|
|
void setAudio(Audio* a) { _audio = a; }
|
|
PlayMode playMode() const { return _playMode; }
|
|
void setPlayMode(PlayMode v) { _playMode = v; }
|
|
|
|
int linkId();
|
|
void linkId(int);
|
|
int getLinkId() const { return _linkId; }
|
|
|
|
QList<Score*> scoreList();
|
|
bool switchLayer(const QString& s);
|
|
//@ appends to the score a named part as last part
|
|
Q_INVOKABLE void appendPart(const QString&);
|
|
//@ appends to the score a number of measures
|
|
Q_INVOKABLE void appendMeasures(int);
|
|
#ifdef SCRIPT_INTERFACE
|
|
//@ ??
|
|
Q_INVOKABLE void addText(const QString&, const QString&);
|
|
//@ creates and returns a cursor to be used to navigate the score
|
|
Q_INVOKABLE Ms::Cursor* newCursor();
|
|
#endif
|
|
qreal computeMinWidth(Segment* fs, bool isFirstMeasureInSystem);
|
|
void updateBarLineSpans(int idx, int linesOld, int linesNew);
|
|
|
|
const std::multimap<int, Spanner*>& spanner() const { return _spanner.map(); }
|
|
SpannerMap& spannerMap() { return _spanner; }
|
|
bool isSpannerStartEnd(int tick, int track) const;
|
|
void removeSpanner(Spanner*);
|
|
void addSpanner(Spanner*);
|
|
void cmdAddSpanner(Spanner* spanner, const QPointF& pos);
|
|
void cmdAddSpanner(Spanner* spanner, int staffIdx, Segment* startSegment, Segment* endSegment);
|
|
void checkSpanner(int startTick, int lastTick);
|
|
const std::set<Spanner*>unmanagedSpanners() { return _unmanagedSpanner; }
|
|
void addUnmanagedSpanner(Spanner*);
|
|
void removeUnmanagedSpanner(Spanner*);
|
|
|
|
Hairpin* addHairpin(bool crescendo, int tickStart, int tickEnd, int track);
|
|
|
|
ChordRest* findCR(int tick, int track) const;
|
|
ChordRest* findCRinStaff(int tick, int staffIdx) const;
|
|
void layoutSpanner();
|
|
void insertTime(int tickPos, int tickLen);
|
|
|
|
ScoreFont* scoreFont() const { return _scoreFont; }
|
|
void setScoreFont(ScoreFont* f) { _scoreFont = f; }
|
|
|
|
qreal noteHeadWidth() const { return _noteHeadWidth; }
|
|
void setNoteHeadWidth( qreal n) { _noteHeadWidth = n; }
|
|
|
|
QList<int> uniqueStaves() const;
|
|
void transpositionChanged(Part*, Interval, int tickStart = 0, int tickEnd = -1);
|
|
|
|
void moveUp(ChordRest*);
|
|
void moveDown(ChordRest*);
|
|
Element* upAlt(Element*);
|
|
Note* upAltCtrl(Note*) const;
|
|
Element* downAlt(Element*);
|
|
Note* downAltCtrl(Note*) const;
|
|
|
|
Element* firstElement();
|
|
Element* lastElement();
|
|
|
|
QString title();
|
|
QString subtitle();
|
|
QString composer();
|
|
QString poet();
|
|
int nmeasures();
|
|
bool hasLyrics();
|
|
bool hasHarmonies();
|
|
int lyricCount();
|
|
int harmonyCount();
|
|
Q_INVOKABLE QString extractLyrics();
|
|
int keysig();
|
|
int duration();
|
|
|
|
void cmdInsertClef(Clef* clef, ChordRest* cr);
|
|
|
|
void cmdExplode();
|
|
void cmdImplode();
|
|
void cmdSlashFill();
|
|
void cmdSlashRhythm();
|
|
void cmdResequenceRehearsalMarks();
|
|
void cmdExchangeVoice(int, int);
|
|
|
|
void setAccessibleInfo(QString s) { accInfo = s.remove(":").remove(";"); }
|
|
QString accessibleInfo() const { return accInfo; }
|
|
|
|
QImage createThumbnail();
|
|
QString createRehearsalMarkText(RehearsalMark* current) const;
|
|
QString nextRehearsalMarkText(RehearsalMark* previous, RehearsalMark* current) const;
|
|
|
|
//@ ??
|
|
Q_INVOKABLE void cropPage(qreal margins);
|
|
bool sanityCheck(const QString& name = QString());
|
|
|
|
bool checkKeys();
|
|
bool checkClefs();
|
|
|
|
QFileInfo* fileInfo() { return &info; }
|
|
const QFileInfo* fileInfo() const { return &info; }
|
|
void setName(const QString& s);
|
|
|
|
virtual QVariant getProperty(P_ID) const override;
|
|
virtual bool setProperty(P_ID, const QVariant&) override;
|
|
virtual QVariant propertyDefault(P_ID) const override;
|
|
|
|
virtual inline QQueue<MidiInputEvent>* midiInputQueue();
|
|
virtual inline std::list<MidiInputEvent>* activeMidiPitches();
|
|
|
|
friend class ChangeSynthesizerState;
|
|
friend class Chord;
|
|
};
|
|
|
|
//---------------------------------------------------------
|
|
// MasterScore
|
|
//---------------------------------------------------------
|
|
|
|
class MasterScore : public Score {
|
|
Q_OBJECT
|
|
UndoStack* _undo;
|
|
TimeSigMap* _sigmap;
|
|
TempoMap* _tempomap;
|
|
RepeatList* _repeatList;
|
|
QList<Excerpt*> _excerpts;
|
|
Revisions* _revisions;
|
|
|
|
CmdState _cmdState; // modified during cmd processing
|
|
|
|
Omr* _omr;
|
|
bool _showOmr;
|
|
|
|
// bool _undoRedo; ///< true if in processing a undo/redo
|
|
int _midiPortCount { 0 }; // A count of JACK/ALSA midi out ports
|
|
QQueue<MidiInputEvent> _midiInputQueue; // MIDI events that have yet to be processed
|
|
std::list<MidiInputEvent> _activeMidiPitches; // MIDI keys currently being held down
|
|
QList<MidiMapping> _midiMapping;
|
|
bool isSimpleMidiMaping; // midi mapping is simple if all ports and channels
|
|
// don't decrease and don't have gaps
|
|
QSet<int> occupiedMidiChannels; // each entry is port*16+channel, port range: 0-inf, channel: 0-15
|
|
unsigned int searchMidiMappingFrom; // makes getting next free MIDI mapping faster
|
|
|
|
void parseVersion(const QString&);
|
|
void reorderMidiMapping();
|
|
void removeDeletedMidiMapping();
|
|
int updateMidiMapping();
|
|
|
|
public:
|
|
MasterScore();
|
|
MasterScore(const MStyle*);
|
|
virtual ~MasterScore();
|
|
MasterScore* clone();
|
|
|
|
// void setUndoRedo(bool val) { _undoRedo = val; }
|
|
// virtual bool undoRedo() const override { return _undoRedo; }
|
|
|
|
virtual bool isMaster() const override { return true; }
|
|
virtual UndoStack* undoStack() const override { return _undo; }
|
|
virtual TimeSigMap* sigmap() const override { return _sigmap; }
|
|
virtual TempoMap* tempomap() const override { return _tempomap; }
|
|
virtual RepeatList* repeatList() const override { return _repeatList; }
|
|
virtual QList<Excerpt*>& excerpts() override { return _excerpts; }
|
|
virtual const QList<Excerpt*>& excerpts() const override { return _excerpts; }
|
|
virtual QQueue<MidiInputEvent>* midiInputQueue() override { return &_midiInputQueue; }
|
|
virtual std::list<MidiInputEvent>* activeMidiPitches() override { return &_activeMidiPitches; }
|
|
|
|
virtual void setUpdateAll() override { _cmdState.setUpdateMode(UpdateMode::UpdateAll); }
|
|
virtual void setLayoutAll() override { _cmdState.setUpdateMode(UpdateMode::LayoutAll); }
|
|
virtual void setLayout(int t) override { _cmdState.setTick(t); }
|
|
virtual CmdState& cmdState() override { return _cmdState; }
|
|
virtual void addLayoutFlags(LayoutFlags val) override { _cmdState.layoutFlags |= val; }
|
|
virtual void setInstrumentsChanged(bool val) override { _cmdState._instrumentsChanged = val; }
|
|
|
|
void setExcerptsChanged(bool val) { _cmdState._excerptsChanged = val; }
|
|
bool excerptsChanged() const { return _cmdState._excerptsChanged; }
|
|
bool instrumentsChanged() const { return _cmdState._instrumentsChanged; }
|
|
|
|
Revisions* revisions() { return _revisions; }
|
|
|
|
bool isSavable() const;
|
|
void setTempomap(TempoMap* tm);
|
|
|
|
bool saveFile();
|
|
FileError read1(XmlReader&, bool ignoreVersionError);
|
|
FileError loadCompressedMsc(QIODevice*, bool ignoreVersionError);
|
|
FileError loadMsc(QString name, bool ignoreVersionError);
|
|
FileError loadMsc(QString name, QIODevice*, bool ignoreVersionError);
|
|
QByteArray readToBuffer();
|
|
QByteArray readCompressedToBuffer();
|
|
|
|
Omr* omr() const { return _omr; }
|
|
void setOmr(Omr* o) { _omr = o; }
|
|
void removeOmr();
|
|
bool showOmr() const { return _showOmr; }
|
|
void setShowOmr(bool v) { _showOmr = v; }
|
|
|
|
int midiPortCount() const { return _midiPortCount; }
|
|
void setMidiPortCount(int val) { _midiPortCount = val; }
|
|
QList<MidiMapping>* midiMapping() { return &_midiMapping; }
|
|
MidiMapping* midiMapping(int channel) { return &_midiMapping[channel]; }
|
|
int midiPort(int idx) const { return _midiMapping[idx].port; }
|
|
int midiChannel(int idx) const { return _midiMapping[idx].channel; }
|
|
void rebuildMidiMapping();
|
|
void checkMidiMapping();
|
|
bool exportMidiMapping() { return !isSimpleMidiMaping; }
|
|
int getNextFreeMidiMapping(int p = -1, int ch = -1);
|
|
int getNextFreeDrumMidiMapping();
|
|
void enqueueMidiEvent(MidiInputEvent ev) { _midiInputQueue.enqueue(ev); }
|
|
void updateChannel();
|
|
void setSoloMute();
|
|
|
|
void addExcerpt(Score*);
|
|
void removeExcerpt(Score*);
|
|
};
|
|
|
|
// inline bool Score::undoRedo() const { return _masterScore->undoRedo(); }
|
|
inline UndoStack* Score::undoStack() const { return _masterScore->undoStack(); }
|
|
inline RepeatList* Score::repeatList() const { return _masterScore->repeatList(); }
|
|
inline TempoMap* Score::tempomap() const { return _masterScore->tempomap(); }
|
|
inline TimeSigMap* Score::sigmap() const { return _masterScore->sigmap(); }
|
|
inline QList<Excerpt*>& Score::excerpts() { return _masterScore->excerpts(); }
|
|
inline const QList<Excerpt*>& Score::excerpts() const { return _masterScore->excerpts(); }
|
|
inline QQueue<MidiInputEvent>* Score::midiInputQueue() { return _masterScore->midiInputQueue(); }
|
|
inline std::list<MidiInputEvent>* Score::activeMidiPitches() { return _masterScore->activeMidiPitches(); }
|
|
inline void Score::setUpdateAll() { _masterScore->setUpdateAll(); }
|
|
inline void Score::setLayoutAll() { _masterScore->setLayoutAll(); }
|
|
inline void Score::setLayout(int tick) { _masterScore->setLayout(tick); }
|
|
inline CmdState& Score::cmdState() { return _masterScore->cmdState(); }
|
|
inline void Score::addLayoutFlags(LayoutFlags f) { _masterScore->addLayoutFlags(f); }
|
|
inline void Score::setInstrumentsChanged(bool v) { _masterScore->setInstrumentsChanged(v); }
|
|
|
|
extern MasterScore* gscore;
|
|
extern void fixTicks();
|
|
|
|
Q_DECLARE_OPERATORS_FOR_FLAGS(LayoutFlags);
|
|
|
|
} // namespace Ms
|
|
|
|
|
|
#endif
|
|
|