Verovio
Source code documentation
timeinterface.h
1 // Name: timeinterface.h
3 // Author: Laurent Pugin
4 // Created: 2015
5 // Copyright (c) Authors and others. All rights reserved.
7 
8 #ifndef __VRV_TIME_INTERFACE_H__
9 #define __VRV_TIME_INTERFACE_H__
10 
11 #include "atts_shared.h"
12 #include "interface.h"
13 #include "vrvdef.h"
14 
15 namespace vrv {
16 
17 class Object;
18 class LayerElement;
19 class Measure;
20 class PrepareStaffCurrentTimeSpanningFunctor;
21 class PrepareTimePointingFunctor;
22 class PrepareTimeSpanningFunctor;
23 class PrepareTimestampsFunctor;
24 class ResetDataFunctor;
25 class StaffAlignment;
26 
27 //----------------------------------------------------------------------------
28 // TimePointInterface
29 //----------------------------------------------------------------------------
30 
35 class TimePointInterface : public Interface, public AttStaffIdent, public AttStartId, public AttTimestampLog {
36 public:
43  virtual ~TimePointInterface();
44  void Reset() override;
45  InterfaceId IsInterface() const override { return INTERFACE_TIME_POINT; }
47 
52  void SetStart(LayerElement *start);
54  LayerElement *GetStart() { return m_start; }
55  const LayerElement *GetStart() const { return m_start; }
57 
61  bool SetStartOnly(LayerElement *start);
62 
66  void AddStaff(int n);
67 
71  bool HasStart() const { return (m_start); }
72 
78  const Measure *GetStartMeasure() const;
80 
85  bool IsOnStaff(int n) const;
86 
90  std::vector<const Staff *> GetTstampStaves(const Measure *measure, const Object *object) const;
92  std::vector<Staff *> GetTstampStaves(const Measure *measure, const Object *object);
94 
99  bool VerifyMeasure(const Object *owner) const;
100 
101  //-----------------//
102  // Pseudo functors //
103  //-----------------//
104 
110  FunctorCode InterfacePrepareTimePointing(PrepareTimePointingFunctor &functor, Object *object);
112  virtual FunctorCode InterfacePrepareTimestamps(PrepareTimestampsFunctor &functor, Object *object);
113  virtual FunctorCode InterfaceResetData(ResetDataFunctor &functor, Object *object);
115 
116 protected:
120  void SetIDStr();
121 
122 private:
123  //
124 public:
125  //
126 protected:
127  LayerElement *m_start;
128  std::string m_startID;
129 
130 private:
131 };
132 
133 //----------------------------------------------------------------------------
134 // TimeSpanningInterface
135 //----------------------------------------------------------------------------
136 
141 class TimeSpanningInterface : public TimePointInterface, public AttStartEndId, public AttTimestamp2Log {
142 public:
149  virtual ~TimeSpanningInterface();
150  void Reset() override;
151  InterfaceId IsInterface() const override { return INTERFACE_TIME_SPANNING; }
153 
158  void SetEnd(LayerElement *end);
160  LayerElement *GetEnd() { return m_end; }
161  const LayerElement *GetEnd() const { return m_end; }
163 
167  bool SetStartAndEnd(LayerElement *element);
168 
172  bool HasStartAndEnd() const { return (m_start && m_end); }
173 
177  Measure *GetEndMeasure();
179  const Measure *GetEndMeasure() const;
181 
185  bool IsSpanningMeasures() const;
186 
190  void SetIDStr();
191 
196  bool IsOrdered() const;
198  bool IsOrdered(const LayerElement *start, const LayerElement *end) const;
200 
207  StaffAlignment *alignment, curvature_CURVEDIR curveDir, bool &skipAbove, bool &skipBelow);
208 
209  //-----------------//
210  // Pseudo functors //
211  //-----------------//
212 
218  FunctorCode InterfacePrepareTimeSpanning(PrepareTimeSpanningFunctor &functor, Object *object);
220  FunctorCode InterfacePrepareTimestamps(PrepareTimestampsFunctor &functor, Object *object) override;
221  FunctorCode InterfacePrepareStaffCurrentTimeSpanning(
222  PrepareStaffCurrentTimeSpanningFunctor &functor, Object *object);
223  FunctorCode InterfaceResetData(ResetDataFunctor &functor, Object *object) override;
225 
226 private:
227  //
228 public:
229  //
230 private:
231  LayerElement *m_end;
232  std::string m_endID;
233 };
234 
235 } // namespace vrv
236 
237 #endif
vrv::PrepareTimePointingFunctor
This class matches the start for TimePointingInterface elements (such as fermata or harm).
Definition: preparedatafunctor.h:414
vrv::TimePointInterface::SetIDStr
void SetIDStr()
Extract the fragment of the start or end @xml:id if given.
vrv::Measure
This class represents a measure in a page-based score (Doc).
Definition: measure.h:37
vrv::TimePointInterface::GetStartMeasure
Measure * GetStartMeasure()
Return the start measure of the TimePointInterface.
vrv::TimeSpanningInterface::GetCrossStaffOverflows
void GetCrossStaffOverflows(StaffAlignment *alignment, curvature_CURVEDIR curveDir, bool &skipAbove, bool &skipBelow)
Check if the slur or tie needs to be taken into account as overflow above or below in case of cross-s...
vrv::TimeSpanningInterface::InterfacePrepareTimeSpanning
FunctorCode InterfacePrepareTimeSpanning(PrepareTimeSpanningFunctor &functor, Object *object)
We have functor code in the interface for avoiding code duplication in each implementation class.
vrv::Object
This class represents a basic object.
Definition: object.h:59
vrv::Interface
This is a base class for regrouping MEI att classes.
Definition: interface.h:32
vrv::TimePointInterface::VerifyMeasure
bool VerifyMeasure(const Object *owner) const
Return true if the interface owner is encoded in the measure of its start element Display a warning i...
vrv::TimePointInterface::InterfacePrepareTimePointing
FunctorCode InterfacePrepareTimePointing(PrepareTimePointingFunctor &functor, Object *object)
We have functor code in the interface for avoiding code duplication in each implementation class.
vrv::TimePointInterface::SetStartOnly
bool SetStartOnly(LayerElement *start)
Set first LayerElement by verifying it is the correct one.
vrv::PrepareTimestampsFunctor
This class matches start and end for TimeSpanningInterface elements with tstamp(2) attributes.
Definition: preparedatafunctor.h:524
vrv::TimeSpanningInterface::IsOrdered
bool IsOrdered() const
Check if the end points are temporally ordered @Return true if end temporally occurs after start.
vrv::TimePointInterface::IsOnStaff
bool IsOnStaff(int n) const
Return true if the TimePointInterface occurs on the staff Looks that the parent staff if the using @...
vrv::TimePointInterface::GetTstampStaves
std::vector< const Staff * > GetTstampStaves(const Measure *measure, const Object *object) const
Return a vector of staves looking at the @staff attribute or at the parent staff of the @startid.
vrv::TimeSpanningInterface::Reset
void Reset() override
Virtual reset method.
vrv::TimePointInterface::AddStaff
void AddStaff(int n)
Add a staff n to the AttStaffident vector (if not already there)
vrv::TimeSpanningInterface::GetEndMeasure
Measure * GetEndMeasure()
Return the end measure of the TimePointInterface.
vrv::TimePointInterface::HasStart
bool HasStart() const
Return true if a start is given (@startid or @tstamp)
Definition: timeinterface.h:71
vrv::TimeSpanningInterface::IsSpanningMeasures
bool IsSpanningMeasures() const
Return true if the element is spanning over two or more measures.
vrv::TimeSpanningInterface::IsInterface
InterfaceId IsInterface() const override
Virtual method returning the InterfaceId of the interface.
Definition: timeinterface.h:151
vrv::TimeSpanningInterface
This class is an interface for spanning elements, such as slur, hairpin, etc.
Definition: timeinterface.h:141
vrv::LayerElement
This class is a base class for the Layer (<layer>) content.
Definition: layerelement.h:46
vrv::ResetDataFunctor
This class resets the drawing values before calling PrepareData after changes.
Definition: resetfunctor.h:22
vrv::TimePointInterface::IsInterface
InterfaceId IsInterface() const override
Virtual method returning the InterfaceId of the interface.
Definition: timeinterface.h:45
vrv::TimePointInterface::Reset
void Reset() override
Virtual reset method.
vrv::TimePointInterface
This class is an interface for elements having a single time point, such as tempo,...
Definition: timeinterface.h:35