MUSX Document Model
Loading...
Searching...
No Matches
Staff.h
1/*
2 * Copyright (C) 2025, Robert Patterson
3 *
4 * Permission is hereby granted, free of charge, to any person obtaining a copy
5 * of this software and associated documentation files (the "Software"), to deal
6 * in the Software without restriction, including without limitation the rights
7 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
8 * copies of the Software, and to permit persons to whom the Software is
9 * furnished to do so, subject to the following conditions:
10 *
11 * The above copyright notice and this permission notice shall be included in
12 * all copies or substantial portions of the Software.
13 *
14 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
17 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
18 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
19 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
20 * THE SOFTWARE.
21 */
22#pragma once
23
24#include <type_traits>
25
26#include "musx/util/Logger.h"
27#include "musx/util/Fraction.h"
28
29#include "BaseClasses.h"
30#include "CommonClasses.h"
31 // do not add other dom class dependencies. Use .cpp files for implementations that need total class access.
32
33namespace musx {
34namespace dom {
35
36namespace details {
37class Baseline;
38class BaselineNoInci;
39class ShapeNoteBase;
40}
41
42namespace others {
43
44class StaffStyle;
51class Staff : public OthersBase
52{
53public:
66
71 enum class StemDirection
72 {
73 Default,
74 AlwaysUp,
76 };
77
82 enum class NotationStyle
83 {
84 Standard,
86 Tablature
87 };
88
93 enum class HideMode
94 {
95 None,
96 Cutaway,
98 Score
99 };
100
106 {
107 Normal,
108 SlashBeats,
109 Rhythmic,
110 Blank,
114 };
115
121 {
122 public:
123 int interval{};
124 int adjust{};
125
127 };
128
141
150 {
151 public:
152 bool setToClef{};
154
156 std::shared_ptr<KeySigTransposition> keysig;
157
159 std::shared_ptr<ChromaticTransposition> chromatic;
160
162 };
163
165 explicit Staff(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, Cmper cmper)
166 : OthersBase(document, partId, shareMode, cmper) {}
167
168 // WARNING: Any fields added here must have a mask added in StaffStyle (if it does not already exist)
169 // and must be added to StaffComposite::applyStyle.
170
171 // Public properties corresponding to the XML structure
173 std::shared_ptr<FontInfo> noteFont;
175 bool useNoteFont{};
178 std::optional<int> staffLines{};
179 std::optional<std::vector<int>> customStaff;
181 std::string instUuid;
182 int capoPos{};
184 bool floatKeys{};
185 bool floatTime{};
186 bool blineBreak{};
187 bool rbarBreak{};
188 bool hasStyles{};
191 std::shared_ptr<Transposition> transposition;
208 bool flatBeams{};
212 bool hideLyrics{};
213 bool noOptimize{};
216 bool hideRepeats{};
218 bool hideRptBars{};
219 bool hideKeySigs{};
221 bool hideClefs{};
223 bool hideChords{};
224 bool noKey{};
229 bool hideRests{};
230 bool hideTies{};
231 bool hideDots{};
241 bool hideTuplets{};
243 bool hideStems{};
245 bool hideBeams{};
263
264 // The following values are not in xml but computed by the factory.
265
279 std::optional<int> autoNumberValue;
280 std::optional<Cmper> percussionMapId;
281
285
289
292
295
299 util::EnigmaParsingContext getFullInstrumentNameCtx(Cmper forPartId, bool preferStaffName = false) const;
300
304 util::EnigmaParsingContext getAbbreviatedInstrumentNameCtx(Cmper forPartId, bool preferStaffName = false) const;
305
310 std::string getFullInstrumentName(util::EnigmaString::AccidentalStyle accidentalStyle = util::EnigmaString::AccidentalStyle::Ascii, bool preferStaffName = false) const;
311
316 std::string getAbbreviatedInstrumentName(util::EnigmaString::AccidentalStyle accidentalStyle = util::EnigmaString::AccidentalStyle::Ascii, bool preferStaffName = false) const;
317
320
323
326
328 bool showNamesForPart(Cmper partId) const
329 { return partId == SCORE_PARTID ? !hideNameInScore : showNameInParts; }
330
340 static void calcAllAutoNumberValues(const DocumentPtr& document);
341
347 template <typename SubType>
348 static void calcAllRuntimeValues(const DocumentPtr& document);
349
354 std::pair<std::string, bool> calcAutoNumberingAffix() const;
355
359 std::string addAutoNumbering(const std::string& plainName) const;
360
365 ClefIndex calcClefIndexAt(MeasCmper measureId, Edu position, bool forWrittenPitch = false) const;
366
368 ClefIndex calcFirstClefIndex(bool forWrittenPitch = false) const
369 { return calcClefIndexAt(1, 0, forWrittenPitch); }
370
375 static ClefIndex calcFirstClefIndex(const DocumentPtr& document, Cmper partId, StaffCmper staffCmper);
376
378 int calcNumberOfStafflines() const;
379
381 int calcMiddleStaffPosition() const;
382
389
394 template<typename BaselineType,
395 std::enable_if_t<std::is_base_of<details::BaselineNoInci, BaselineType>::value, int> = 0>
397 {
398 return calcBaselinePositionImpl<BaselineType>(systemId, std::nullopt);
399 }
400
406 template<typename BaselineType,
407 std::enable_if_t<std::is_base_of<details::Baseline, BaselineType>::value &&
408 !std::is_base_of<details::BaselineNoInci, BaselineType>::value, int> = 0>
409 Evpu calcBaselinePosition(SystemCmper systemId, Cmper lyricNumber) const
410 {
411 return calcBaselinePositionImpl<BaselineType>(systemId, lyricNumber);
412 }
413
417 std::vector<LyricsLineInfo> createLyricsLineInfo(SystemCmper systemId) const;
418
420 int calcTopLinePosition() const;
421
423 int calcBottomLinePosition() const;
424
426 bool hasInstrumentAssigned() const;
427
433 std::pair<int, int> calcTranspositionInterval() const;
434
437 MusxInstanceList<PartDefinition> getContainingParts(bool includeScore = true) const;
438
442
445 bool calcAlternateNotationHidesEntries(LayerIndex forLayerIndex) const;
446
450 bool iterateEntries(std::function<bool(const EntryInfoPtr&)> iterator) const;
451
452 void integrityCheck(const std::shared_ptr<Base>& ptrToThis) override
453 {
455 if (!staffLines && !customStaff) {
456 MUSX_INTEGRITY_ERROR("Staff or StaffStyle " + std::to_string(getCmper()) + " has neither a standard nor a custom staff definition.");
457 } else if (staffLines && customStaff) {
458 MUSX_INTEGRITY_ERROR("Staff or StaffStyle " + std::to_string(getCmper()) + " has both a standard and a custom staff definition.");
459 }
460 if (customStaff) { // guarantee ascending order of staves.
461 std::sort(customStaff.value().begin(), customStaff.value().end(),
462 [](const auto& a, const auto& b) { return a < b; });
463 }
464 if (transposition) {
465 if (!transposition->chromatic && !transposition->keysig) {
466 MUSX_INTEGRITY_ERROR("Staff or StaffStyle " + std::to_string(getCmper()) + " has transposition with neither keysig nor chromatic transposition defined.");
467 } else if (transposition->chromatic && transposition->keysig) {
468 MUSX_INTEGRITY_ERROR("Staff or StaffStyle " + std::to_string(getCmper()) + " has transposition with both keysig and chromatic transposition defined.");
469 }
470 }
471 if (useNoteFont && !noteFont) {
472 noteFont = std::make_shared<FontInfo>(getDocument()); // do this first to avoid unreachable code warning, since MUSX_INTEGRITY_ERROR might throw
473 MUSX_INTEGRITY_ERROR("Staff or StaffStyle " + std::to_string(getCmper()) + " specifies to use a custom notehead font, but no custom font was provided.");
474 }
475 }
476
477 constexpr static std::string_view XmlNodeName = "staffSpec";
479
480private:
481 template <typename NamePositionType>
482 MusxInstance<NamePositioning> getNamePosition() const;
483
484 template<typename BaselineType>
485 Evpu calcBaselinePositionImpl(SystemCmper systemId, std::optional<Cmper> lyricNumber) const;
486};
487
495class StaffStyle : public Staff
496{
497protected:
499 explicit StaffStyle(const MusxInstance<Staff>& staff)
500 : Staff(*staff) {}
501
504 void createMasks(const MusxInstance<Base>& ptrToSelf)
505 {
506 masks = std::make_shared<Masks>(ptrToSelf);
507 }
508
509public:
511 explicit StaffStyle(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, Cmper cmper)
512 : Staff(document, partId, shareMode, cmper) {}
513
564
565 std::string styleName;
566 bool copyable{};
567 bool addToMenu{};
568 std::shared_ptr<Masks> masks;
570
593 bool containsInstrumentChange() const;
594
603 Cmper partId, StaffCmper staffId, MeasCmper measId, Edu eduPosition);
604
605 void integrityCheck(const std::shared_ptr<Base>& ptrToThis) override
606 {
607 if (!masks) {
608 // Finale allows creation of staff styles with no masks, so this is just a verbose comment
610 + " (" + std::to_string(getCmper()) + ") does not override anything.");
611 createMasks(ptrToThis);
612 }
613 if (useNoteFont && !masks->floatNoteheadFont && !noteFont) {
614 useNoteFont = false; // silence integrity check in Staff.
615 }
616 Staff::integrityCheck(ptrToThis);
617 }
618
619 constexpr static std::string_view XmlNodeName = "staffStyle";
621};
622
632{
633public:
635 explicit StaffStyleAssign(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, Cmper cmper, Inci inci)
636 : EnigmaMusicRange(document, partId, shareMode, cmper, inci) {}
637
639
644
645 void integrityCheck(const std::shared_ptr<Base>& ptrToThis) override
646 {
648 if (!styleId) {
649 MUSX_INTEGRITY_ERROR(std::string("Staff style assignment has no staff style id:")
650 + " Part " + std::to_string(getSourcePartId())
651 + " Staff " + std::to_string(getCmper())
652 );
653 }
654 }
655
656 constexpr static std::string_view XmlNodeName = "staffStyleAssign";
658};
659
668{
669private:
671 explicit StaffComposite(const MusxInstance<Staff>& staff, MeasCmper measId, Edu eduPosition)
672 : StaffStyle(staff), m_measureId(measId), m_eduPosition(eduPosition) {}
673
676 void applyStyle(const MusxInstance<StaffStyle>& staffStyle);
677
678 const MeasCmper m_measureId;
679 const Edu m_eduPosition;
680
681public:
693 static MusxInstance<StaffComposite> createCurrent(const DocumentPtr& document, Cmper partId, StaffCmper staffId, MeasCmper measId, Edu eduPosition);
694
696 MeasCmper getMeasureId() const { return m_measureId; }
697
699 Edu eduPosition() const { return m_eduPosition; }
700
703};
704
705} // namespace others
706} // namespace dom
707} // namespace musx
DocumentPtr getDocument() const
Gets a reference to the Document.
Definition BaseClasses.h:108
Cmper getSourcePartId() const
Gets the source partId for this instance. If an instance is fully shared with the score,...
Definition BaseClasses.h:124
virtual void integrityCheck(const std::shared_ptr< Base > &ptrToThis)
Allows a class to determine if it has been properly contructed by the factory and fix issues that it ...
Definition BaseClasses.h:154
ShareMode
Describes how this instance is shared between part and score.
Definition BaseClasses.h:91
Base class for classes that are contained by other classes.
Definition BaseClasses.h:224
ContainedClassBase(const MusxInstance< Base > &parent)
Constructs a ContainedClassBase object.
Definition BaseClasses.h:233
Wraps a frame of shared_ptr<const EntryInfo> and an index for per entry access. This class manages ow...
Definition Entries.h:420
Provides optional per-type extension methods for MusxInstanceList.
Definition MusxInstance.h:103
Base class for all "others" types.
Definition BaseClasses.h:283
Cmper getCmper() const
Gets the cmper key value.
Definition BaseClasses.h:328
The representation of a range of music used by Enigma files.
Definition CommonClasses.h:684
Represents a composite of an underlying Staff instance with any applicable StaffStyle instances appli...
Definition Staff.h:668
static MusxInstance< StaffComposite > createCurrent(const DocumentPtr &document, Cmper partId, StaffCmper staffId, MeasCmper measId, Edu eduPosition)
Calculates the current staff at the specified metric position by applying all relevant staff styles,...
Definition Staff.cpp:951
MusxInstance< others::Staff > getRawStaff() const
Returns the underlying staff without any staff styles applied.
Definition Staff.cpp:942
MeasCmper getMeasureId() const
Returns the measure this staff composite was created with.
Definition Staff.h:696
Edu eduPosition() const
Returns the Edu position this staff composite was created with.
Definition Staff.h:699
Represents an assignment.
Definition Staff.h:632
Cmper styleId
The cmper of the assigned StaffStyle.
Definition Staff.h:638
void integrityCheck(const std::shared_ptr< Base > &ptrToThis) override
Allows a class to determine if it has been properly contructed by the factory and fix issues that it ...
Definition Staff.h:645
StaffStyleAssign(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, Cmper cmper, Inci inci)
Constructor function.
Definition Staff.h:635
static const xml::XmlElementArray< StaffStyleAssign > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Staff.h:656
MusxInstance< StaffStyle > getStaffStyle() const
Returns the StaffStyle instance for this assignment.
Definition Staff.cpp:1007
lists the masks that deterimine if this staff style overrides the staff settings
Definition Staff.h:516
bool rbarBreak
overrides Staff::rbarBreak
Definition Staff.h:530
bool blineBreak
overrides Staff::blineBreak
Definition Staff.h:529
bool hideRptBars
overrides Staff::hideRptBars
Definition Staff.h:539
bool showTies
overrides Staff::hideTies
Definition Staff.h:548
bool negTimeParts
overrides Staff::hideTimeSigsInParts
Definition Staff.h:559
bool hideStaffLines
overrides Staff::hideStaffLines
Definition Staff.h:557
bool fullName
overrides Staff::fullNameTextId
Definition Staff.h:535
bool floatNoteheadFont
overrides notehead font settings
Definition Staff.h:520
bool negKey
overrides Staff::hideKeySigs
Definition Staff.h:540
bool negClef
overrides Staff::hideClefs
Definition Staff.h:542
bool negRepeat
overrides Staff::hideRepeats
Definition Staff.h:532
bool flatBeams
overrides Staff::flatBeams
Definition Staff.h:522
bool showNameParts
overrides Staff::showNameInParts
Definition Staff.h:555
bool hideChords
overrides Staff::hideChords
Definition Staff.h:552
bool hideBarlines
overrides Staff::hideBarlines
Definition Staff.h:534
bool noOptimize
overrides Staff::noOptimize
Definition Staff.h:524
bool blankMeasureRest
overrides Staff::blankMeasure
Definition Staff.h:523
bool staffType
overrides staff properties (see StaffComposite::applyStyle)
Definition Staff.h:527
bool negMnumb
overrides Staff::hideMeasNums
Definition Staff.h:531
bool hideKeySigsShowAccis
overrides Staff::hideKeySigsShowAccis
Definition Staff.h:560
bool redisplayLayerAccis
overrides Staff::redisplayLayerAccis
Definition Staff.h:558
bool negNameScore
overrides Staff::hideNameInScore
Definition Staff.h:533
static const xml::XmlElementArray< Masks > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
bool hideFretboards
overrides Staff::hideFretboards
Definition Staff.h:553
bool hideLyrics
overrides Staff::hideLyrics
Definition Staff.h:554
bool fullNamePos
overrides presence, absence of NamePositionStyleFull instance.
Definition Staff.h:545
bool transposition
overrides transposition fields
Definition Staff.h:528
bool abrvName
overrides Staff::abbrvNameTextId
Definition Staff.h:536
bool negTime
overrides Staff::hideTimeSigs (in Score)
Definition Staff.h:541
bool altNotation
overrides alternate notation properties (see StaffComposite::applyStyle)
Definition Staff.h:547
bool showNoteColors
overrides Staff::showNoteColors
Definition Staff.h:556
bool showStems
overrides stem properties (see StaffComposite::applyStyle)
Definition Staff.h:551
bool abrvNamePos
overrides presence, absence of NamePositionStyleAbbreviated instance.
Definition Staff.h:546
bool floatKeys
overrides Staff::floatKeys
Definition Staff.h:537
bool notationStyle
overrides notations style
Definition Staff.h:525
bool showRests
overrides Staff::hideRests
Definition Staff.h:550
bool useNoteShapes
overrides Staff::useNoteShapes
Definition Staff.h:521
bool floatTime
overrides Staff::floatTime
Definition Staff.h:538
bool hideStaff
overrides Staff::hideMode
Definition Staff.h:543
bool defaultClef
overrides Staff::defaultClef
Definition Staff.h:526
bool noKey
overrides Staff::noKey
Definition Staff.h:544
bool showDots
overrides Staff::hideDots
Definition Staff.h:549
Represents a Finale staff style.
Definition Staff.h:496
void integrityCheck(const std::shared_ptr< Base > &ptrToThis) override
Allows a class to determine if it has been properly contructed by the factory and fix issues that it ...
Definition Staff.h:605
std::shared_ptr< Masks > masks
Definition Staff.h:568
static const xml::XmlElementArray< StaffStyle > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
StaffStyle(const MusxInstance< Staff > &staff)
protected constructor for StaffComposite. This constructor must be followed by a call to createMasks.
Definition Staff.h:499
StaffStyle(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, Cmper cmper)
Constructor function.
Definition Staff.h:511
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Staff.h:619
bool containsInstrumentChange() const
Determines whether this staff style represents or includes an instrument change.
Definition Staff.cpp:975
static MusxInstanceList< StaffStyle > findAllOverlappingStyles(const DocumentPtr &document, Cmper partId, StaffCmper staffId, MeasCmper measId, Edu eduPosition)
Finds a subset from all StaffStyle instances that overlap with the specified metric position on a giv...
Definition Staff.cpp:983
bool copyable
whether the staff style assignments for this style should be copied when copy/pasting music
Definition Staff.h:566
std::string styleName
name of staff style
Definition Staff.h:565
void createMasks(const MusxInstance< Base > &ptrToSelf)
Separate creator for masks.
Definition Staff.h:504
bool addToMenu
add this staff style to the context menu for staff styles
Definition Staff.h:567
Represents chromatic transposition details.
Definition Staff.h:134
static const xml::XmlElementArray< ChromaticTransposition > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
int diatonic
The diatonic interval. See music_theory::Transposer for more information.
Definition Staff.h:137
int alteration
The alteration that defines the chromatic interval (in chromatic half-steps). See music_theory::Trans...
Definition Staff.h:136
Represents key signature transposition details.
Definition Staff.h:121
int adjust
The adjustment to the number of sharps or flats in the key signature.
Definition Staff.h:124
static const xml::XmlElementArray< KeySigTransposition > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
int interval
The diatonic transposition interval.
Definition Staff.h:123
Encapsulates transposition options for a staff.
Definition Staff.h:150
std::shared_ptr< ChromaticTransposition > chromatic
Shared pointer to the chromatic transposition details, if any.
Definition Staff.h:159
std::shared_ptr< KeySigTransposition > keysig
Shared pointer to the key signature transposition details, if any.
Definition Staff.h:156
bool noSimplifyKey
Inverse of "Simplify Key" (xml node is <noKeyOpt>)
Definition Staff.h:153
static const xml::XmlElementArray< Transposition > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
bool setToClef
If true, forces the clef in Staff::transposedClef.
Definition Staff.h:152
Represents the definition of a Finale staff.
Definition Staff.h:52
bool altHideOtherLyrics
Hide lyrics in other layers in alternate notation.
Definition Staff.h:204
bool hideDots
Inverse of "Display Augmentation Dots".
Definition Staff.h:231
AutoNumberingStyle
Enum for auto-numbering style. Auto-numbering is based on instUuid.
Definition Staff.h:59
@ ArabicSuffix
Arabic numeral suffix (default). May not appear in xml.
@ ArabicPrefix
Arabic numeral prefix (with dot): 1. 2. 3. ...
@ OrdinalPrefix
Ordinal number prefix: 1st 2nd 3rd, ...
bool noteShapesFromStyle
True if noteShapesId is for a staff style. (Determines which note shapes class to retrieve....
Definition Staff.h:268
Evpu dwRestOffset
Offset for downstem rests.
Definition Staff.h:225
bool hideRepeats
Inverse of "Display Endings and Text Repeats".
Definition Staff.h:216
ClefIndex defaultClef
Index of default clef for the staff.
Definition Staff.h:176
AlternateNotation
Enum for alternate notation styles.
Definition Staff.h:106
@ BlankWithRests
Blank Notation with Rests.
@ SlashBeats
Slash Notation (on beats)
util::EnigmaParsingContext getAbbreviatedInstrumentNameCtx(Cmper forPartId, bool preferStaffName=false) const
Returns the parsing context for the abbreviated name.
Definition Staff.cpp:340
void integrityCheck(const std::shared_ptr< Base > &ptrToThis) override
Allows a class to determine if it has been properly contructed by the factory and fix issues that it ...
Definition Staff.h:452
bool hideClefs
Inverse of "Display Clefs".
Definition Staff.h:221
MusxInstanceList< PartDefinition > getContainingParts(bool includeScore=true) const
Gets a list of all parts that contain this staff.
Definition Staff.cpp:661
bool altRhythmStemsUp
Show stems up in alternate Rhythmic Notation mode.
Definition Staff.h:199
Efix horzStemOffDown
Horizontal Stem Offsets: Down Stem.
Definition Staff.h:252
std::pair< std::string, bool > calcAutoNumberingAffix() const
Calculate the auto numbering prefix or suffix, if needed.
Definition Staff.cpp:243
std::vector< LyricsLineInfo > createLyricsLineInfo(SystemCmper systemId) const
Creates a vector of LyricsLineInfo for the current requested part.
Definition Staff.cpp:572
bool hideRepeatTopDot
Inverse of "Top Repeat Dot" in Staff Setup dialog.
Definition Staff.h:211
Evpu hRestOffset
Offset for half rests.
Definition Staff.h:227
std::optional< int > staffLines
Number of lines in the staff (if no custom staff)
Definition Staff.h:178
Efix vertStemStartOffUp
Vertical Stem Offsets For Notehead End: Up Stem.
Definition Staff.h:253
bool hideKeySigs
Inverse of "Display Key Signatures".
Definition Staff.h:219
Cmper multiStaffInstId
Definition Staff.h:277
NotationStyle
Enum for notation style.
Definition Staff.h:83
bool hideStaffLines
Inverse of "Display Staff Lines".
Definition Staff.h:222
bool hideTimeSigs
Inverse of "Display Time Signatures in Score".
Definition Staff.h:220
bool noOptimize
Inverse of "Allow Hiding When Empty".
Definition Staff.h:213
std::optional< std::vector< int > > customStaff
A list of stafflines from 0..26 where a standard 5-line staff is values 11, 12, 13,...
Definition Staff.h:179
Efix vertTabNumOff
Vertical offset for tab number. (Tablature Staff Attributes)
Definition Staff.h:237
int calcNumberOfStafflines() const
Calculates the number of staff lines on this staff.
Definition Staff.cpp:459
bool noKey
"Ignore Key Signatures"
Definition Staff.h:224
static void calcAllRuntimeValues(const DocumentPtr &document)
Populate runtime values for all staves or staffstyles, such as percussion map Id if any.
Definition Staff.cpp:118
std::shared_ptr< FontInfo > noteFont
The custom font to use for noteheads. Guaranteed non-null by integrityCheck if useNoteFont is true.
Definition Staff.h:173
static void calcAllAutoNumberValues(const DocumentPtr &document)
Get the auto-numbering value for this staff, if applicable.
Definition Staff.cpp:37
std::pair< int, int > calcTranspositionInterval() const
Calculates the transposition interval for this staff or staff composite.
Definition Staff.cpp:648
bool hideRepeatBottomDot
Inverse of "Bottom Repeat Dot" in Staff Setup dialog.
Definition Staff.h:207
bool altSlashDots
Show dots on beat slashes in compound meter.
Definition Staff.h:200
int capoPos
"Capo Position" (Tablature Staff Attributes)
Definition Staff.h:182
bool fullNamePosFromStyle
Definition Staff.h:271
bool hasStyles
Indicates that this staff has staff style assignments.
Definition Staff.h:188
Cmper abrvNamePosId
Definition Staff.h:273
Evpu calcBaselinePosition(SystemCmper systemId, Cmper lyricNumber) const
Returns the baseline position for the staff at the given system. The staff should be the staff at the...
Definition Staff.h:409
Efix vertStemEndOffUp
Vertical Stem Offsets For Stem End: Up Stem.
Definition Staff.h:255
int calcTopLinePosition() const
Calculates the position of the top staff line, relative to the reference line.
Definition Staff.cpp:484
bool altHideArtics
Hide Articulations in alternate notation (in Apply-To Layer)
Definition Staff.h:196
MusxInstance< MultiStaffInstrumentGroup > getMultiStaffInstGroup() const
Returns the MultiStaffInstrumentGroup for this staff if it is part of one in the data....
Definition Staff.cpp:287
std::string addAutoNumbering(const std::string &plainName) const
Add auto numbering as a prefix or suffix, if needed.
Definition Staff.cpp:265
StemDirection stemDirection
stem direction for staff (xml node is <stemDir>)
Definition Staff.h:244
bool hideStems
Inverse of "Display Stems".
Definition Staff.h:243
Evpu otherRestOffset
Offset for other rests.
Definition Staff.h:228
std::string getFullInstrumentName(util::EnigmaString::AccidentalStyle accidentalStyle=util::EnigmaString::AccidentalStyle::Ascii, bool preferStaffName=false) const
Returns the full instrument name for this staff without Enigma tags and with autonumbering (if any)
Definition Staff.cpp:332
std::optional< int > autoNumberValue
Calculated autonumbering value. It is computed by calcAllAutoNumberValues.
Definition Staff.h:279
Efix horzStemOffUp
Horizontal Stem Offsets: Up Stem.
Definition Staff.h:251
bool abrvNamePosFromStyle
Definition Staff.h:275
bool iterateEntries(std::function< bool(const EntryInfoPtr &)> iterator) const
Iterate all entries in the document by staff and then measure. This function wraps MusxInstanceList<S...
Definition Staff.cpp:702
Efix vertStemStartOffDown
Vertical Stem Offsets For Notehead End: Down Stem.
Definition Staff.h:254
Evpu lineSpace
Distance between staff lines.
Definition Staff.h:180
Evpu wRestOffset
Offset for whole rests.
Definition Staff.h:226
bool stemStartFromStaff
Definition Staff.h:246
bool altHideSmartShapes
Hide Smart Shapes (in Apply-To layer: probably only affects entry-attached shapes)
Definition Staff.h:198
AlternateNotation altNotation
Alternate notation on the staff.
Definition Staff.h:194
bool stemsFixedEnd
"Use Vertical Offset For Beam End Of Stems (Offset From Staff)"
Definition Staff.h:249
MusxInstance< details::ShapeNoteBase > getNoteShapes() const
Returns the note shape record in effect for this staff instance.
Definition Staff.cpp:368
HideMode hideMode
"Force Hide Staff" option
Definition Staff.h:257
bool hideTuplets
Inverse of "Show Tuplets" (Tablature Staff Attributes)
Definition Staff.h:241
Staff(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, Cmper cmper)
Constructor function.
Definition Staff.h:165
bool hideBarlines
Inverse of "Display Barlines".
Definition Staff.h:217
int lowestFret
"Default Lowest Fret" (Tablature Staff Attributes)
Definition Staff.h:183
bool useNoteShapes
Indicates that note shapes should be used. It is ignored is no staff- or staffstyle-specific note sha...
Definition Staff.h:174
bool hasInstrumentAssigned() const
Return true if this staff has an instrument assigned.
Definition Staff.cpp:640
LayerIndex altLayer
Alternate notation Apply To Layer index (0..3)
Definition Staff.h:195
bool floatKeys
"Independent Key Signature"
Definition Staff.h:184
Cmper fullNameTextId
Full name TextBlock ID. (xml node is <fullName>)
Definition Staff.h:233
NotationStyle notationStyle
Standard, percussion, or tablature.
Definition Staff.h:172
StemDirection
Enum for staff-level stem direction override.
Definition Staff.h:72
@ AlwaysDown
stems are always down on this staff
@ Default
the default (may not occur in xml)
@ AlwaysUp
stems are always up on this staff
bool useAutoNumbering
Whether names should be auto-numbered. (xml node is <useAutoNum>)
Definition Staff.h:261
bool hideTies
Inverse of "Display Ties".
Definition Staff.h:230
util::EnigmaParsingContext getFullInstrumentNameCtx(Cmper forPartId, bool preferStaffName=false) const
Returns the parsing context for the full name.
Definition Staff.cpp:312
bool showNameInParts
"Display Staff Name in Parts" (xml node is <showNameParts>)
Definition Staff.h:189
ClefIndex transposedClef
Index of transposed clef for the staff. Only used if Transposition::setToClef is true.
Definition Staff.h:177
bool floatTime
"Independent Time Signature"
Definition Staff.h:185
bool altHideOtherSmartShapes
Hide Smart Shapes in other layers in alternate notation.
Definition Staff.h:205
std::optional< Cmper > percussionMapId
Calculated percussion map Id for a percussion staff. (Populated by in calcAllRuntimeValues....
Definition Staff.h:280
int calcMiddleStaffPosition() const
Calculates the middle staff position. For staves with even numbers of lines, it is the middle space.
Definition Staff.cpp:469
Evpu botBarlineOffset
Offset for the bottom barline.
Definition Staff.h:193
Evpu calcBaselinePosition(SystemCmper systemId) const
Returns the baseline position for the staff at the given system. The staff should be the staff at the...
Definition Staff.h:396
bool calcAlternateNotationHidesEntries(LayerIndex forLayerIndex) const
Returns true if the given layer is hidden by alternate notation.
Definition Staff.cpp:696
bool hideLyrics
Inverse of "Display Lyrics".
Definition Staff.h:212
Efix vertStemEndOffDown
Vertical Stem Offsets For Stem End: Down Stem.
Definition Staff.h:256
std::string getFullName(util::EnigmaString::AccidentalStyle accidentalStyle=util::EnigmaString::AccidentalStyle::Ascii) const
Returns the full staff name without Enigma tags. If the full name contains part-specific tags (rare),...
Definition Staff.cpp:277
Cmper abbrvNameTextId
Abbreviated name TextBlock ID. (xml node is <abbrvName>)
Definition Staff.h:234
std::string getAbbreviatedName(util::EnigmaString::AccidentalStyle accidentalStyle=util::EnigmaString::AccidentalStyle::Ascii) const
Returns the abbreviated staff name without Enigma tags. If the abbreviated name contains part-specifi...
Definition Staff.cpp:282
bool hideFretboards
Inverse of "Display Fretboards".
Definition Staff.h:209
MusxInstance< details::StaffGroup > getMultiStaffInstVisualGroup() const
Returns the details::StaffGroup for this staff if it is part of a multistaff instrument (as defined i...
Definition Staff.cpp:298
bool rbarBreak
"Break Repeat Barlines Between Staves"
Definition Staff.h:187
Evpu topRepeatDotOff
Offset for top repeat dots.
Definition Staff.h:236
HideMode
Enum for hide mode.
Definition Staff.h:94
@ Score
Collapse in score only.
@ ScoreParts
Collapse in score and parts.
bool showNoteColors
"Color Noteheads" (Score Manager)
Definition Staff.h:190
bool redisplayLayerAccis
"Redisplay Accidentals in Other Layers Within Measures"
Definition Staff.h:258
bool altHideExpressions
Hide Expressions in alternate notation (in Apply-To Layer)
Definition Staff.h:203
bool useNoteFont
Indicates if noteFont should be used.
Definition Staff.h:175
Evpu topBarlineOffset
Offset for the top barline.
Definition Staff.h:214
Cmper fretInstId
Cmper of FretInstrument for TAB strings. (Tablature Staff Attributes)
Definition Staff.h:242
bool hideBeams
Inverse of "Show Beams".
Definition Staff.h:245
bool hideTimeSigsInParts
Inverse of "Display Time Signatures in Parts".
Definition Staff.h:259
MusxInstance< NamePositioning > getFullNamePosition() const
Returns the full name positioning in effect for this staff instance.
Definition Staff.cpp:419
bool hideChords
Inverse of "Display Chords".
Definition Staff.h:223
int calcBottomLinePosition() const
Calculates the position of the top staff line, relative to the reference line.
Definition Staff.cpp:498
Cmper fullNamePosId
Definition Staff.h:269
bool showNamesForPart(Cmper partId) const
Returns if names should be shown for the specified part.
Definition Staff.h:328
bool hideRests
Inverse of "Display Rests".
Definition Staff.h:229
bool breakTabLinesAtNotes
"Break Tablature Lines At Numbers" (Tablature Staff Attributes)
Definition Staff.h:240
int stemReversal
Stem reversal value.
Definition Staff.h:232
bool blankMeasure
Inverse of "Display Rests in Empty Measures".
Definition Staff.h:210
Evpu botRepeatDotOff
Offset for bottom repeat dots.
Definition Staff.h:235
bool altHideOtherArtics
Hide articulations in other layers in alternate notation.
Definition Staff.h:202
bool altHideOtherNotes
Hide notes in other layers in alternate notation.
Definition Staff.h:201
bool blineBreak
"Break Barlines Between Staves"
Definition Staff.h:186
MusxInstance< NamePositioning > getAbbreviatedNamePosition() const
Returns the abbreviated name positioning in effect for this staff instance.
Definition Staff.cpp:427
static const xml::XmlElementArray< Staff > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
MusxInstance< PartDefinition > firstContainingPart() const
Finds the first part that contains this staff, not including the score.
Definition Staff.cpp:680
ClefIndex calcClefIndexAt(MeasCmper measureId, Edu position, bool forWrittenPitch=false) const
Returns the clef in this staff at the specified location.
Definition Staff.cpp:435
ClefIndex calcFirstClefIndex(bool forWrittenPitch=false) const
Returns the first clef in this staff.
Definition Staff.h:368
bool useTabLetters
"Use Letters" (Tablature Staff Attributes)
Definition Staff.h:239
bool hideRptBars
Inverse of "Display Repeat Bars".
Definition Staff.h:218
std::shared_ptr< Transposition > transposition
Transposition details, if non-null.
Definition Staff.h:191
bool hideKeySigsShowAccis
"Hide Key Signature and Show Accidentals" transposition option.
Definition Staff.h:262
AutoNumberingStyle autoNumbering
Autonumbering style if useAutoNumbering is true. (xml node is <autoNum>)
Definition Staff.h:260
Cmper noteShapesId
Definition Staff.h:266
bool hideNameInScore
Inverse of "Display Staff Name in Score" (xml node is <hideStfNameInScore>)
Definition Staff.h:192
std::string instUuid
Unique identifier for the type of instrument.
Definition Staff.h:181
bool altHideOtherExpressions
Hide Expressions in other layers in alternate notation.
Definition Staff.h:206
bool stemsFixedStart
"Use Vertical Offset For Notehead End Of Stems"
Definition Staff.h:250
bool hideMeasNums
Inverse of "Display Measure Numbers".
Definition Staff.h:215
std::string getAbbreviatedInstrumentName(util::EnigmaString::AccidentalStyle accidentalStyle=util::EnigmaString::AccidentalStyle::Ascii, bool preferStaffName=false) const
Returns the abbreviated instrument name for this staff without Enigma tags and with autonumbering (if...
Definition Staff.cpp:360
bool flatBeams
"Flat Beams"
Definition Staff.h:208
bool altHideLyrics
Hide Lyrics in alternate notation (in Apply-To Layer)
Definition Staff.h:197
bool showTabClefAllSys
Inverse of "Show Clef Only On First Measure" (Tablature Staff Attributes)
Definition Staff.h:238
Evpu calcBaselineZeroPosition() const
Calculates the baseline zero position for this staff, relative to the reference line,...
Definition Staff.cpp:512
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Staff.h:477
Wrapper class for interpreting and rendering Enigma-style strings with insert handling.
Definition EnigmaString.h:423
AccidentalStyle
Enumeration to specify the type of accidental substitution representation.
Definition EnigmaString.h:199
@ Ascii
Use ASCII substitutions for accidentals.
@ Verbose
Informational messages that should only displayed when verbose logging is requested.
static void log(LogLevel level, const std::string &message)
Logs a message with a specific severity level.
Definition Logger.h:87
int16_t MeasCmper
Enigma meas Cmper (may be negative when not applicable)
Definition Fundamentals.h:64
int32_t Efix
EFIX value (64 per EVPU, 64*288=18432 per inch)
Definition Fundamentals.h:60
std::shared_ptr< const T > MusxInstance
Defines the type of a musx instance stored in a pool.
Definition MusxInstance.h:39
unsigned int LayerIndex
Layer index (valid values are 0..3)
Definition Fundamentals.h:71
constexpr Cmper SCORE_PARTID
The part id of the score.
Definition Fundamentals.h:79
int16_t Inci
Enigma "incident" key type.
Definition Fundamentals.h:56
int32_t Evpu
EVPU value (288 per inch)
Definition Fundamentals.h:57
uint16_t Cmper
Enigma "comperator" key type.
Definition Fundamentals.h:55
@ Percussion
Percussion clef, open rectangle (no pitch).
uint16_t ClefIndex
Index into options::ClefOptions::clefDefs.
Definition Fundamentals.h:68
int32_t Edu
"Enigma Durational Units" value (1024 per quarter note)
Definition Fundamentals.h:61
std::weak_ptr< Document > DocumentWeakPtr
Shared weak Document pointer.
Definition BaseClasses.h:57
std::shared_ptr< Document > DocumentPtr
Shared Document pointer.
Definition BaseClasses.h:55
int16_t StaffCmper
Enigma staff (staffId) Cmper (may be negative when not applicable)
Definition Fundamentals.h:65
int16_t SystemCmper
Enigma systems Cmper (may be negative when not applicable)
Definition Fundamentals.h:66
std::vector< XmlElementDescriptor< T > > XmlElementArray
an array type for XmlElementDescriptor instances.
Definition XmlInterface.h:127
object model for musx file (enigmaxml)
Definition BaseClasses.h:36