tracktion-engine 3.0-10-g034fdde4aa5
Tracktion Engine — High level data model for audio applications

« « « Anklang Documentation
Loading...
Searching...
No Matches
Public Member Functions | List of all members
tracktion::engine::ArrangerTrack Class Reference

A track similar to the MarkerTrack but can be used to move sections of an Edit around. More...

#include "tracktion_ArrangerTrack.h"

Inheritance diagram for tracktion::engine::ArrangerTrack:
tracktion::engine::ClipTrack tracktion::engine::Track tracktion::engine::ClipOwner tracktion::engine::EditItem tracktion::engine::Selectable juce::ReferenceCountedObject juce::ValueTree::Listener juce::AsyncUpdater

Public Member Functions

 ArrangerTrack (Edit &, const juce::ValueTree &)
 
bool isArrangerTrack () const override
 Returns true if this is an ArrangerTrack.
 
juce::String getSelectableDescription () override
 Subclasses must return a description of what they are.
 
juce::String getName () const override
 
bool canContainPlugin (Plugin *) const override
 Returns true if this track can contain a specific Plugin.
 
- Public Member Functions inherited from tracktion::engine::ClipTrack
 ClipTrack (Edit &, const juce::ValueTree &, bool hasModifierList)
 
void initialise () override
 Initialises the Track.
 
void flushStateToValueTree () override
 Flushes all plugin states on the track to the state object.
 
ClipfindClipForID (EditItemID) const override
 Returns a clip one with a matching ID can be found on this Track.
 
CollectionClipgetCollectionClip (int index) const noexcept
 
CollectionClipgetCollectionClip (Clip *) const
 
int getNumCollectionClips () const noexcept
 
int indexOfCollectionClip (CollectionClip *) const
 
int getIndexOfNextCollectionClipAt (TimePosition)
 
CollectionClipgetNextCollectionClipAt (TimePosition)
 
bool contains (CollectionClip *) const
 
void addCollectionClip (CollectionClip *)
 
void removeCollectionClip (CollectionClip *)
 
int getNumTrackItems () const override
 Should return the number of TrackItem[s] on this Track.
 
TrackItemgetTrackItem (int idx) const override
 Should return the TrackItem at the given index.
 
int indexOfTrackItem (TrackItem *) const override
 Should return the index of the given TrackItem.
 
int getIndexOfNextTrackItemAt (TimePosition) override
 Should return the index of the TrackItem after this time.
 
TrackItemgetNextTrackItemAt (TimePosition) override
 Should return the TrackItem after this time.
 
void insertSpaceIntoTrack (TimePosition, TimeDuration) override
 inserts space and moves everything up
 
TimeDuration getLength () const
 
TimeDuration getLengthIncludingInputTracks () const
 
TimeRange getTotalRange () const
 
bool addClip (const Clip::Ptr &)
 
ClipinsertClipWithState (juce::ValueTree)
 
ClipinsertClipWithState (const juce::ValueTree &stateToUse, const juce::String &name, TrackItem::Type type, ClipPosition position, bool deleteExistingClips, bool allowSpottingAdjustment)
 
ClipinsertNewClip (TrackItem::Type, TimeRange position, SelectionManager *selectionManagerToSelectWith)
 
ClipinsertNewClip (TrackItem::Type, const juce::String &name, TimeRange position, SelectionManager *selectionManagerToSelectWith)
 
ClipinsertNewClip (TrackItem::Type, const juce::String &name, ClipPosition position, SelectionManager *selectionManagerToSelectWith)
 
juce::ReferenceCountedObjectPtr< WaveAudioClipinsertWaveClip (const juce::String &name, const juce::File &sourceFile, ClipPosition position, bool deleteExistingClips)
 
juce::ReferenceCountedObjectPtr< WaveAudioClipinsertWaveClip (const juce::String &name, ProjectItemID sourceID, ClipPosition position, bool deleteExistingClips)
 
