ScorePlayer


A ScorePlayer is an object which can play a Score. The ScorePlayer keeps track of the position, speed, and filters of the Score. Note that it is perfectly okay to have multiple ScorePlayers playing the same Score at once.

class ScorePlayer {
public:
  typedef UtilPtr<Score> ScorePtr;
  typedef UtilPtr<MidiFilter> MidiFilterPtr;
  ScorePlayer(ScorePtr);
  ~ScorePlayer();
  void start();
  void stop();
  bool isPlaying() const;
  void setLoop(bool);
  bool getLoop() const;
  void rewind();
  void setIndex(int);
  int getIndex() const;
  void setTimeUnscaled(ScoreTime);
  ScoreTime getTimeUnscaled() const;
  void setTimeScaled(ScoreTime);
  ScoreTime getTimeScaled() const;
  void setScale(ScoreScale);
  ScoreScale getScale() const;
  void addFilter(MidiFilterPtr);
  void removeFilter(char*);
  MidiFilterPtr getFilter(char*) const;
};
ScorePlayer(ScorePtr s)
Creates a new ScorePlayer which can play Score s. When created, the ScorePlayer is not playing, is not looped, is positioned at the beginning, and has no filters.
~ScorePlayer()
Destroys the ScorePlayer. The ScorePlayer stops playing when it is destroyed.
void start()
This causes the ScorePlayer to start playing the Score at the current position. Nothing happens if the ScorePlayer is already playing.
void stop()
This causes the ScorePlayer to stop playing the Score. Nothing happens if the ScorePlayer is not playing.
bool isPlaying()
This function returns 1 if the ScorePlayer is playing and 0 if it is not.
void setLoop(bool l)
This function causes the ScorePlayer to loop (i. e. go back to the beginning when it reaches the end) if the argument is 1, and not loop (i. e. stop playing when it reaches the end) if the argument is 0. It is okay to do this whether the ScorePlayer is currently playing or not.
bool getLoop()
This returns the value set by setLoop.
void rewind()
This moves the ScorePlayer back to the beginning of the Score. Yes, it is okay to do this while the ScorePlayer is playing.
void setIndex(int n)
This moves the ScorePlayer to event number n. Yes, it is okay to do this while the ScorePlayer is playing.
int getIndex()
This returns the current event index.
void setTimeUnscaled(ScoreTime t)
This sets the position of the ScorePlayer to t demimilliseconds from the beginning of the Score, based on the default speed of the Score. It is okay to call this function while the ScorePlayer is playing.
ScoreTime getTimeUnscaled()
This gets the position of the ScorePlayer in demimilliseconds from the beginning of the Score, based on the default speed of the Score.
void setTimeScaled(ScoreTime t)
This sets the position of the ScorePlayer to t demimilliseconds from the beginning of the Score, based on the current ScoreScale of the ScorePlayer. It is okay to call this function while the ScorePlayer is playing.
ScoreTime getTimeScaled()
This gets the position of the ScorePlayer in demimilliseconds from the beginning of the Score, based on the current ScoreScale of the ScorePlayer.
void setScale(ScoreScale s)
This sets the speed of the ScorePlayer. The default durations are multiplied by s to get the actual durations. Therefore, 1 will play the Score at the default speed, .5 will play it twice as fast, 2 will play it twice as slow, etc. And guess what? You can call this function while the ScorePlayer is playing.
ScoreScale getScale()
This returns the scaling factor that was set with setScale.
void addFilter(MidiFilterPtr f)This member function adds a MidiFilter to the ScorePlayer. If a MidiFilter of the same type already exists (e. g. there is already a Transposer and you try to add another Transposer), then the existing one will be removed.
void removeFilter(char* x)
This member function removes the filter named x (for example, "Transposer") from the ScorePlayer
MidiFilterPtr getFilter(char* x)
This member function returns a pointer to the filter named x, if it exists in the current ScorePlayer, or a null pointer if it does not.

Modified 16 December 1995 pepellet@mit.edu