|
MUSX Document Model
|
Options for page formatting in the document. More...
#include <Options.h>
Inheritance diagram for musx::dom::options::PageFormatOptions:Classes | |
| class | PageFormat |
| Represents the format settings for a page. More... | |
Public Types | |
| enum class | AdjustPageScope { Current , All , LeftOrRight , PageRange } |
| Enum for the scope of page adjustments. More... | |
Public Types inherited from musx::dom::EnigmaBase | |
| 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 Member Functions | |
| MusxInstance< PageFormat > | calcPageFormatForPart (Cmper partId) const |
| Calculates the page format options for a specific part. | |
| PageFormatOptions (const DocumentPtr &document, Cmper partId=0, ShareMode shareMode=ShareMode::All) | |
| Constructor for PageFormatOptions. | |
Public Member Functions inherited from musx::dom::EnigmaBase | |
| Cmper | getSourcePartId () const |
| Gets the source partId for this instance. If an instance is fully shared with the score, the source is SCORE_PARTID. If an instance is partially shared or non shared, the source is the ID of the part that sourced it. | |
| ShareMode | getShareMode () const |
| Gets the sharing mode for this instance. | |
| const SharedNodes & | getUnlinkedNodes () 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 (const std::shared_ptr< EnigmaBase > &ptrToThis) |
| Performs a final consistency check after population. | |
| virtual bool | requireAllFields () const |
| Returns true if all fields are required for valid input. | |
Public Member Functions inherited from musx::dom::DocumentElement | |
| virtual | ~DocumentElement () noexcept(false)=default |
| Virtual destructor for polymorphic behavior. | |
| DocumentPtr | getDocument () const |
| Gets a reference to the Document. | |
| Cmper | getPartId () const |
| Gets the part id associated with this instance. | |
Static Public Member Functions | |
| static const xml::XmlElementArray< PageFormatOptions > & | xmlMappingArray () |
| Required for musx::factory::FieldPopulator. | |
Public Attributes | |
| AdjustPageScope | adjustPageScope {} |
| Scope of page adjustments. | |
| std::shared_ptr< PageFormat > | pageFormatScore |
| Page format for score settings. | |
| std::shared_ptr< PageFormat > | pageFormatParts |
| Page format for parts settings. | |
| bool | avoidSystemMarginCollisions {} |
| Whether to avoid system margin collisions. | |
Static Public Attributes | |
| static constexpr std::string_view | XmlNodeName = "pageFormatOptions" |
| The XML node name for this type. | |
Additional Inherited Members | |
Protected Member Functions inherited from musx::dom::OptionsBase | |
| OptionsBase (const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode) | |
| Constructs the OptionsBase and validates XmlNodeName in the derived class. | |
Protected Member Functions inherited from musx::dom::EnigmaBase | |
| EnigmaBase (const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode) | |
| Constructs the base class. | |
| EnigmaBase (const EnigmaBase &)=default | |
| explicit default copy constructor | |
| EnigmaBase (EnigmaBase &&) noexcept=default | |
| explicit default move constructor | |
| EnigmaBase & | operator= (const EnigmaBase &) |
| no-op copy assignment operator allows subclasses to copy their values. | |
| EnigmaBase & | operator= (EnigmaBase &&) noexcept |
| no-op move assignment operator allows subclasses to move their values. | |
Protected Member Functions inherited from musx::dom::DocumentElement | |
| DocumentElement (const DocumentWeakPtr &document, Cmper partId) | |
| Constructs the document element. | |
| DocumentElement (const DocumentElement &)=default | |
| explicit default copy constructor | |
| DocumentElement (DocumentElement &&) noexcept=default | |
| explicit default move constructor | |
| DocumentElement & | operator= (const DocumentElement &) |
| no-op copy assignment operator allows subclasses to copy their values. | |
| DocumentElement & | operator= (DocumentElement &&) noexcept |
| no-op move assignment operator allows subclasses to move their values. | |
Options for page formatting in the document.
This class provides configuration options for page formatting, including scope adjustment, page format score, and page format parts.
|
strong |
|
inlineexplicit |
Constructor for PageFormatOptions.
| document | A shared pointer to the document. |
| partId | Usually 0. This parameter is needed for the generic factory routine. |
| shareMode | Usually ShareMode::All. This parameter is needed for the generic factory routine. |
| MusxInstance< PageFormatOptions::PageFormat > musx::dom::options::PageFormatOptions::calcPageFormatForPart | ( | Cmper | partId | ) | const |
Calculates the page format options for a specific part.
The options are mixed with actual page and system information for the specified part to produce a set of page format options that matches the input partId if it uses consistent page formatting on all its pages. This may be useful if a particular part uses different settings than the other parts. An example might be a Piano/Vocal score with a different page size than the other parts.
| partId | [in] the part for which to calculate. Pass SCORE_PARTID for the score. |