juce::ReferenceCountedObjectPtr< MidiClipinsertMIDIClip (TimeRange position, SelectionManager *selectionManagerToSelectWith)
 
juce::ReferenceCountedObjectPtr< MidiClipinsertMIDIClip (const juce::String &name, TimeRange position, SelectionManager *selectionManagerToSelectWith)
 
juce::ReferenceCountedObjectPtr< EditClipinsertEditClip (TimeRange position, ProjectItemID sourceID)
 
void deleteRegion (TimeRange, SelectionManager *)
 
void deleteRegionOfClip (Clip::Ptr, TimeRange, SelectionManager *)
 
ClipsplitClip (Clip &, TimePosition)
 breaks a clip into 2 bits
 
void splitAt (TimePosition)
 split all clips at this time
 
TimePosition getNextTimeOfInterest (TimePosition afterThisTime)
 finds the next cut point
 
TimePosition getPreviousTimeOfInterest (TimePosition beforeThisTime)
 
bool containsPlugin (const Plugin *) const override
 Tests whether this Track or a clip on it contains the given plugin.
 
Plugin::Array getAllPlugins () const override
 Returns all pugins on this Track.
 
void sendMirrorUpdateToAllPlugins (Plugin &) const override
 Sends a message to all plugins that the given plugin has changed.
 
bool areAnyClipsUsingFile (const AudioFile &)
 
bool containsAnyMIDIClips () const
 
juce::ValueTreegetClipOwnerState () override
 Must return the state of this ClipOwner.
 
EditItemID getClipOwnerID () override
 Must return the ID of this ClipOwner.
 
SelectablegetClipOwnerSelectable () override
 Must return the selectable if this ClipOwner is one.
 
EditgetClipOwnerEdit () override
 Must return the Edit this ClipOwner belongs to.
 
void clipCreated (Clip &) override
 Called when a clip is created which could be during Edit load.
 
void clipAddedOrRemoved () override
 Called when a clip is added or removed.
 
void clipOrderChanged () override
 Called when clips have moved times so that their order has changed.
 
void clipPositionChanged () override
 Called when a clip start or end position has changed.
 
- Public Member Functions inherited from tracktion::engine::Track
 Track (Edit &, const juce::ValueTree &, bool hasModifierList)
 Creates a track with a given state.
 
 ~Track () override
 Destructor.
 
void refreshCurrentAutoParam ()
 Updates the current parameter bases on the set IDs.
 
juce::String getName () const override
 Returns the name of the Track.
 
void setName (const juce::String &)
 Sets the name of the Track.
 
void resetName ()
 Sets the name of the Track to an empty string.
 
virtual void sanityCheckName ()
 Sub-classes can impliment this to avoid certain characters being used in a name.
 
virtual bool isAudioTrack () const
 Returns true if this is an AudioTrack.
 
virtual bool isAutomationTrack () const
 Returns true if this is an AutomationTrack.
 
virtual bool isFolderTrack () const
 Returns true if this is a FolderTrack.
 
virtual bool isMarkerTrack () const
 Returns true if this is a MarkerTrack.
 
virtual bool isTempoTrack () const
 Returns true if this is a TempoTrack.
 
virtual bool isChordTrack () const
 Returns true if this is a ChordTrack.
 
virtual bool isMasterTrack () const
 Returns true if this is a MasterTrack.
 
bool canContainMarkers () const
 Returns true if this Track can contain MarkerClip[s].
 
bool canContainMIDI () const
 Returns true if this Track can contain MidiClip[s].
 
bool canContainAudio () const
 Returns true if this Track can contain WaveAudioClip[s].
 
bool canContainEditClips () const
 Returns true if this Track can contain EditClip[s].
 
bool canContainPlugins () const
 Returns true if this Track can contain Plugin[s].
 
bool isMovable () const
 Returns true if this Track is movable.
 
bool acceptsInput () const
 Returns true if this track can have inputs assigned to it.
 
bool createsOutput () const
 Returns true if this track creates audible output.
 
