|
tracktion-engine 3.0-10-g034fdde4aa5
Tracktion Engine — High level data model for audio applications
« « « Anklang Documentation |
Base class for Clips that produce some kind of audio e.g. More...
#include "tracktion_AudioClipBase.h"
Classes | |
| struct | ProxyRenderingInfo |
| Holds information about how to render a proxy for this clip. More... | |
| class | TempoDetectTask |
| Performs a tempo detection task on a background thread. More... | |
Public Types | |
| enum | FadeBehaviour { gainFade , speedRamp } |
| Describes the fade behaviour. More... | |
| enum | AutoPitchMode { pitchTrack , chordTrackMono , chordTrackPoly } |
| Defines the auto pitch mode. More... | |
| enum class | ClipDirection { previous , next , none } |
| Defines a prevous/next direction. More... | |
| using | Ptr = juce::ReferenceCountedObjectPtr< AudioClipBase > |
Public Types inherited from tracktion::engine::Clip | |
| enum class | FollowActionDurationType { beats , loops } |
| Defines the types of duration follow actions can use. More... | |
| enum | SyncType { syncBarsBeats , syncAbsolute } |
| Determines the clip sync type. More... | |
| using | Ptr = juce::ReferenceCountedObjectPtr< Clip > |
| using | Array = juce::ReferenceCountedArray< Clip > |
Public Types inherited from tracktion::engine::TrackItem | |
| enum class | Type { unknown , wave , midi , edit , step , marker , pitch , timeSig , collection , video , recording , chord , arranger , container } |
| Defines the types of item that can live on Track[s]. More... | |
Public Types inherited from tracktion::engine::Selectable | |
| using | WeakRef = juce::WeakReference< Selectable > |
Public Member Functions | |
| AudioClipBase (const juce::ValueTree &, EditItemID, Type, ClipOwner &) | |
| Creates a basic AudioClip. | |
| ~AudioClipBase () override | |
| Destructor. | |
| TimeDuration | getMaximumLength () override |
| Returns the maximum length for this clip. | |
| virtual TimeDuration | getSourceLength () const =0 |
| Must return the length in seconds of the source material e.g. | |
| virtual AudioFile | getAudioFile () const |
| Returns the file used to play back the source and will get proxied etc. | |
| AudioFile | getPlaybackFile () |
| Returns the current AudioFile being used by the Clip, either the original source or a proxy. | |
| virtual juce::File | getOriginalFile () const =0 |
| Must return the file that the source ProjectItemID refers to. | |
| virtual HashCode | getHash () const =0 |
| Must return a unique hash for this clip's source. | |
| virtual AudioFileInfo | getWaveInfo () |
| Returns the WaveInfo for a clip. | |
| void | markAsDirty () |
| Resets the dirty flag so that a new render will be attempted. | |
| void | updateSourceFile () |
| Checks the current source file to see if it's up to date and then triggers a source render if needed. | |
| virtual bool | needsRender () const |
| Subclasses should override this to return true if they need the rest of the render callbacks. | |
| virtual RenderManager::Job::Ptr | getRenderJob (const AudioFile &) |
| Subclasses should override this to return a RenderJob suitable for rendering its source file. | |
| virtual void | renderComplete () |
| Callback to indicate that the render has completed. | |
| virtual juce::String | getRenderMessage () |
| Override this to return a custom message to be displayed over waveforms during rendering. | |
| virtual juce::String | getClipMessage () |
| Override this to return a custom message to display over the clip where the "file missing" text usually goes. | |
| void | cancelCurrentRender () |
| If a render is in progress, this will cancel it. | |
| void | setGainDB (float dB) |
| Sets the gain of the clip in dB. | |
| float | getGainDB () const noexcept |
| Returns the gain of the clip in dB. | |
| float | getGain () const noexcept |
| Returns the gain of the clip. | |
| void | setPan (float pan) |
| Sets the pan of the clip. | |
| float | getPan () const noexcept |
| Returns the pan of the clip from -1 to 1. | |
| void | setMuted (bool shouldBeMuted) override |
| Mutes or unmutes the clip. | |
| bool | isMuted () const override |
| Returns true if the clip is muted. | |
| LiveClipLevel | getLiveClipLevel () |
| Returns a LiveClipLevel which can be used to read the gain, pan and mute statuses. | |
| void | setLeftChannelActive (bool) |
| Enables the left channel of the clip. | |
| bool | isLeftChannelActive () const |
| Returns whether the left channel of the clip is enabled. | |
| void | setRightChannelActive (bool) |
| Enables the right channel of the clip. | |
| bool | isRightChannelActive () const |
| Returns whether the right channel of the clip is enabled. | |
| juce::AudioChannelSet | getActiveChannels () const |
| Returns the layout of the active channels. | |
| bool | setFadeIn (TimeDuration length) |
| Sets the fade in duration in seconds. | |
| TimeDuration | getFadeIn () const |
| Returns the fade in duration in seconds. | |
| bool | setFadeOut (TimeDuration length) |
| Sets the fade out duration in seconds. | |
| TimeDuration | getFadeOut () const |
| Returns the fade out duration in seconds. | |
| void | setFadeInType (AudioFadeCurve::Type) |
| Sets the curve shape for the fade in to use. | |
| AudioFadeCurve::Type | getFadeInType () const |
| Returns the curve shape for the fade in to use. | |
| void | setFadeOutType (AudioFadeCurve::Type newType) |
| Sets the curve shape for the fade out to use. | |
| AudioFadeCurve::Type | getFadeOutType () const |
| Returns the curve shape for the fade out to use. | |
| void | setAutoCrossfade (bool shouldAutoCrossfade) |
| Enables/disables auto-crossfading. | |
| bool | getAutoCrossfade () const noexcept |
| Returns whether auto-crossfade is enabled. | |
| void | updateAutoCrossfadesAsync (bool updateOverlapped) |
| Triggers an update of the auto-crossfades. | |
| void | applyEdgeFades () |
| Sets the fade in/out lengths to be 0.03s to avoid any clicks at the start/end of th clip. | |
| void | copyFadeToAutomation (bool fadeIn, bool removeClipFade) |
| Copies the fade in curve to a volume automation curve. | |
| void | setFadeInBehaviour (FadeBehaviour newBehaviour) |
| Sets the fade in behaviour. | |
| FadeBehaviour | getFadeInBehaviour () const |
| Returns the fade in behaviour. | |
| void | setFadeOutBehaviour (FadeBehaviour newBehaviour) |
| Sets the fade out behaviour. | |
| FadeBehaviour | getFadeOutBehaviour () const |
| Returns the fade out behaviour. | |
| virtual void | setLoopDefaults ()=0 |
| Override this to fill in the LoopInfo structure as best fits the source. | |
| void | setLoopInfo (const LoopInfo &) |
| Sets a LoopInfo to describe this clip's tempo, time sig etc. | |
| const LoopInfo & | getLoopInfo () const |
| Returns the LoopInfo being used to describe this clip. | |
| LoopInfo & | getLoopInfo () |
| Returns the LoopInfo being used to describe this clip. | |
| TimeRange | getLoopRange () const |
| Returns the loop range in seconds. | |
| bool | canLoop () const override |
| Returns true if this clip is capable of looping. | |
| bool | isLooping () const override |
| Returns true if this clip is currently looping. | |
| bool | beatBasedLooping () const override |
| Returns true if this clip's looping is based on beats or false if absolute time. | |
| void | setNumberOfLoops (int num) override |
| Sets the clip looping a number of times. | |
| void | disableLooping () override |
| Disables all looping. | |
| BeatPosition | getLoopStartBeats () const override |
| Returns the beat position of the loop start point. | |
| TimePosition | getLoopStart () const override |
| Returns the start time of the loop start point. | |
| BeatDuration | getLoopLengthBeats () const override |
| Returns the length of loop in beats. | |
| TimeDuration | getLoopLength () const override |
| Returns the length of loop in seconds. | |
| void | setLoopRange (TimeRange) override |
| Sets the loop range the clip should use in seconds. | |
| void | setLoopRangeBeats (BeatRange) override |
| Sets the loop range the clip should use in beats. | |
| void | setAutoDetectBeats (bool) |
| Enables auto-detection of beats. | |
| bool | getAutoDetectBeats () const |
| Returns true if auto-detect of beats is enabled. | |
| void | setBeatSensitivity (float s) |
| Sets the beat sensitivity, triggering a LoopInfo update if auto-detect is enabled. | |
| float | getBeatSensitivity () const |
| Returns the beat sensitivity. | |
| void | pitchTempoTrackChanged () override |
| Called when there are pitch or tempo changes made which might require clips to adjust timing information. | |
| void | setSpeedRatio (double newSpeed) override |
| Sets a speed ratio i.e. | |
| void | setTimeStretchMode (TimeStretcher::Mode mode) |
| Sets a time-stretch mode to use. | |
| TimeStretcher::Mode | getTimeStretchMode () const noexcept |
| Returns the time-stretch mode that has been set. | |
| TimeStretcher::Mode | getActualTimeStretchMode () const noexcept |
| Returns the time-stretch mode that is in use. | |
| void | setAutoTempo (bool shouldUseAutoTempo) |
| Enables/disables auto-tempo. | |
| bool | getAutoTempo () const |
| Returns true if auto-tempo has been set. | |
| void | setAutoPitch (bool shouldUseAutoPitch) |
| Enables/disables auto-pitch. | |
| bool | getAutoPitch () const |
| Returns true if auto-pitch has been set. | |
| void | setAutoPitchMode (AutoPitchMode m) |
| Sets the AutoPitchMode to use. | |
| AutoPitchMode | getAutoPitchMode () |
| Returns the AutoPitchMode in use. | |
| void | setWarpTime (bool shouldUseWarpTime) |
| Enables/disables warp time. | |
| bool | getWarpTime () const |
| Returns true if warp time is enabled. | |
| WarpTimeManager & | getWarpTimeManager () const |
| Returns the WarpTimeManager for this clip used to maipluate warp markers. | |
| void | setTranspose (int numSemitones) |
| Sets the number of semitones to transpose the clip by. | |
| int | getTransposeSemiTones (bool includeAutoPitch) const |
| Returns the number of semitones this clip will be changed by. | |
| void | setPitchChange (float semitones) |
| Sets the number of semitones to transpose the clip by. | |
| float | getPitchChange () const |
| Returns the number of semitones to transpose the clip by. | |
| float | getPitchRatio () const |
| Returns the pitch change as a normalised ratio. | |
| void | setIsReversed (bool shouldBeReversed) |
| Enables reversing of the clip's source material. | |
| bool | getIsReversed () const noexcept |
| Returns true if the clip's source material is reversed. | |
| LoopInfo | autoDetectBeatMarkers (const LoopInfo ¤t, bool autoBeat, float sensitivity) const |
| Scans the current source file for any beats and adds them to the LoopInfo returned. | |
| bool | performTempoDetect () |
| Performs a tempo-detection task and if successful sets the clip's LoopInfo tempo to this. | |
| juce::StringArray | getPitchChoices () |
| Returns an array describng what pitch each semitone change will be. | |
| virtual bool | canHaveEffects () const |
| Returns true if this clip can have ClipEffects added to it. | |
| void | enableEffects (bool enable, bool warn) |
| Enables/disables ClipEffects for this clip. | |
| bool | effectsEnabled () const |
| Returns true if ClipEffects are enabled. | |
| void | addEffect (const juce::ValueTree &effectsTree) |
| Adds a ClipEffect to this clip. | |
| void | setEffectsVisible (bool b) |
| Sets the effectsVisible flag for this clip. | |
| bool | getEffectsVisible () const |
| Returns true if the effectsVisible flag is set for this clip. | |
| ClipEffects * | getClipEffects () const noexcept |
| Returns the ClipEffects for this clip if it has been enabled. | |
| bool | canSnapToOriginalBWavTime () |
| Returns true if source file has a bwav time reference metadata property. | |
| void | snapToOriginalBWavTime () |
| Moves the clip to the bwav time reference metadata property time. | |
| virtual juce::Array< ProjectItemID > | getTakes () const |
| Returns the ProjectItemID of the clip's takes. | |
| juce::String | canAddClipPlugin (const Plugin::Ptr &) const |
| Returns an empty string if this plugin can be added, otherwise an error message due to the clip plugin being an incorrect type (e.g. | |
| virtual bool | isUsingFile (const AudioFile &) |
| Should return true if the clip is referencing the file in any way. | |
| AudioFile | getProxyFileToCreate (bool renderTimestretched) |
| Returns the AudioFile to create to play this clip back. | |
| void | setUsesProxy (bool canUseProxy) noexcept |
| Can be used to disable proxy file generation for this clip. | |
| bool | canUseProxy () const noexcept |
| Retuns true if this clip can use a proxy file. | |
| bool | usesTimeStretchedProxy () const |
| Retuns true if this clip use a proxy file due to timestretching. | |
| std::unique_ptr< ProxyRenderingInfo > | createProxyRenderingInfo () |
| Creates a ProxyRenderingInfo object to decribe the stretch segements of this clip. | |
| HashCode | getProxyHash () |
| Returns a hash identifying the proxy settings. | |
| void | beginRenderingNewProxyIfNeeded () |
| Triggers creation of a new proxy file if one is required. | |
| const AudioSegmentList & | getAudioSegmentList () |
| Returns an AudioSegmentList describing this file if it is using auto-tempo. | |
| void | setResamplingQuality (ResamplingQuality) |
| Sets the resampling qulity to use. | |
| ResamplingQuality | getResamplingQuality () const |
| Returns the resampling quality to the be used. | |
| void | reverseLoopPoints () |
| Reverses the loop points to expose the same section of the source file but reversed. | |
| void | checkFadeLengthsForOverrun () |
| Trims the fade in out lengths to avoid any overlap between them. | |
| AudioClipBase * | getOverlappingClip (ClipDirection) const |
| Returns the previous/next overlapping clip if one exists. | |
| bool | isUsingMelodyne () const |
| Returns true if this clip is using Melodyne. | |
| void | showMelodyneWindow () |
| Shows the Melodyne window if this clip is using Melodyne. | |
| void | hideMelodyneWindow () |
| Hides the Melodyne window if this clip is using Melodyne. | |
| void | melodyneConvertToMIDI () |
| If this clip is using Melodyne, this will create a new MIDI clip based on the Melodyne analysis. | |
| void | loadMelodyneState () |
| bool | setupARA (bool dontPopupErrorMessages) |
| This internal method is used solely to find out if createAudioNode() should return nullptr or not. | |
| void | initialise () override |
| Initialises the Clip. | |
| void | cloneFrom (Clip *) override |
| Clones the given clip to this clip. | |
| void | flushStateToValueTree () override |
| Can be overridden to ensure any state (e.g. | |
| void | setParent (ClipOwner *) override |
| bool | canBeAddedTo (ClipOwner &) override |
| Tests whether this clip can go on the given parent. | |
| void | changed () override |
| This should be called to send a change notification to any SelectableListeners that are registered with this object. | |
| juce::Colour | getDefaultColour () const override |
| Returns the default colour for this clip. | |
| PatternGenerator * | getPatternGenerator () override |
| Returns the PatternGenerator for this clip if it has one. | |
| void | addMark (TimePosition relCursorPos) |
| void | moveMarkTo (TimePosition relCursorPos) |
| void | deleteMark (TimePosition relCursorPos) |
| void | getRescaledMarkPoints (juce::Array< TimePosition > &rescaled, juce::Array< int > &orig) const |
| juce::Array< TimePosition > | getRescaledMarkPoints () const override |
| Returns the mark points relative to the start of the clip, rescaled to the current speed. | |
| juce::Array< ReferencedItem > | getReferencedItems () override |
| void | reassignReferencedItem (const ReferencedItem &, ProjectItemID newID, double newStartTime) override |
| std::shared_ptr< LaunchHandle > | getLaunchHandle () override |
| Some clip types can be launched, if that's possible, this returns a handle to trigger starting/stopping the clip. | |
| void | setUsesGlobalLaunchQuatisation (bool useGlobal) override |
| Some clip types can be launched, if that's possible, this sets whether the clip's quantisation or the global quantisation should be used. | |
| bool | usesGlobalLaunchQuatisation () override |
| Some clip types can be launched, if that's possible, this returns whether the clip's quantisation or the global quantisation should be used. | |
| LaunchQuantisation * | getLaunchQuantisation () override |
| Some clip types can be launched, if that's possible, this returns a quantisation that can be used for this clip. | |
| FollowActions * | getFollowActions () override |
| Some clip types can be launched, if that's possible, this can be used to determine the action to perform after a clip has played. | |
| bool | addClipPlugin (const Plugin::Ptr &, SelectionManager &) override |
| Adds a plugin to the clip. | |
| Plugin::Array | getAllPlugins () override |
| Returns all the plugins on the clip. | |
| void | sendMirrorUpdateToAllPlugins (Plugin &) const override |
| Sends an update to all plugins mirroing the one passed in. | |
| PluginList * | getPluginList () override |
| Returns the PluginList for this clip if it has one. | |
Public Member Functions inherited from tracktion::engine::Clip | |
| Clip (const juce::ValueTree &, ClipOwner &, EditItemID, Type) | |
| Creates a clip of a given type from a ValueTree state. | |
| ~Clip () override | |
| Destructor. | |
| virtual void | sourceMediaChanged () |
| Called when the source media file reference (attribute "source") has changed - i.e. | |
| virtual juce::String | getName () const override |
| Returns the name of the clip. | |
| void | setName (const juce::String &newName) |
| Sets a new name for a clip. | |
| virtual bool | isMidi () const =0 |
| Returns true if this is a MidiClip. | |
| virtual bool | usesSourceFile () const |
| True if it references a source file - i.e. | |
| SourceFileReference & | getSourceFileReference () |
| Returns the SourceFileReference of the Clip. | |
| juce::File | getCurrentSourceFile () const |
| Returns the current source file, this is different to the SourceFileReference as it could be a temporary comp file, clipFX, reverse render etc. | |
| juce::Array< ReferencedItem > | getReferencedItems () override |
| Returns an array of any ReferencedItem[s] e.g. | |
| void | reassignReferencedItem (const ReferencedItem &, ProjectItemID, double) override |
| Should be implemented to change the underlying source to a new ProjectItemID. | |
| ClipPosition | getPosition () const override |
| Returns the ClipPosition on the parent Track. | |
| BeatPosition | getContentBeatAtTime (TimePosition) const |
| Returns the beat number (with offset) at the given time. | |
| TimePosition | getTimeOfContentBeat (BeatPosition) const |
| Returns time of a beat number. | |
| virtual juce::Array< TimePosition > | getInterestingTimes () |
| Returns times for snapping to, relative to the Edit. | |
| TimePosition | getSpottingPoint () const |
| Returns the first marked time in the source file which can be used for syncronising newly added clips. | |
| TimeRange | getLoopRange () const |
| Returns the loop range in seconds. | |
| BeatRange | getLoopRangeBeats () const |
| Returns the loop range in beats. | |
| virtual void | setSyncType (SyncType sync) |
| Sets the sync type for the clip. | |
| SyncType | getSyncType () const |
| Returns the sync type clip is using. | |
| void | setPosition (ClipPosition newPosition) |
| Sets the position of the clip. | |
| void | setStart (TimePosition newStart, bool preserveSync, bool keepLength) |
| Sets the start time of the clip. | |
| void | setLength (TimeDuration newLength, bool preserveSync) |
| Sets the length of the clip. | |
| void | setEnd (TimePosition newEnd, bool preserveSync) |
| Sets the end of the clip. | |
| void | setOffset (TimeDuration newOffset) |
| Sets the offset of the clip, i.e. | |
| void | trimAwayOverlap (TimeRange editRangeToTrim) |
| Trims away any part of the clip that overlaps this region. | |
| void | removeFromParent () |
| Removes this clip from the parent track or container clip. | |
| bool | moveTo (ClipOwner &) |
| Moves the clip to a new parent (if possible). | |
| double | getSpeedRatio () const noexcept |
| Returns the speed ratio i.e. | |
| virtual void | rescale (TimePosition pivotTimeInEdit, double factor) |
| stretches and scales this clip relative to a fixed point in the edit. | |
| bool | isGrouped () const override |
| Returns true if the clip is part of a group. | |
| TrackItem * | getGroupParent () const override |
| Returns the parent TrackItem if part of a group. | |
| void | setGroup (EditItemID newGroupID) |
| Sets the clip to be part of a group. | |
| EditItemID | getGroupID () const noexcept |
| Returns the ID of the group. | |
| CollectionClip * | getGroupClip () const |
| Returns this as a CollectionClip if it is one. | |
| bool | isLinked () const |
| Returns true if this clip is linked with any others. | |
| void | setLinkGroupID (juce::String newLinkID) |
| Sets the link ID to link this clip with others. | |
| juce::String | getLinkGroupID () const |
| Returns the link ID of this clip. | |
| ClipOwner * | getParent () const |
| Returns the parent ClipOwner this clip is on. | |
| ClipTrack * | getClipTrack () const |
| Returns the parent ClipTrack this clip is on (if any). | |
| Track * | getTrack () const override |
| Returns the parent Track this clip is on (if any). | |
| ClipSlot * | getClipSlot () const |
| Returns the parent ClipSlot this clip is on (if any). | |
| virtual juce::Colour | getColour () const |
| Returns the colour property of this clip. | |
| void | setColour (juce::Colour col) |
| Sets the colour property of this clip. | |
| virtual void | removePlugin (const Plugin::Ptr &) |
| Removes the given plugin from the clip if the clip supports plugins. | |
| virtual void | clearTakes () |
| Clears any takes this clip has. | |
| virtual bool | hasAnyTakes () const |
| Returns true if this clip has any takes. | |
| virtual juce::StringArray | getTakeDescriptions () const |
| Returns the descriptions of any takes. | |
| virtual void | setCurrentTake (int) |
| Sets a given take index to be the current take. | |
| virtual int | getCurrentTake () const |
| Returns the current take index. | |
| virtual int | getNumTakes (bool) |
| Returns the total number of takes. | |
| virtual bool | isCurrentTakeComp () |
| Returns true if the current take is a comp. | |
| virtual void | setShowingTakes (bool shouldShow) |
| Sets whether the clip should be showing takes. | |
| virtual bool | isShowingTakes () const |
| Returns true if the clip is showing takes. | |
| virtual Clip::Array | unpackTakes (bool) |
| Attempts to unpack the takes to new clips. | |
| void | updateLinkedClips () |
| Triggers a call to cloneFrom for all clips with the same linkID. | |
| void | addListener (Listener *) |
| Adds a Listener. | |
| void | removeListener (Listener *) |
| Removes a Listener. | |
| juce::ListenerList< Listener > & | getListeners () |
| Returns the listener list so Nodes can manually call them. | |
| void | changed () override |
| This should be called to send a change notification to any SelectableListeners that are registered with this object. | |
| juce::UndoManager * | getUndoManager () const |
| Returns the UndoManager. | |
Public Member Functions inherited from tracktion::engine::TrackItem | |
| TrackItem (Edit &, EditItemID, Type) | |
| Creates a TrackItem with an ID and type. | |
| ~TrackItem () | |
| Destructor. | |
| TimeRange | getEditTimeRange () const |
| Returns the time range of this item. | |
| BeatRange | getEditBeatRange () const |
| Returns the beat range of this item. | |
| BeatPosition | getStartBeat () const |
| Returns the start beat in the Edit of this item. | |
| BeatPosition | getContentStartBeat () const |
| Returns the start beat of the content in the Edit of this item. | |
| BeatPosition | getEndBeat () const |
| Returns the end beat in the Edit of this item. | |
| BeatDuration | getLengthInBeats () const |
| Returns the duration in beats the of this item. | |
| TimePosition | getTimeOfRelativeBeat (BeatDuration) const |
| Returns an Edit time point for a given number of beats from the start of this item. | |
| BeatPosition | getBeatOfRelativeTime (TimeDuration) const |
| Returns an Edit beat point for a given number of seconds from the start of this item. | |
| BeatDuration | getOffsetInBeats () const |
| Returns an the offset of this item in beats. | |
| EditItemID | getTrackID () const |
| Returns the ID of the Track this item lives on. | |
Public Member Functions inherited from tracktion::engine::EditItem | |
| EditItem (EditItemID, Edit &) | |
Public Member Functions inherited from tracktion::engine::Selectable | |
| virtual juce::String | getSelectableDescription ()=0 |
| Subclasses must return a description of what they are. | |
| virtual void | selectionStatusChanged (bool isNowSelected) |
| Can be overridden to tell this object that it has just been selected or deselected. | |
| 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::RenderManager::Job::Listener | |
| virtual void | jobStarted (RenderManager::Job &) |
Static Public Member Functions | |
| static juce::StringArray | getRootNoteChoices (Engine &) |
| Returns an array of the root note choices e.g. | |
Static Public Member Functions inherited from tracktion::engine::Clip | |
| static bool | isClipState (const juce::ValueTree &) |
| Checks whether a ValueTree is some kind of clip state. | |
| static bool | isClipState (const juce::Identifier &) |
| Checks whether a ValueTree type is some kind of clip state. | |
| static Ptr | createClipForState (const juce::ValueTree &, ClipOwner &targetParent) |
| Creates a clip for a given ValueTree representation. | |
Static Public Member Functions inherited from tracktion::engine::TrackItem | |
| static const char * | typeToString (Type) |
| Returns the string version of a TrackItem::Type. | |
| static juce::Identifier | clipTypeToXMLType (Type) |
| Returns an Identifier version of a TrackItem::Type. | |
| static TrackItem::Type | xmlTagToType (juce::StringRef) |
| Returns the TrackItem::Type of a type string. | |
| static TrackItem::Type | stringToType (const juce::String &) |
| Returns the TrackItem::Type of a type string. | |
| static juce::String | getSuggestedNameForNewItem (Type) |
| Returns a text string for a new clip of the given type. | |
| template<typename ArrayType > | |
| static void | sortByTime (ArrayType &items) |
| Helper function to sort an array of TrackItem[s] by their start time. | |
| template<typename ArrayType > | |
| static void | stableSortByTime (ArrayType &items) |
| Helper function to sort an array of TrackItem[s] by their start time without changing the order of items at the same time. | |
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. | |
Static Public Member Functions inherited from tracktion::engine::Exportable | |
| static juce::Array< Exportable * > | addAllExportables (Edit &) |
| Returns all the Exportables contained in an Edit. | |
Public Attributes | |
| juce::ReferenceCountedObjectPtr< MelodyneFileReader > | melodyneProxy |
| The MelodyneFileReader proxy if this clip is using Melodyne. | |
| juce::CachedValue< TimeStretcher::ElastiqueProOptions > | elastiqueProOptions |
| The ElastiqueProOptions for fine tuning Elastique (if available). | |
Public Attributes inherited from tracktion::engine::Clip | |
| juce::CachedValue< FollowActionDurationType > | followActionDurationType |
| The type of duration to use for when to trigger the follow action. | |
| juce::CachedValue< BeatDuration > | followActionBeats |
| Determines the time for which a launched clip will play before a follow action is taken. | |
| juce::CachedValue< double > | followActionNumLoops |
| Determines the number of loops for which a launched clip will play before a follow action is taken. | |
| juce::ValueTree | state |
| The ValueTree of the Clip state. | |
| juce::CachedValue< juce::Colour > | colour |
| The colour property. | |
| juce::CachedValue< bool > | disabled |
| Whether the Clip is disabled or not. | |
Public Attributes inherited from tracktion::engine::TrackItem | |
| const Type | type |
| The type of this item. | |
Public Attributes inherited from tracktion::engine::EditItem | |
| Edit & | edit |
| const EditItemID | itemID |
| Every EditItem has an ID which is unique within the edit. | |
Public Attributes inherited from tracktion::engine::Selectable | |
| WeakRef::Master | masterReference |
Friends | |
| class | WaveCompManager |
Base class for Clips that produce some kind of audio e.g.
WaveAudioClip or EditClip. This class contains the common functionality such as gains, fades, plugins etc.
If your source if dynamically generated override needsRender to return true. This will then trigger the rest of the render callbacks which should be used to generate the source and fill in any update messages etc.
If your source is static override getAudioFile to return the source file. Note that this may be changed by the UI so it is a good idea to also overrride sourceMediaChanged and getSourceLength to update properties accordingly when the source ProjectItemID is re-assigned.
Either way you must override getHash which should return a hash of the current source e.g. an AudioFile hash or hash describing the current render set-up of an Edit.
Definition at line 31 of file tracktion_AudioClipBase.h.
Definition at line 43 of file tracktion_AudioClipBase.h.
Defines the auto pitch mode.
| Enumerator | |
|---|---|
| pitchTrack | Clip tracks the Edit's PitchSequence. |
| chordTrackMono | Clip tracks the chord track with a monophonic pitch change. |
| chordTrackPoly | Clip tracks the pitch track with a polyphonic pitch change. |
Definition at line 305 of file tracktion_AudioClipBase.h.
|
strong |
Defines a prevous/next direction.
Definition at line 510 of file tracktion_AudioClipBase.h.
Describes the fade behaviour.
| Enumerator | |
|---|---|
| gainFade | Fade is a volume/gain ramp. |
| speedRamp | Fade is a change of playback speed for tape start/stop effects. |
Definition at line 212 of file tracktion_AudioClipBase.h.
| tracktion::engine::AudioClipBase::AudioClipBase | ( | const juce::ValueTree & | v, |
| EditItemID | id, | ||
| Type | t, | ||
| ClipOwner & | targetParent | ||
| ) |
Creates a basic AudioClip.
Definition at line 200 of file tracktion_AudioClipBase.cpp.
|
override |
Destructor.
Definition at line 277 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Adds a plugin to the clip.
Reimplemented from tracktion::engine::Clip.
Definition at line 1586 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::addEffect | ( | const juce::ValueTree & | effectsTree | ) |
Adds a ClipEffect to this clip.
Definition at line 1325 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::addMark | ( | TimePosition | relCursorPos | ) |
Definition at line 1369 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::applyEdgeFades | ( | ) |
Sets the fade in/out lengths to be 0.03s to avoid any clicks at the start/end of th clip.
Definition at line 759 of file tracktion_AudioClipBase.cpp.
| LoopInfo tracktion::engine::AudioClipBase::autoDetectBeatMarkers | ( | const LoopInfo & | current, |
| bool | autoBeat, | ||
| float | sensitivity | ||
| ) | const |
Scans the current source file for any beats and adds them to the LoopInfo returned.
| current | A LoopInfo to initialise the result from |
| autoBeat | Whether to auto detect the beats from the source file |
| sensitivity | The sensitivity to use 0-1 [[ blocks ]] |
Definition at line 1194 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Returns true if this clip's looping is based on beats or false if absolute time.
Reimplemented from tracktion::engine::Clip.
Definition at line 249 of file tracktion_AudioClipBase.h.
| void tracktion::engine::AudioClipBase::beginRenderingNewProxyIfNeeded | ( | ) |
Triggers creation of a new proxy file if one is required.
Definition at line 2224 of file tracktion_AudioClipBase.cpp.
| juce::String tracktion::engine::AudioClipBase::canAddClipPlugin | ( | const Plugin::Ptr & | p | ) | const |
Returns an empty string if this plugin can be added, otherwise an error message due to the clip plugin being an incorrect type (e.g.
MIDI) or the list is full.
Definition at line 1572 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Tests whether this clip can go on the given parent.
Implements tracktion::engine::Clip.
Definition at line 391 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::cancelCurrentRender | ( | ) |
If a render is in progress, this will cancel it.
Definition at line 2272 of file tracktion_AudioClipBase.cpp.
|
virtual |
Returns true if this clip can have ClipEffects added to it.
Reimplemented in tracktion::engine::EditClip.
Definition at line 394 of file tracktion_AudioClipBase.h.
|
overridevirtual |
Returns true if this clip is capable of looping.
Reimplemented from tracktion::engine::Clip.
Definition at line 936 of file tracktion_AudioClipBase.cpp.
| bool tracktion::engine::AudioClipBase::canSnapToOriginalBWavTime | ( | ) |
Returns true if source file has a bwav time reference metadata property.
Definition at line 1443 of file tracktion_AudioClipBase.cpp.
|
noexcept |
Retuns true if this clip can use a proxy file.
Definition at line 470 of file tracktion_AudioClipBase.h.
|
overridevirtual |
This should be called to send a change notification to any SelectableListeners that are registered with this object.
Reimplemented from tracktion::engine::Selectable.
Reimplemented in tracktion::engine::EditClip.
Definition at line 396 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::checkFadeLengthsForOverrun | ( | ) |
Trims the fade in out lengths to avoid any overlap between them.
Definition at line 677 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Clones the given clip to this clip.
Reimplemented from tracktion::engine::Clip.
Reimplemented in tracktion::engine::ContainerClip, tracktion::engine::EditClip, and tracktion::engine::WaveAudioClip.
Definition at line 306 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::copyFadeToAutomation | ( | bool | fadeIn, |
| bool | removeClipFade | ||
| ) |
Copies the fade in curve to a volume automation curve.
| fadeIn | If true, this copies the fade-in, if false, the fade-out |
| removeClipFade | If true, the fade in will be set to 0 |
Definition at line 767 of file tracktion_AudioClipBase.cpp.
|
protected |
Triggers a source or proxy render after a timeout.
Call this if something changes that may affect either the source or the proxy e.g. Edit clip tracks or tempo sequence.
Definition at line 2266 of file tracktion_AudioClipBase.cpp.
| std::unique_ptr< AudioClipBase::ProxyRenderingInfo > tracktion::engine::AudioClipBase::createProxyRenderingInfo | ( | ) |
Creates a ProxyRenderingInfo object to decribe the stretch segements of this clip.
Definition at line 2108 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::deleteMark | ( | TimePosition | relCursorPos | ) |
Definition at line 1411 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Disables all looping.
Reimplemented from tracktion::engine::Clip.
Definition at line 903 of file tracktion_AudioClipBase.cpp.
| bool tracktion::engine::AudioClipBase::effectsEnabled | ( | ) | const |
Returns true if ClipEffects are enabled.
Definition at line 403 of file tracktion_AudioClipBase.h.
| void tracktion::engine::AudioClipBase::enableEffects | ( | bool | enable, |
| bool | warn | ||
| ) |
Enables/disables ClipEffects for this clip.
| enable | Whether to turn on/off clip FX for this clip |
| warn | If true and clip FX are enabled, this will show a confirmation dialog to the user first |
Definition at line 1300 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Can be overridden to ensure any state (e.g.
clip plugins) is flushed to the ValueTree ready for saving.
Reimplemented from tracktion::engine::Clip.
Reimplemented in tracktion::engine::ContainerClip.
Definition at line 366 of file tracktion_AudioClipBase.cpp.
| juce::AudioChannelSet tracktion::engine::AudioClipBase::getActiveChannels | ( | ) | const |
Returns the layout of the active channels.
Definition at line 158 of file tracktion_AudioClipBase.h.
|
noexcept |
Returns the time-stretch mode that is in use.
Note that even if not time-stretch mode has been set e.g. for speed changes, if auto-pitch or auto-tempo is enabled, a time-stretch mode will have to be used and this returns it.
Definition at line 591 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Returns all the plugins on the clip.
Reimplemented from tracktion::engine::Clip.
Definition at line 1597 of file tracktion_AudioClipBase.cpp.
|
virtual |
Returns the file used to play back the source and will get proxied etc.
Reimplemented in tracktion::engine::EditClip.
Definition at line 59 of file tracktion_AudioClipBase.h.
| const AudioSegmentList & tracktion::engine::AudioClipBase::getAudioSegmentList | ( | ) |
Returns an AudioSegmentList describing this file if it is using auto-tempo.
This can be useful for drawing waveforms. [[ message_thread ]]
Definition at line 1049 of file tracktion_AudioClipBase.cpp.
|
noexcept |
Returns whether auto-crossfade is enabled.
Definition at line 193 of file tracktion_AudioClipBase.h.
| bool tracktion::engine::AudioClipBase::getAutoDetectBeats | ( | ) | const |
Returns true if auto-detect of beats is enabled.
Definition at line 274 of file tracktion_AudioClipBase.h.
| bool tracktion::engine::AudioClipBase::getAutoPitch | ( | ) | const |
Returns true if auto-pitch has been set.
Definition at line 326 of file tracktion_AudioClipBase.h.
| AutoPitchMode tracktion::engine::AudioClipBase::getAutoPitchMode | ( | ) |
Returns the AutoPitchMode in use.
Definition at line 332 of file tracktion_AudioClipBase.h.
| bool tracktion::engine::AudioClipBase::getAutoTempo | ( | ) | const |
Returns true if auto-tempo has been set.
Definition at line 318 of file tracktion_AudioClipBase.h.
| float tracktion::engine::AudioClipBase::getBeatSensitivity | ( | ) | const |
Returns the beat sensitivity.
Definition at line 281 of file tracktion_AudioClipBase.h.
|
noexcept |
Returns the ClipEffects for this clip if it has been enabled.
Definition at line 415 of file tracktion_AudioClipBase.h.
|
virtual |
Override this to return a custom message to display over the clip where the "file missing" text usually goes.
Reimplemented in tracktion::engine::EditClip.
Definition at line 118 of file tracktion_AudioClipBase.h.
|
overridevirtual |
Returns the default colour for this clip.
Implements tracktion::engine::Clip.
Definition at line 407 of file tracktion_AudioClipBase.cpp.
| bool tracktion::engine::AudioClipBase::getEffectsVisible | ( | ) | const |
Returns true if the effectsVisible flag is set for this clip.
Definition at line 412 of file tracktion_AudioClipBase.h.
| TimeDuration tracktion::engine::AudioClipBase::getFadeIn | ( | ) | const |
Returns the fade in duration in seconds.
Definition at line 539 of file tracktion_AudioClipBase.cpp.
| FadeBehaviour tracktion::engine::AudioClipBase::getFadeInBehaviour | ( | ) | const |
Returns the fade in behaviour.
Definition at line 221 of file tracktion_AudioClipBase.h.
| AudioFadeCurve::Type tracktion::engine::AudioClipBase::getFadeInType | ( | ) | const |
Returns the curve shape for the fade in to use.
Definition at line 180 of file tracktion_AudioClipBase.h.
| TimeDuration tracktion::engine::AudioClipBase::getFadeOut | ( | ) | const |
Returns the fade out duration in seconds.
Definition at line 554 of file tracktion_AudioClipBase.cpp.
| FadeBehaviour tracktion::engine::AudioClipBase::getFadeOutBehaviour | ( | ) | const |
Returns the fade out behaviour.
Definition at line 226 of file tracktion_AudioClipBase.h.
| AudioFadeCurve::Type tracktion::engine::AudioClipBase::getFadeOutType | ( | ) | const |
Returns the curve shape for the fade out to use.
Definition at line 185 of file tracktion_AudioClipBase.h.
|
overridevirtual |
Some clip types can be launched, if that's possible, this can be used to determine the action to perform after a clip has played.
Reimplemented from tracktion::engine::Clip.
Definition at line 1562 of file tracktion_AudioClipBase.cpp.
|
noexcept |
Returns the gain of the clip.
Definition at line 129 of file tracktion_AudioClipBase.h.
|
noexcept |
Returns the gain of the clip in dB.
Definition at line 127 of file tracktion_AudioClipBase.h.
|
pure virtual |
Must return a unique hash for this clip's source.
This should be the same until the clip changes as it is used to determine if the proxy needs regenerating.
Implemented in tracktion::engine::ContainerClip, tracktion::engine::EditClip, and tracktion::engine::WaveAudioClip.
|
noexcept |
Returns true if the clip's source material is reversed.
Definition at line 370 of file tracktion_AudioClipBase.h.
|
overridevirtual |
Some clip types can be launched, if that's possible, this returns a handle to trigger starting/stopping the clip.
Reimplemented from tracktion::engine::Clip.
Definition at line 1546 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Some clip types can be launched, if that's possible, this returns a quantisation that can be used for this clip.
N.B. This will always be the clip's LaunchQuantisation, to find out if you should use the Edit's LaunchQuantisation, check usesGlobalLaunchQuatisation first
Reimplemented from tracktion::engine::Clip.
Definition at line 1554 of file tracktion_AudioClipBase.cpp.
| LiveClipLevel tracktion::engine::AudioClipBase::getLiveClipLevel | ( | ) |
Returns a LiveClipLevel which can be used to read the gain, pan and mute statuses.
Definition at line 1651 of file tracktion_AudioClipBase.cpp.
| LoopInfo & tracktion::engine::AudioClipBase::getLoopInfo | ( | ) |
Returns the LoopInfo being used to describe this clip.
Definition at line 239 of file tracktion_AudioClipBase.h.
| const LoopInfo & tracktion::engine::AudioClipBase::getLoopInfo | ( | ) | const |
Returns the LoopInfo being used to describe this clip.
Definition at line 237 of file tracktion_AudioClipBase.h.
|
overridevirtual |
Returns the length of loop in seconds.
Reimplemented from tracktion::engine::Clip.
Definition at line 950 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Returns the length of loop in beats.
Reimplemented from tracktion::engine::Clip.
Definition at line 966 of file tracktion_AudioClipBase.cpp.
| TimeRange tracktion::engine::AudioClipBase::getLoopRange | ( | ) | const |
Returns the loop range in seconds.
Definition at line 925 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Returns the start time of the loop start point.
Reimplemented from tracktion::engine::Clip.
Definition at line 942 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Returns the beat position of the loop start point.
Reimplemented from tracktion::engine::Clip.
Definition at line 958 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Returns the maximum length for this clip.
This can change depending on the clips properties e.g. if the clip is timestretched then this will return a proportion of getSourceLength, if it is looped this will return infinite.
Reimplemented from tracktion::engine::Clip.
Definition at line 413 of file tracktion_AudioClipBase.cpp.
|
pure virtual |
Must return the file that the source ProjectItemID refers to.
Implemented in tracktion::engine::ContainerClip, tracktion::engine::EditClip, and tracktion::engine::WaveAudioClip.
| AudioClipBase * tracktion::engine::AudioClipBase::getOverlappingClip | ( | ClipDirection | direction | ) | const |
Returns the previous/next overlapping clip if one exists.
Definition at line 698 of file tracktion_AudioClipBase.cpp.
|
noexcept |
Returns the pan of the clip from -1 to 1.
Definition at line 136 of file tracktion_AudioClipBase.h.
|
overridevirtual |
Returns the PatternGenerator for this clip if it has one.
Reimplemented from tracktion::engine::Clip.
Definition at line 374 of file tracktion_AudioClipBase.cpp.
| float tracktion::engine::AudioClipBase::getPitchChange | ( | ) | const |
Returns the number of semitones to transpose the clip by.
Definition at line 361 of file tracktion_AudioClipBase.h.
| juce::StringArray tracktion::engine::AudioClipBase::getPitchChoices | ( | ) |
Returns an array describng what pitch each semitone change will be.
Definition at line 1267 of file tracktion_AudioClipBase.cpp.
| float tracktion::engine::AudioClipBase::getPitchRatio | ( | ) | const |
Returns the pitch change as a normalised ratio.
0 = no change, <0 = pitched down, >0 = pitched up.
Definition at line 364 of file tracktion_AudioClipBase.h.
| AudioFile tracktion::engine::AudioClipBase::getPlaybackFile | ( | ) |
Returns the current AudioFile being used by the Clip, either the original source or a proxy.
Definition at line 2166 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Returns the PluginList for this clip if it has one.
Reimplemented from tracktion::engine::Clip.
Definition at line 614 of file tracktion_AudioClipBase.h.
| AudioFile tracktion::engine::AudioClipBase::getProxyFileToCreate | ( | bool | renderTimestretched | ) |
Returns the AudioFile to create to play this clip back.
| renderTimestretched | If true, this should be a time-stretched version of the clip |
Definition at line 1899 of file tracktion_AudioClipBase.cpp.
| HashCode tracktion::engine::AudioClipBase::getProxyHash | ( | ) |
Returns a hash identifying the proxy settings.
Definition at line 2194 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Implements tracktion::engine::Exportable.
Definition at line 1462 of file tracktion_AudioClipBase.cpp.
|
virtual |
Subclasses should override this to return a RenderJob suitable for rendering its source file.
Note that because we can only render one source this should also check to see if the source should be reversed and do so accordingly. This will be called on the message thread so should complete quickly, if your source needs some time consuming setup (e.g. loading Edits) then make sure your render job does this in its render thread.
Reimplemented in tracktion::engine::EditClip, and tracktion::engine::WaveAudioClip.
Definition at line 103 of file tracktion_AudioClipBase.h.
|
virtual |
Override this to return a custom message to be displayed over waveforms during rendering.
This is called periodically once a render has started. Once you are done, this should return an empty string to let the AudioStripBase know to stop updating.
Reimplemented in tracktion::engine::EditClip, and tracktion::engine::WaveAudioClip.
Definition at line 115 of file tracktion_AudioClipBase.h.
| ResamplingQuality tracktion::engine::AudioClipBase::getResamplingQuality | ( | ) | const |
Returns the resampling quality to the be used.
Definition at line 1065 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Returns the mark points relative to the start of the clip, rescaled to the current speed.
Reimplemented from tracktion::engine::Clip.
Definition at line 1747 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::getRescaledMarkPoints | ( | juce::Array< TimePosition > & | rescaled, |
| juce::Array< int > & | orig | ||
| ) | const |
Definition at line 1755 of file tracktion_AudioClipBase.cpp.
|
static |
Returns an array of the root note choices e.g.
"C#" etc.
Definition at line 1256 of file tracktion_AudioClipBase.cpp.
|
pure virtual |
Must return the length in seconds of the source material e.g.
the length of the audio file or edit.
Implemented in tracktion::engine::ContainerClip, tracktion::engine::EditClip, and tracktion::engine::WaveAudioClip.
|
virtual |
Returns the ProjectItemID of the clip's takes.
Reimplemented in tracktion::engine::WaveAudioClip.
Definition at line 1539 of file tracktion_AudioClipBase.cpp.
|
noexcept |
Returns the time-stretch mode that has been set.
Definition at line 586 of file tracktion_AudioClipBase.cpp.
| int tracktion::engine::AudioClipBase::getTransposeSemiTones | ( | bool | includeAutoPitch | ) | const |
Returns the number of semitones this clip will be changed by.
N.B. this is used if auto-pitch is enabled.
| includeAutoPitch | If true, this will include the changes defined by auto-pitch. If false, this will only be the number explicitly set in setTranspose |
Definition at line 1178 of file tracktion_AudioClipBase.cpp.
| bool tracktion::engine::AudioClipBase::getWarpTime | ( | ) | const |
Returns true if warp time is enabled.
Definition at line 340 of file tracktion_AudioClipBase.h.
| WarpTimeManager & tracktion::engine::AudioClipBase::getWarpTimeManager | ( | ) | const |
Returns the WarpTimeManager for this clip used to maipluate warp markers.
Definition at line 1165 of file tracktion_AudioClipBase.cpp.
|
virtual |
Returns the WaveInfo for a clip.
By default this just looks in the AudioSegmentList cache but subclasses can override this to return a custom WaveInfo if they don't reference source files..
Reimplemented in tracktion::engine::EditClip.
Definition at line 2182 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::hideMelodyneWindow | ( | ) |
Hides the Melodyne window if this clip is using Melodyne.
Definition at line 1100 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Initialises the Clip.
Called once automatically after construction.
Reimplemented from tracktion::engine::Clip.
Reimplemented in tracktion::engine::ContainerClip, tracktion::engine::EditClip, and tracktion::engine::WaveAudioClip.
Definition at line 286 of file tracktion_AudioClipBase.cpp.
| bool tracktion::engine::AudioClipBase::isLeftChannelActive | ( | ) | const |
Returns whether the left channel of the clip is enabled.
Definition at line 465 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Returns true if this clip is currently looping.
Reimplemented from tracktion::engine::Clip.
Definition at line 247 of file tracktion_AudioClipBase.h.
|
overridevirtual |
Returns true if the clip is muted.
Implements tracktion::engine::Clip.
Definition at line 141 of file tracktion_AudioClipBase.h.
| bool tracktion::engine::AudioClipBase::isRightChannelActive | ( | ) | const |
Returns whether the right channel of the clip is enabled.
Definition at line 492 of file tracktion_AudioClipBase.cpp.
|
virtual |
Should return true if the clip is referencing the file in any way.
Reimplemented in tracktion::engine::ContainerClip, tracktion::engine::WaveAudioClip, and tracktion::engine::EditClip.
Definition at line 1867 of file tracktion_AudioClipBase.cpp.
| bool tracktion::engine::AudioClipBase::isUsingMelodyne | ( | ) | const |
Returns true if this clip is using Melodyne.
Definition at line 1084 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::loadMelodyneState | ( | ) |
Definition at line 1089 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::markAsDirty | ( | ) |
Resets the dirty flag so that a new render will be attempted.
Call this whenever one of your clips properties that will change the source file change. This flag is used to avoid constantly re-rendering failed sources.
Definition at line 1657 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::melodyneConvertToMIDI | ( | ) |
If this clip is using Melodyne, this will create a new MIDI clip based on the Melodyne analysis.
Definition at line 1106 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::moveMarkTo | ( | TimePosition | relCursorPos | ) |
Definition at line 1379 of file tracktion_AudioClipBase.cpp.
|
virtual |
Subclasses should override this to return true if they need the rest of the render callbacks.
Reimplemented in tracktion::engine::EditClip, and tracktion::engine::WaveAudioClip.
Definition at line 95 of file tracktion_AudioClipBase.h.
| bool tracktion::engine::AudioClipBase::performTempoDetect | ( | ) |
Performs a tempo-detection task and if successful sets the clip's LoopInfo tempo to this.
Definition at line 1241 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Called when there are pitch or tempo changes made which might require clips to adjust timing information.
Reimplemented from tracktion::engine::Clip.
Reimplemented in tracktion::engine::ContainerClip.
Definition at line 1032 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Implements tracktion::engine::Exportable.
Definition at line 1519 of file tracktion_AudioClipBase.cpp.
|
virtual |
Callback to indicate that the render has completed.
If you override this, make sure to call the base class implementation first.
Reimplemented in tracktion::engine::EditClip, and tracktion::engine::WaveAudioClip.
Definition at line 1736 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::reverseLoopPoints | ( | ) |
Reverses the loop points to expose the same section of the source file but reversed.
Definition at line 602 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Sends an update to all plugins mirroing the one passed in.
Reimplemented from tracktion::engine::Clip.
Definition at line 1602 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::setAutoCrossfade | ( | bool | shouldAutoCrossfade | ) |
Enables/disables auto-crossfading.
When enabled, the fade in/out length will automatically be set to the length of any overlapping clip regions.
Definition at line 191 of file tracktion_AudioClipBase.h.
| void tracktion::engine::AudioClipBase::setAutoDetectBeats | ( | bool | b | ) |
Enables auto-detection of beats.
If this is true the LoopInfo will be set based on what beats were detected. This will aso updat eif the sensitivity is changed
Definition at line 1020 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::setAutoPitch | ( | bool | shouldUseAutoPitch | ) |
Enables/disables auto-pitch.
If enabled, this clip will adjust its playback pitch to stay in sync with the Edit's PitchSequence.
Definition at line 323 of file tracktion_AudioClipBase.h.
| void tracktion::engine::AudioClipBase::setAutoPitchMode | ( | AutoPitchMode | m | ) |
Sets the AutoPitchMode to use.
Definition at line 329 of file tracktion_AudioClipBase.h.
| void tracktion::engine::AudioClipBase::setAutoTempo | ( | bool | shouldUseAutoTempo | ) |
Enables/disables auto-tempo.
If enabled, this clip will adjust its playback speed to stay in sync with the Edit's TempoSequence.
Definition at line 315 of file tracktion_AudioClipBase.h.
| void tracktion::engine::AudioClipBase::setBeatSensitivity | ( | float | s | ) |
Sets the beat sensitivity, triggering a LoopInfo update if auto-detect is enabled.
Definition at line 1026 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::setEffectsVisible | ( | bool | b | ) |
Sets the effectsVisible flag for this clip.
Definition at line 409 of file tracktion_AudioClipBase.h.
| bool tracktion::engine::AudioClipBase::setFadeIn | ( | TimeDuration | length | ) |
Sets the fade in duration in seconds.
If the duration is longer than the clip or overlaps the fade out, this will reduce the fade out accordingly.
Definition at line 498 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::setFadeInBehaviour | ( | FadeBehaviour | newBehaviour | ) |
Sets the fade in behaviour.
Definition at line 219 of file tracktion_AudioClipBase.h.
| void tracktion::engine::AudioClipBase::setFadeInType | ( | AudioFadeCurve::Type | t | ) |
Sets the curve shape for the fade in to use.
Definition at line 569 of file tracktion_AudioClipBase.cpp.
| bool tracktion::engine::AudioClipBase::setFadeOut | ( | TimeDuration | length | ) |
Sets the fade out duration in seconds.
If the duration is longer than the clip or overlaps the fade in, this will reduce the fade in accordingly.
Definition at line 519 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::setFadeOutBehaviour | ( | FadeBehaviour | newBehaviour | ) |
Sets the fade out behaviour.
Definition at line 224 of file tracktion_AudioClipBase.h.
| void tracktion::engine::AudioClipBase::setFadeOutType | ( | AudioFadeCurve::Type | newType | ) |
Sets the curve shape for the fade out to use.
Definition at line 577 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::setGainDB | ( | float | dB | ) |
Sets the gain of the clip in dB.
Definition at line 431 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::setIsReversed | ( | bool | shouldBeReversed | ) |
Enables reversing of the clip's source material.
Definition at line 367 of file tracktion_AudioClipBase.h.
| void tracktion::engine::AudioClipBase::setLeftChannelActive | ( | bool | b | ) |
Enables the left channel of the clip.
Definition at line 443 of file tracktion_AudioClipBase.cpp.
|
pure virtual |
Override this to fill in the LoopInfo structure as best fits the source.
Implemented in tracktion::engine::ContainerClip, tracktion::engine::EditClip, and tracktion::engine::WaveAudioClip.
| void tracktion::engine::AudioClipBase::setLoopInfo | ( | const LoopInfo & | loopInfo_ | ) |
Sets a LoopInfo to describe this clip's tempo, time sig etc.
which is used when syncing to the TempoSequence and PitchSequence.
Definition at line 871 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Sets the loop range the clip should use in seconds.
Reimplemented from tracktion::engine::Clip.
Definition at line 974 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Sets the loop range the clip should use in beats.
Reimplemented from tracktion::engine::Clip.
Reimplemented in tracktion::engine::ContainerClip.
Definition at line 1005 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Mutes or unmutes the clip.
Reimplemented from tracktion::engine::Clip.
Definition at line 139 of file tracktion_AudioClipBase.h.
|
overridevirtual |
Sets the clip looping a number of times.
Reimplemented from tracktion::engine::Clip.
Definition at line 876 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::setPan | ( | float | pan | ) |
Sets the pan of the clip.
| pan | -1 = full left, 0 = centre, 1 = full right |
Definition at line 436 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Reimplemented from tracktion::engine::Clip.
Definition at line 384 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::setPitchChange | ( | float | semitones | ) |
Sets the number of semitones to transpose the clip by.
N.B. this is only used if auto-pitch is disabled.
Definition at line 358 of file tracktion_AudioClipBase.h.
| void tracktion::engine::AudioClipBase::setResamplingQuality | ( | ResamplingQuality | rq | ) |
Sets the resampling qulity to use.
This is only applicable if setUsesProxy has been set to false. If a proxy is used, Lagrange interpolation will be used. N.B. the higher the quality, the more higher the CPU usage during playback.
Definition at line 1060 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::setRightChannelActive | ( | bool | b | ) |
Enables the right channel of the clip.
Definition at line 470 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Sets a speed ratio i.e.
how quickly the clip plays back.
Reimplemented from tracktion::engine::Clip.
Definition at line 1071 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::setTimeStretchMode | ( | TimeStretcher::Mode | mode | ) |
Sets a time-stretch mode to use.
Definition at line 1157 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::setTranspose | ( | int | numSemitones | ) |
Sets the number of semitones to transpose the clip by.
Definition at line 346 of file tracktion_AudioClipBase.h.
| bool tracktion::engine::AudioClipBase::setupARA | ( | bool | dontPopupErrorMessages | ) |
This internal method is used solely to find out if createAudioNode() should return nullptr or not.
Though a bit spaghetti, the ARA node generation will be handled elsewhere, the parent AudioTrack, for the sake of live-play.
It's possible no ARA-compatible plugins were found,
or that ARA complained about something resulting
in failure to set it up accordingly.
Celemony's ARA is really flaky and touchy, so the latter
is most likely!
Definition at line 1608 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Some clip types can be launched, if that's possible, this sets whether the clip's quantisation or the global quantisation should be used.
Reimplemented from tracktion::engine::Clip.
Definition at line 598 of file tracktion_AudioClipBase.h.
|
noexcept |
Can be used to disable proxy file generation for this clip.
If disabled, the audio engine will time-stretch the file in real time which may use more CPU.
Definition at line 1878 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::setWarpTime | ( | bool | shouldUseWarpTime | ) |
Enables/disables warp time.
Warp Time enables segmented warping of the audio.
Definition at line 337 of file tracktion_AudioClipBase.h.
| void tracktion::engine::AudioClipBase::showMelodyneWindow | ( | ) |
Shows the Melodyne window if this clip is using Melodyne.
Definition at line 1094 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::snapToOriginalBWavTime | ( | ) |
Moves the clip to the bwav time reference metadata property time.
Definition at line 1448 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::updateAutoCrossfadesAsync | ( | bool | updateOverlapped | ) |
Triggers an update of the auto-crossfades.
N.B. you shouldn't normally need to call this, it's called by the AudioTrack when clips are moved.
| updateOverlapped | If true, this will also update any other clips that overlap this one. |
Definition at line 728 of file tracktion_AudioClipBase.cpp.
|
protected |
Definition at line 354 of file tracktion_AudioClipBase.cpp.
| void tracktion::engine::AudioClipBase::updateSourceFile | ( | ) |
Checks the current source file to see if it's up to date and then triggers a source render if needed.
This uses the needsRender and getHash methods to determine the source file to be used. Call this if something changes that will affect the render e.g. tracks in an EditClip.
Definition at line 1663 of file tracktion_AudioClipBase.cpp.
|
overridevirtual |
Some clip types can be launched, if that's possible, this returns whether the clip's quantisation or the global quantisation should be used.
Reimplemented from tracktion::engine::Clip.
Definition at line 600 of file tracktion_AudioClipBase.h.
| bool tracktion::engine::AudioClipBase::usesTimeStretchedProxy | ( | ) | const |
Retuns true if this clip use a proxy file due to timestretching.
This can be because auto-tempo, auto-pitch or a pitch change has been set.
Definition at line 1884 of file tracktion_AudioClipBase.cpp.
|
overrideprotectedvirtual |
Reimplemented from juce::ValueTree::Listener.
Definition at line 2427 of file tracktion_AudioClipBase.cpp.
|
overrideprotectedvirtual |
Reimplemented from juce::ValueTree::Listener.
Definition at line 2473 of file tracktion_AudioClipBase.cpp.
|
overrideprotectedvirtual |
Reimplemented from juce::ValueTree::Listener.
Definition at line 2450 of file tracktion_AudioClipBase.cpp.
|
overrideprotectedvirtual |
Reimplemented from juce::ValueTree::Listener.
Definition at line 2478 of file tracktion_AudioClipBase.cpp.
|
overrideprotectedvirtual |
Reimplemented from juce::ValueTree::Listener.
Definition at line 2332 of file tracktion_AudioClipBase.cpp.
|
friend |
Definition at line 618 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 651 of file tracktion_AudioClipBase.h.
|
mutableprotected |
Definition at line 649 of file tracktion_AudioClipBase.h.
|
mutableprotected |
Definition at line 647 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 627 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 643 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 625 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 625 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 643 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 644 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 643 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 641 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 622 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 648 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 643 of file tracktion_AudioClipBase.h.
| juce::CachedValue<TimeStretcher::ElastiqueProOptions> tracktion::engine::AudioClipBase::elastiqueProOptions |
The ElastiqueProOptions for fine tuning Elastique (if available).
Definition at line 553 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 624 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 628 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 626 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 624 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 628 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 626 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 643 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 659 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 656 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 621 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 639 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 632 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 634 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 631 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 633 of file tracktion_AudioClipBase.h.
| juce::ReferenceCountedObjectPtr<MelodyneFileReader> tracktion::engine::AudioClipBase::melodyneProxy |
The MelodyneFileReader proxy if this clip is using Melodyne.
Definition at line 517 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 638 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 654 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 636 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 658 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 629 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 642 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 637 of file tracktion_AudioClipBase.h.
|
protected |
Definition at line 643 of file tracktion_AudioClipBase.h.
|
mutableprotected |
Definition at line 646 of file tracktion_AudioClipBase.h.