MUSX Document Model
Loading...
Searching...
No Matches
musx::dom::details::SecondaryBeamAlterationsDownStem Class Reference

Beam alteration for downstem secondary beams. More...

#include <Details.h>

+ Inheritance diagram for musx::dom::details::SecondaryBeamAlterationsDownStem:

Public Member Functions

 SecondaryBeamAlterationsDownStem (const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, EntryNumber entnum, Inci inci)
 Constructor.
 
- Public Member Functions inherited from musx::dom::details::BeamAlterations
 BeamAlterations (const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, EntryNumber entnum, std::optional< Inci > inci=std::nullopt)
 Constructor.
 
Efix calcEffectiveBeamWidth () const
 Calculates the effective beam width by returning either the default width or the width override value specified by beamWidth.
 
bool isActive () const
 Returns whether this beam alteration record is active. Its flattenStyle must match the value in options::BeamOptions.
 
- Public Member Functions inherited from musx::dom::EntryDetailsBase
EntryNumber getEntryNumber () const
 Gets the entnum key value.
 
- Public Member Functions inherited from musx::dom::DetailsBase
Cmper getCmper1 () const
 Gets the cmper1 key value.
 
Cmper getCmper2 () const
 Gets the cmper2 key value.
 
std::optional< IncigetInci () const
 Gets the optional array index (inci).
 
- Public Member Functions inherited from musx::dom::Base
virtual ~Base () noexcept(false)=default
 Virtual destructor for polymorphic behavior.
 
DocumentPtr getDocument () const
 Gets a reference to the Document.
 
virtual Cmper getPartId () const
 Gets the partId for this instance (or SCORE_PARTID for score)
 
ShareMode getShareMode () const
 Gets the sharing mode for this instance.
 
const SharedNodesgetUnlinkedNodes () const
 Gets the unlinked nodes for this instance. (Only populated for ShareMode::Partial)
 
void addUnlinkedNode (const std::string &nodeName)
 Adds a shared node for this instance.
 
virtual void integrityCheck ()
 Allows a class to determine if it has been properly contructed by the factory and fix issues that it can, such as creating default instances of contained classes.
 
virtual bool requireAllFields () const
 Specifies if the parser should alert (print or throw) when an unknown xml tag is found for this class.
 

Static Public Member Functions

static bool calcIsFeatheredBeam (const EntryInfoPtr &entryInfo, Evpu &outLeftY, Evpu &outRightY)
 Calculates if the input entry starts a feathered beam and returns information about it.
 
- Static Public Member Functions inherited from musx::dom::details::BeamAlterations
template<typename T , std::enable_if_t< std::is_base_of_v< BeamAlterations, T >, int > = 0>
static void calcAllActiveFlags (const DocumentPtr &document)
 Used by the factory to set active indicators.
 
static const xml::XmlElementArray< BeamAlterations > & xmlMappingArray ()
 Required for musx::factory::FieldPopulator.
 

Static Public Attributes

static constexpr std::string_view XmlNodeName = "beamAltSecDownStem"
 The XML node name for this type.
 

Additional Inherited Members

- Public Types inherited from musx::dom::details::BeamAlterations
using FlattenStyle = options::BeamOptions::FlattenStyle
 see options::BeamOptions::FlattenStyle
 
- Public Types inherited from musx::dom::Base
enum class  ShareMode { All , Partial , None }
 Describes how this instance is shared between part and score. More...
 
using SharedNodes = std::set< std::string >
 The container type for shared nodes.
 
- Public Attributes inherited from musx::dom::details::BeamAlterations
Evpu leftOffsetH {}
 Horizontal adjustment of the beam start. (xml node is <xAdd>)
 
Evpu leftOffsetY {}
 Vertical adjustment of the beam start. (xml node is <yAdd>)
 
Evpu rightOffsetH {}
 Horizontal adjustment of the beam end. (xml node is <sxAdd>)
 
Evpu rightOffsetY {}
 Vertical adjustment of the beam end. (xml node is <syAdd>)
 
Edu dura {}
 For secondary beams, specifies the duration corresponding to the secondary beam (16th beam is 256, 32nd beam is 128, etc.)
 
FlattenStyle flattenStyle {}
 Beam shaping style (xml node is <context>).
 
Efix beamWidth {}
 The calcEffectiveBeamWidth method handles this for you.
 
- Protected Member Functions inherited from musx::dom::EntryDetailsBase
 EntryDetailsBase (const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, EntryNumber entnum, std::optional< Inci > inci=std::nullopt)
 Constructs a EntryDetailsBase object.
 
- Protected Member Functions inherited from musx::dom::DetailsBase
 DetailsBase (const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, Cmper cmper1, Cmper cmper2, std::optional< Inci > inci=std::nullopt)
 Constructs a DetailsBase object.
 
- Protected Member Functions inherited from musx::dom::Base
 Base (const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode)
 Constructs the base class.
 
 Base (const Base &)=default
 explicit default copy constructor
 
 Base (Base &&) noexcept=default
 explicit default move constructor
 
Baseoperator= (const Base &)
 no-op copy assignment operator allows subclasses to copy their values.
 
Baseoperator= (Base &&) noexcept
 no-op move assignment operator allows subclasses to move their values.
 
- Static Protected Member Functions inherited from musx::dom::details::BeamAlterations
template<typename SecondaryBeamType >
static bool calcIsFeatheredBeamImpl (const EntryInfoPtr &entryInfo, Evpu &outLeftY, Evpu &outRightY)
 Implementation of SecondaryBeamAlterationsDownStem::calcIsFeatheredBeam and SecondaryBeamAlterationsUpStem::calcIsFeatheredBeam.
 

Detailed Description

Beam alteration for downstem secondary beams.

Entry::stemDetail is set if the entry has any beam extensions.

Constructor & Destructor Documentation

◆ SecondaryBeamAlterationsDownStem()

musx::dom::details::SecondaryBeamAlterationsDownStem::SecondaryBeamAlterationsDownStem ( const DocumentWeakPtr document,
Cmper  partId,
ShareMode  shareMode,
EntryNumber  entnum,
Inci  inci 
)
inlineexplicit

Constructor.

Parameters
documentA weak pointer to the associated document.
partIdThe part this is for.
shareModeThe sharing mode.
entnumThe entry number this applies to.
inciThe incident, since each secondary beam has a record. They are in no guaranteed order. Use the BeamAlterations::dura value to determine which beam this pertains to.

Member Function Documentation

◆ calcIsFeatheredBeam()

static bool musx::dom::details::SecondaryBeamAlterationsDownStem::calcIsFeatheredBeam ( const EntryInfoPtr entryInfo,
Evpu outLeftY,
Evpu outRightY 
)
inlinestatic

Calculates if the input entry starts a feathered beam and returns information about it.

Note
Instead of calling this function directly, consider using EntryInfoPtr::calcIsFeatheredBeamStart instead.
Parameters
[in]entryInfoThe entry info to search.
[out]outLeftYThe height of the left side of the feathered beam
[out]outRightYThe height of the right side of the feathered beam
Returns
true if this is a feathered beam. If the return value is false, outLeftY and outRightY are unchanged.