bool wantsAutomation () const
 Returns true if this track can show automation.
 
virtual bool isFrozen (FreezeType) const
 Returns true if this track is frozen using the given type.
 
virtual void setFrozen (bool, FreezeType)
 Attempts to freeze or unfreeze the track using a given FreezeType.
 
bool isHidden () const
 Returns true if this track should be hidden from view.
 
void setHidden (bool h)
 Sets whether this track should be hidden from view.
 
bool isProcessing (bool includeParents) const
 Returns true if this track should be included in playback.
 
void setProcessing (bool p)
 Sets whether this track should be included in playback.
 
virtual bool processAudioNodesWhileMuted () const
 Subclasses can override this to ensure track contents are still played even when the track is muted.
 
virtual juce::Array< Track * > getInputTracks () const
 Should return any tracks which feed into this track.
 
juce::Array< Track * > getAllSubTracks (bool recursive) const
 Returns all nested tracks.
 
juce::Array< AudioTrack * > getAllAudioSubTracks (bool recursive) const
 Returns all nested AudioTrack[s].
 
TrackListgetSubTrackList () const
 Returns the TrackList if this Track has any sub-tracks.
 
bool hasSubTracks () const
 Returns true if this track has any subtracks.
 
TrackgetSiblingTrack (int delta, bool keepWithinSameParent) const
 Returns a sibling Track to this one.
 
juce::ValueTree getParentTrackTree () const
 Returns the state of the parent Track.
 
TrackgetParentTrack () const
 Returns the parent Track if this is a nested track.
 
FolderTrackgetParentFolderTrack () const
 Returns the parent FolderTrack if this is nested in one.
 
bool isAChildOf (const Track &possibleParent) const
 Tests whether this is a child of a given Track.
 
bool isPartOfSubmix () const
 Tests whether this nested within a submix FolderTrack.
 
int getIndexInEditTrackList () const
 Returns the index of this track in a flat list of tracks contained in an Edit.
 
int getTrackDepth () const
 Returns the number of parents within which this track is nested.
 
virtual bool isMuted (bool) const
 Returns true if this track is muted.
 
virtual bool isSolo (bool) const
 Returns true if this track is soloed.
 
virtual bool isSoloIsolate (bool) const
 Returns true if this track is solo isolated.
 
virtual void setMute (bool)
 Subclasses should implement this to mute themselves.
 
virtual void setSolo (bool)
 Subclasses should implement this to solo themselves.
 
virtual void setSoloIsolate (bool)
 Subclasses should implement this to solo isolate themselves.
 
MuteAndSoloLightState getMuteAndSoloLightState () const
 Returns the mute a solo status.
 
bool shouldBePlayed () const noexcept
 Tests whether this track should be audible in the playback graph i.e.
 
void updateAudibility (bool areAnyTracksSolo)
 Updates the audibility state of the Track.
 
juce::Array< AutomatableParameter * > getAllAutomatableParams () const
 Returns all the parameters for this track's Plugin[s] and Modifier[s].
 
void visitAllAutomatableParams (const std::function< void(AutomatableParameter &)> &) const
 Visits all the parameters for this track's Plugin[s] and Modifier[s].
 
AutomatableParametergetCurrentlyShownAutoParam () const noexcept
 Returns the parameter whos curve should be shown on this Track.
 
void setCurrentlyShownAutoParam (const AutomatableParameter::Ptr &)
 Sets a parameter to display on this Track.
 
void hideAutomatableParametersForSource (EditItemID pluginOrParameterID)
 Hides a shown parameter if it matches the given ID.
 
bool hasFreezePointPlugin () const
 Tests whether this Track contains a FreezePointPlugin.
 
juce::Array< AutomatableEditItem * > getAllAutomatableEditItems () const
 Returns all AutomatableEditItem[s] on this Track.
 
void flipAllPluginsEnablement ()
 Toggles the Plugin::isEnabled state for all Plugin[s] on this Track.
 
ModifierListgetModifierList () const
 Returns the ModifierList for this track, if it has one.
 
void setColour (juce::Colour newColour)
 Sets a colour for this track to use.
 
juce::Colour getColour () const
 Returns the the of this.
 
bool canShowImage () const
 Tests whether this Track can show an image.
 
void setTrackImage (const juce::String &idOrData)
 Sets some image data to use.
 
juce::String getTrackImage () const
 Returns previously set image data.
 
bool imageHasChanged ()
 Tests and resets a flag internally kept when the image changes.
 
void setTags (const juce::StringArray &)
 Sets an array of Strings to use as tags.
 
juce::String getTags () const
 Returns the tags as a pipe-separated single String.
 
const juce::StringArraygetTagsArray () const noexcept
 Returns the array of tags.
 
- Public Member Functions inherited from tracktion::engine::EditItem
 EditItem (EditItemID, Edit &)
 
- Public Member Functions inherited from tracktion::engine::Selectable
virtual void selectionStatusChanged (bool isNowSelected)
 Can be overridden to tell this object that it has just been selected or deselected.
 
virtual void changed ()
 This should be called to send a change notification to any SelectableListeners that are registered with this object.
 
virtual void selectableAboutToBeDeleted ()
 Called just before the selectable is about to be deleted so any subclasses should still be valid at this point.
 
void addListener (SelectableListener *)
 
void removeListener (SelectableListener *)
 
void addSelectableListener (SelectableListener *)
 
void removeSelectableListener (SelectableListener *)
 
void cancelAnyPendingUpdates ()
 If changed() has been called, this will cancel any pending async change notificaions.
 
void deselect ()
 
void propertiesChanged ()
 
void notifyListenersOfDeletion ()
 
WeakRef getWeakRef ()
 
- Public Member Functions inherited from juce::ReferenceCountedObject
void incReferenceCount () noexcept
 
void decReferenceCount () noexcept
 
bool decReferenceCountWithoutDeleting () noexcept
 
int getReferenceCount () const noexcept
 
- Public Member Functions inherited from tracktion::engine::ClipOwner
 ClipOwner ()
 Constructs an empty ClipOwner.
 
virtual ~ClipOwner ()
 Destructor.
 
const juce::Array< Clip * > & getClips () const
 Returns the clips this owner contains.
 

Additional Inherited Members

- Public Types inherited from tracktion::engine::ClipTrack
using Ptr = juce::ReferenceCountedObjectPtr< ClipTrack >
 
- Public Types inherited from tracktion::engine::Track
enum  FreezeType { groupFreeze , individualFreeze , anyFreeze }
 Determines the type of freeze. More...
 
enum  MuteAndSoloLightState {
  soloLit , soloFlashing , soloIsolate , muteLit ,
  muteFlashing
}
 Determines the status of the mute and solo indicators. More...
 
using Ptr = juce::ReferenceCountedObjectPtr< Track >
 
using Array = juce::ReferenceCountedArray< Track >
 
- Public Types inherited from tracktion::engine::Selectable
using WeakRef = juce::WeakReference< Selectable >
 
- Static Public Member Functions inherited from tracktion::engine::Selectable
static void initialise ()
 
static bool isSelectableValid (const Selectable *) noexcept
 checks whether this object has been deleted.
 
- Public Attributes inherited from tracktion::engine::Track
juce::ValueTree state
 The state of this Track.
 
PluginList pluginList
 The Track's PluginList.
 
- Public Attributes inherited from tracktion::engine::EditItem
Editedit
 
const EditItemID itemID
 Every EditItem has an ID which is unique within the edit.
 
- Public Attributes inherited from tracktion::engine::Selectable
WeakRef::Master masterReference
 
- Static Public Attributes inherited from tracktion::engine::Track
static const int minTrackHeightForDetail
 The minimim height to show track contents at.
 
static const int trackHeightForEditor
 The height at which inline editors should be shown.
 
static const int frozenTrackHeight
 The height to show group frozen tracks.
 
- Protected Member Functions inherited from tracktion::engine::ClipTrack
juce::Array< TimePositionfindAllTimesOfInterest ()
 
void refreshTrackItems () const
 
- Protected Member Functions inherited from tracktion::engine::Track
void valueTreePropertyChanged (juce::ValueTree &, const juce::Identifier &) override
 
void valueTreeChildAdded (juce::ValueTree &, juce::ValueTree &) override
 
void valueTreeChildRemoved (juce::ValueTree &, juce::ValueTree &, int) override
 
void valueTreeChildOrderChanged (juce::ValueTree &, int, int) override
 
void valueTreeParentChanged (juce::ValueTree &) override
 
void handleAsyncUpdate () override
 
virtual bool isTrackAudible (bool areAnyTracksSolo) const
 Returns whether this Track should be audible.
 
- Protected Member Functions inherited from juce::ReferenceCountedObject
 ReferenceCountedObject (const ReferenceCountedObject &) noexcept
 
 ReferenceCountedObject (ReferenceCountedObject &&) noexcept
 
ReferenceCountedObjectoperator= (const ReferenceCountedObject &) noexcept
 
ReferenceCountedObjectoperator= (ReferenceCountedObject &&) noexcept
 
void resetReferenceCount () noexcept
 
- Protected Member Functions inherited from juce::ValueTree::Listener
virtual void valueTreeRedirected (ValueTree &treeWhichHasBeenChanged)
 
- Protected Member Functions inherited from juce::AsyncUpdater
void triggerAsyncUpdate ()
 
void cancelPendingUpdate () noexcept
 
void handleUpdateNowIfNeeded ()
 
bool isUpdatePending () const noexcept
 
- Protected Member Functions inherited from tracktion::engine::ClipOwner
void initialiseClipOwner (Edit &, juce::ValueTree clipParentState)
 Must be called once from the subclass constructor to init the clip owner.
 
- Protected Attributes inherited from tracktion::engine::ClipTrack
std::unique_ptr< CollectionClipListcollectionClipList
 
bool trackItemsDirty
 
juce::Array< TrackItem * > trackItems
 

Detailed Description

A track similar to the MarkerTrack but can be used to move sections of an Edit around.

Definition at line 16 of file tracktion_ArrangerTrack.h.

Constructor & Destructor Documentation

◆ ArrangerTrack()

tracktion::engine::ArrangerTrack::ArrangerTrack ( Edit e,
const juce::ValueTree v 
)

Definition at line 14 of file tracktion_ArrangerTrack.cpp.

◆ ~ArrangerTrack()

tracktion::engine::ArrangerTrack::~ArrangerTrack ( )
override

Definition at line 19 of file tracktion_ArrangerTrack.cpp.

Member Function Documentation

◆ canContainPlugin()

bool tracktion::engine::ArrangerTrack::canContainPlugin ( Plugin ) const
overridevirtual

Returns true if this track can contain a specific Plugin.

Subclasses can override this to avoid specific plugins such as VCAPlugin[s] on AudioTrack[s].

Implements tracktion::engine::Track.

Definition at line 27 of file tracktion_ArrangerTrack.cpp.

◆ getName()

juce::String tracktion::engine::ArrangerTrack::getName ( ) const
overridevirtual

Implements tracktion::engine::EditItem.

Definition at line 26 of file tracktion_ArrangerTrack.cpp.

◆ getSelectableDescription()

juce::String tracktion::engine::ArrangerTrack::getSelectableDescription ( )
overridevirtual

Subclasses must return a description of what they are.

Implements tracktion::engine::Selectable.

Definition at line 25 of file tracktion_ArrangerTrack.cpp.

◆ isArrangerTrack()

bool tracktion::engine::ArrangerTrack::isArrangerTrack ( ) const
overridevirtual

Returns true if this is an ArrangerTrack.

Reimplemented from tracktion::engine::Track.

Definition at line 24 of file tracktion_ArrangerTrack.cpp.


The documentation for this class was generated from the following files: