{! @file AudioUnitParameters.h @framework AudioToolbox.framework @copyright (c) 2000-2015 Apple, Inc. All rights reserved. @abstract Constants for the parameters of Apple audio units. } { Pascal Translation: Gorazd Krosl , October 2009 } { Pascal Translation Update: Jonas Maebe , October 2012 } { Pascal Translation Update: Jonas Maebe , July 2019 } { Modified for use with Free Pascal Version 308 Please report any bugs to } {$ifc not defined MACOSALLINCLUDE or not MACOSALLINCLUDE} {$mode macpas} {$modeswitch cblocks} {$packenum 1} {$macro on} {$inline on} {$calling mwpascal} {$IFNDEF FPC_DOTTEDUNITS} unit AudioUnitParameters; {$ENDIF FPC_DOTTEDUNITS} interface {$setc UNIVERSAL_INTERFACES_VERSION := $0400} {$setc GAP_INTERFACES_VERSION := $0308} {$ifc not defined USE_CFSTR_CONSTANT_MACROS} {$setc USE_CFSTR_CONSTANT_MACROS := TRUE} {$endc} {$ifc defined CPUPOWERPC and defined CPUI386} {$error Conflicting initial definitions for CPUPOWERPC and CPUI386} {$endc} {$ifc defined FPC_BIG_ENDIAN and defined FPC_LITTLE_ENDIAN} {$error Conflicting initial definitions for FPC_BIG_ENDIAN and FPC_LITTLE_ENDIAN} {$endc} {$ifc not defined __ppc__ and defined CPUPOWERPC32} {$setc __ppc__ := 1} {$elsec} {$setc __ppc__ := 0} {$endc} {$ifc not defined __ppc64__ and defined CPUPOWERPC64} {$setc __ppc64__ := 1} {$elsec} {$setc __ppc64__ := 0} {$endc} {$ifc not defined __i386__ and defined CPUI386} {$setc __i386__ := 1} {$elsec} {$setc __i386__ := 0} {$endc} {$ifc not defined __x86_64__ and defined CPUX86_64} {$setc __x86_64__ := 1} {$elsec} {$setc __x86_64__ := 0} {$endc} {$ifc not defined __arm__ and defined CPUARM} {$setc __arm__ := 1} {$elsec} {$setc __arm__ := 0} {$endc} {$ifc not defined __arm64__ and defined CPUAARCH64} {$setc __arm64__ := 1} {$elsec} {$setc __arm64__ := 0} {$endc} {$ifc defined cpu64} {$setc __LP64__ := 1} {$elsec} {$setc __LP64__ := 0} {$endc} {$ifc defined __ppc__ and __ppc__ and defined __i386__ and __i386__} {$error Conflicting definitions for __ppc__ and __i386__} {$endc} {$ifc defined __ppc__ and __ppc__} {$setc TARGET_CPU_PPC := TRUE} {$setc TARGET_CPU_PPC64 := FALSE} {$setc TARGET_CPU_X86 := FALSE} {$setc TARGET_CPU_X86_64 := FALSE} {$setc TARGET_CPU_ARM := FALSE} {$setc TARGET_CPU_ARM64 := FALSE} {$setc TARGET_OS_MAC := TRUE} {$setc TARGET_OS_IPHONE := FALSE} {$setc TARGET_IPHONE_SIMULATOR := FALSE} {$setc TARGET_OS_EMBEDDED := FALSE} {$elifc defined __ppc64__ and __ppc64__} {$setc TARGET_CPU_PPC := FALSE} {$setc TARGET_CPU_PPC64 := TRUE} {$setc TARGET_CPU_X86 := FALSE} {$setc TARGET_CPU_X86_64 := FALSE} {$setc TARGET_CPU_ARM := FALSE} {$setc TARGET_CPU_ARM64 := FALSE} {$setc TARGET_OS_MAC := TRUE} {$setc TARGET_OS_IPHONE := FALSE} {$setc TARGET_IPHONE_SIMULATOR := FALSE} {$setc TARGET_OS_EMBEDDED := FALSE} {$elifc defined __i386__ and __i386__} {$setc TARGET_CPU_PPC := FALSE} {$setc TARGET_CPU_PPC64 := FALSE} {$setc TARGET_CPU_X86 := TRUE} {$setc TARGET_CPU_X86_64 := FALSE} {$setc TARGET_CPU_ARM := FALSE} {$setc TARGET_CPU_ARM64 := FALSE} {$ifc defined iphonesim} {$setc TARGET_OS_MAC := FALSE} {$setc TARGET_OS_IPHONE := TRUE} {$setc TARGET_IPHONE_SIMULATOR := TRUE} {$elsec} {$setc TARGET_OS_MAC := TRUE} {$setc TARGET_OS_IPHONE := FALSE} {$setc TARGET_IPHONE_SIMULATOR := FALSE} {$endc} {$setc TARGET_OS_EMBEDDED := FALSE} {$elifc defined __x86_64__ and __x86_64__} {$setc TARGET_CPU_PPC := FALSE} {$setc TARGET_CPU_PPC64 := FALSE} {$setc TARGET_CPU_X86 := FALSE} {$setc TARGET_CPU_X86_64 := TRUE} {$setc TARGET_CPU_ARM := FALSE} {$setc TARGET_CPU_ARM64 := FALSE} {$ifc defined iphonesim} {$setc TARGET_OS_MAC := FALSE} {$setc TARGET_OS_IPHONE := TRUE} {$setc TARGET_IPHONE_SIMULATOR := TRUE} {$elsec} {$setc TARGET_OS_MAC := TRUE} {$setc TARGET_OS_IPHONE := FALSE} {$setc TARGET_IPHONE_SIMULATOR := FALSE} {$endc} {$setc TARGET_OS_EMBEDDED := FALSE} {$elifc defined __arm__ and __arm__} {$setc TARGET_CPU_PPC := FALSE} {$setc TARGET_CPU_PPC64 := FALSE} {$setc TARGET_CPU_X86 := FALSE} {$setc TARGET_CPU_X86_64 := FALSE} {$setc TARGET_CPU_ARM := TRUE} {$setc TARGET_CPU_ARM64 := FALSE} {$setc TARGET_OS_MAC := FALSE} {$setc TARGET_OS_IPHONE := TRUE} {$setc TARGET_IPHONE_SIMULATOR := FALSE} {$setc TARGET_OS_EMBEDDED := TRUE} {$elifc defined __arm64__ and __arm64__} {$setc TARGET_CPU_PPC := FALSE} {$setc TARGET_CPU_PPC64 := FALSE} {$setc TARGET_CPU_X86 := FALSE} {$setc TARGET_CPU_X86_64 := FALSE} {$setc TARGET_CPU_ARM := FALSE} {$setc TARGET_CPU_ARM64 := TRUE} {$ifc defined ios} {$setc TARGET_OS_MAC := FALSE} {$setc TARGET_OS_IPHONE := TRUE} {$setc TARGET_OS_EMBEDDED := TRUE} {$elsec} {$setc TARGET_OS_MAC := TRUE} {$setc TARGET_OS_IPHONE := FALSE} {$setc TARGET_OS_EMBEDDED := FALSE} {$endc} {$setc TARGET_IPHONE_SIMULATOR := FALSE} {$elsec} {$error __ppc__ nor __ppc64__ nor __i386__ nor __x86_64__ nor __arm__ nor __arm64__ is defined.} {$endc} {$ifc defined __LP64__ and __LP64__ } {$setc TARGET_CPU_64 := TRUE} {$elsec} {$setc TARGET_CPU_64 := FALSE} {$endc} {$ifc defined FPC_BIG_ENDIAN} {$setc TARGET_RT_BIG_ENDIAN := TRUE} {$setc TARGET_RT_LITTLE_ENDIAN := FALSE} {$elifc defined FPC_LITTLE_ENDIAN} {$setc TARGET_RT_BIG_ENDIAN := FALSE} {$setc TARGET_RT_LITTLE_ENDIAN := TRUE} {$elsec} {$error Neither FPC_BIG_ENDIAN nor FPC_LITTLE_ENDIAN are defined.} {$endc} {$setc ACCESSOR_CALLS_ARE_FUNCTIONS := TRUE} {$setc CALL_NOT_IN_CARBON := FALSE} {$setc OLDROUTINENAMES := FALSE} {$setc OPAQUE_TOOLBOX_STRUCTS := TRUE} {$setc OPAQUE_UPP_TYPES := TRUE} {$setc OTCARBONAPPLICATION := TRUE} {$setc OTKERNEL := FALSE} {$setc PM_USE_SESSION_APIS := TRUE} {$setc TARGET_API_MAC_CARBON := TRUE} {$setc TARGET_API_MAC_OS8 := FALSE} {$setc TARGET_API_MAC_OSX := TRUE} {$setc TARGET_CARBON := TRUE} {$setc TARGET_CPU_68K := FALSE} {$setc TARGET_CPU_MIPS := FALSE} {$setc TARGET_CPU_SPARC := FALSE} {$setc TARGET_OS_UNIX := FALSE} {$setc TARGET_OS_WIN32 := FALSE} {$setc TARGET_RT_MAC_68881 := FALSE} {$setc TARGET_RT_MAC_CFM := FALSE} {$setc TARGET_RT_MAC_MACHO := TRUE} {$setc TYPED_FUNCTION_POINTERS := TRUE} {$setc TYPE_BOOL := FALSE} {$setc TYPE_EXTENDED := FALSE} {$setc TYPE_LONGLONG := TRUE} {$IFDEF FPC_DOTTEDUNITS} uses MacOsApi.MacTypes; {$ELSE FPC_DOTTEDUNITS} uses MacTypes; {$ENDIF FPC_DOTTEDUNITS} {$endc} {not MACOSALLINCLUDE} {$ALIGN POWER} //#pragma mark General Declarations { ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ The following specifies the equivalent parameterID's for the Group scope for standard MIDI Controllers. This list is not exhaustive. It represents the parameters, and their corresponding MIDI messages, that should be supported in Group scope by MIDI capable AUs. Group scope parameter IDs from 0 < 512 are reserved for mapping MIDI controllers. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ } const kAUGroupParameterID_Volume = 7; // value 0 < 128 kAUGroupParameterID_Sustain = 64; // value 0-63 (off), 64-127 (on) kAUGroupParameterID_Sostenuto = 66; // value 0-63 (off), 64-127 (on) kAUGroupParameterID_AllNotesOff = 123; // value ignored kAUGroupParameterID_ModWheel = 1; // value 0 < 128 kAUGroupParameterID_PitchBend = $E0; // value -8192 - 8191 kAUGroupParameterID_AllSoundOff = 120; // value ignored kAUGroupParameterID_ResetAllControllers = 121; // value ignored kAUGroupParameterID_Pan = 10; // value 0 < 128 kAUGroupParameterID_Foot = 4; // value 0 < 128 kAUGroupParameterID_ChannelPressure = $D0; // value 0 < 128 kAUGroupParameterID_KeyPressure = $A0; // values 0 < 128 kAUGroupParameterID_Expression = 11; // value 0 < 128 kAUGroupParameterID_DataEntry = 6; // value 0 < 128 kAUGroupParameterID_Volume_LSB = kAUGroupParameterID_Volume + 32; // value 0 < 128 kAUGroupParameterID_ModWheel_LSB = kAUGroupParameterID_ModWheel + 32; // value 0 < 128 kAUGroupParameterID_Pan_LSB = kAUGroupParameterID_Pan + 32; // value 0 < 128 kAUGroupParameterID_Foot_LSB = kAUGroupParameterID_Foot + 32; // value 0 < 128 kAUGroupParameterID_Expression_LSB = kAUGroupParameterID_Expression + 32; // value 0 < 128 kAUGroupParameterID_DataEntry_LSB = kAUGroupParameterID_DataEntry + 32; // value 0 < 128 kAUGroupParameterID_KeyPressure_FirstKey = 256; // value 0 < 128 kAUGroupParameterID_KeyPressure_LastKey = 383; // value 0 < 128 { ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ Supporting the kAUGroupParameterID_KeyPressure parameter indicates to hosts that your audio unit supports polyphonic "aftertouch" key pressure. Each of the 128 MIDI key numbers can have its own value for polyphonic aftertouch. To respond to aftertouch for a particular key, your audio unit needs to support an additional parameter specifically for that key. The aftertouch parameter ID for a given MIDI key is equal to the MIDI key number plus 256. For example, the aftertouch parameter ID for MIDI key #60 (middle C) is: 60 + kAUGroupParameterID_KeyPressure_FirstKey = 316 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ } { ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ The following sections specify the parameter IDs for the audio units included in Mac OS X. Host applications can use these IDs to directly address these parameters without first discovering them through the AUParameterInfo mechanism (see the AudioUnitProperties.h header file) Each parameter is preceeded by a comment that indicates scope, unit of measurement, minimum value, maximum value, and default value. See the AudioUnitProperties.h header file for additional information that a parameter may report When displaying to the user information about a parameter, a host application should always get the parameter information from the audio unit itself. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ } // Parameters for all Panner AudioUnits const // Global, Linear, 0->1, 1 kPannerParam_Gain = 0; // Global, Degrees, -180->180, 0 kPannerParam_Azimuth = 1; // Global, Degrees, -90->90, 0 kPannerParam_Elevation = 2; // Global, Linear, 0->1, 1 kPannerParam_Distance = 3; // 0 .. 1 // Global, Meters, 0.01->1000, 1 kPannerParam_CoordScale = 4; // Global, Meters, 0.01->1000, 1 kPannerParam_RefDistance = 5; //#pragma mark Apple Specific // Parameters for the AUSpatialMixer unit const // Input, Degrees, -180->180, 0 kSpatialMixerParam_Azimuth = 0; // Input, Degrees, -90->90, 0 kSpatialMixerParam_Elevation = 1; // Input, Metres, 0->10000, 0 kSpatialMixerParam_Distance = 2; // Input/Output, dB, -120->20, 0 kSpatialMixerParam_Gain = 3; // Input, rate scaler 0.5 -> 2.0 kSpatialMixerParam_PlaybackRate = 4; // bus enable : 0.0 or 1.0 kSpatialMixerParam_Enable = 5; // Minimum input gain constraint : 0.0 -> 1.0 kSpatialMixerParam_MinGain = 6; // Maximum input gain constraint : 0.0 -> 1.0 kSpatialMixerParam_MaxGain = 7; // Input, Dry/Wet equal-power blend, % 0.0 -> 100.0 kSpatialMixerParam_ReverbBlend = 8; // Global, dB, -40.0 -> +40.0 kSpatialMixerParam_GlobalReverbGain = 9; // Input, Lowpass filter attenuation at 5KHz : decibels -100.0dB -> 0.0dB // smaller values make both direct and reverb sound more muffled; a value of 0.0 indicates no filtering // Occlusion is a filter applied to the sound prior to the reverb send kSpatialMixerParam_OcclusionAttenuation = 10; // Input, Lowpass filter attenuation at 5KHz : decibels -100.0dB -> 0.0dB // smaller values make direct sound more muffled; a value of 0.0 indicates no filtering // Obstruction is a filter applied to the "direct" part of the sound (so is post reverb send) kSpatialMixerParam_ObstructionAttenuation = 11; // Reverb parameters applicable to AUSpatialMixer const // Global, Hertz, 10.0 -> 20000.0, 800.0 kReverbParam_FilterFrequency = 14; // Global, Octaves, 0.05 -> 4.0, 3.0 kReverbParam_FilterBandwidth = 15; // Global, Decibels, -18.0 -> +18.0, 0.0 kReverbParam_FilterGain = 16; // Global, Indexed, 0->kNumAUNBandEQFilterTypes-1, 0 kReverbParam_FilterType = 17; // only available for AUSpatialMixer // Global, Boolean, 0->1, 1 kReverbParam_FilterEnable = 18; // only available for AUSpatialMixer // Parameters for the AUMixer3D unit const // Input, Degrees, -180->180, 0 k3DMixerParam_Azimuth = 0; // Input, Degrees, -90->90, 0 k3DMixerParam_Elevation = 1; // Input, Metres, 0->10000, 0 k3DMixerParam_Distance = 2; // Input/Output, dB, -120->20, 0 k3DMixerParam_Gain = 3; // Input, rate scaler 0.5 -> 2.0 k3DMixerParam_PlaybackRate = 4; {$ifc TARGET_OS_MAC} // Desktop specific 3D mixer parameters // Input, Dry/Wet equal-power blend, % 0.0 -> 100.0 k3DMixerParam_ReverbBlend = 5; // Global, dB, -40.0 -> +40.0 k3DMixerParam_GlobalReverbGain = 6; // Input, Lowpass filter attenuation at 5KHz : decibels -100.0dB -> 0.0dB // smaller values make both direct and reverb sound more muffled; a value of 0.0 indicates no filtering // Occlusion is a filter applied to the sound prior to the reverb send k3DMixerParam_OcclusionAttenuation = 7; // Input, Lowpass filter attenuation at 5KHz : decibels -100.0dB -> 0.0dB // smaller values make direct sound more muffled; a value of 0.0 indicates no filtering // Obstruction is a filter applied to the "direct" part of the sound (so is post reverb send) k3DMixerParam_ObstructionAttenuation = 8; // Input/Output, dB, -120->20, 0 k3DMixerParam_MinGain = 9; // Input/Output, dB, -120->20, 0 k3DMixerParam_MaxGain = 10; // read-only // // For each of the following, use the parameter ID plus the channel number // to get the specific parameter ID for a given channel. // For example, k3DMixerParam_PostAveragePower indicates the left channel // while k3DMixerParam_PostAveragePower + 1 indicates the right channel. k3DMixerParam_PreAveragePower = 1000; k3DMixerParam_PrePeakHoldLevel = 2000; k3DMixerParam_PostAveragePower = 3000; k3DMixerParam_PostPeakHoldLevel = 4000; {$endc} { TARGET_OS_MAC } // Parameters for the AUMultiChannelMixer unit // these are available for both desktop and iphone const // Global, Linear Gain, 0->1, 1. (the volume value can actually be any finite number, including negative.) kMultiChannelMixerParam_Volume = 0; // Global, Boolean, 0->1, 1 kMultiChannelMixerParam_Enable = 1; // Global, Pan, -1->1, 0 kMultiChannelMixerParam_Pan = 2; // -1 - 0 - 1, only valid when output is not mono // setting kAudioUnitProperty_MatrixLevels overrides any // previously set kMultiChannelMixerParam_Pan and vice versa // read-only, Input or Output scope. // these report level in dB, as do the other mixers kMultiChannelMixerParam_PreAveragePower = 1000; kMultiChannelMixerParam_PrePeakHoldLevel = 2000; kMultiChannelMixerParam_PostAveragePower = 3000; kMultiChannelMixerParam_PostPeakHoldLevel = 4000; // Parameters for the AUMatrixMixer unit const kMatrixMixerParam_Volume = 0; kMatrixMixerParam_Enable = 1; // read-only // these report level in dB, as do the other mixers kMatrixMixerParam_PreAveragePower = 1000; kMatrixMixerParam_PrePeakHoldLevel = 2000; kMatrixMixerParam_PostAveragePower = 3000; kMatrixMixerParam_PostPeakHoldLevel = 4000; // these report linear levels - for "expert" use only. kMatrixMixerParam_PreAveragePowerLinear = 5000; kMatrixMixerParam_PrePeakHoldLevelLinear = 6000; kMatrixMixerParam_PostAveragePowerLinear = 7000; kMatrixMixerParam_PostPeakHoldLevelLinear = 8000; // Output Units // Parameters for the AudioDeviceOutput, DefaultOutputUnit, and SystemOutputUnit units const // Global, LinearGain, 0->1, 1 kHALOutputParam_Volume = 14; // Parameters for the AUTimePitch, AUTimePitch (offline), AUPitch units const kTimePitchParam_Rate = 0; kTimePitchParam_Pitch = 1; kTimePitchParam_EffectBlend = 2; // only for the AUPitch unit // Parameters for AUNewTimePitch const // rate control. // Global, rate, 1/32 -> 32.0, 1.0 kNewTimePitchParam_Rate = 0; // pitch shift in cents. // Global, Cents, -2400 -> 2400, 1.0 kNewTimePitchParam_Pitch = 1; // Overlap is the number of overlapped spectral windows that are used to produce the output. // The value of overlap is directly proportional to CPU cost. More overlaps can make smooth // passages sound smoother. For percussive sound, a lower overlap may be better. // Global, generic, 3.0 -> 32.0, 8.0 kNewTimePitchParam_Overlap = 4; // Peak locking enforces phase coherence of spectral peaks. // Peak locking adds some expense but results in a less "phasey" // or reverberant sound, sometimes also called loss of presence. // However the flip side is that it can sound more stuttery for some content. // Global, Boolean, 0->1, 1 kNewTimePitchParam_EnablePeakLocking = 6; // Parameters for the AUSampler unit const // Global, dB, -90->12, 0 kAUSamplerParam_Gain = 900; // Global, Semitones, -24->24, 0 kAUSamplerParam_CoarseTuning = 901; // Global, Cents, -99->99, 0 kAUSamplerParam_FineTuning = 902; // Global, -1.0->1.0, 0 kAUSamplerParam_Pan = 903; // Effect units // The values for some effect unit parameters depend on the audio unit's sample rate. // For example, maximum values are typically the Nyquist frequency (indicated here as // SampleRate/2). // Parameters for the AUBandpass unit const // Global, Hz, 20->(SampleRate/2), 5000 kBandpassParam_CenterFrequency = 0; // Global, Cents, 100->12000, 600 kBandpassParam_Bandwidth = 1; // Parameters for the AUHipass unit const // Global, Hz, 10->(SampleRate/2), 6900 kHipassParam_CutoffFrequency = 0; // Global, dB, -20->40, 0 kHipassParam_Resonance = 1; // Parameters for the AULowpass unit const // Global, Hz, 10->(SampleRate/2), 6900 kLowPassParam_CutoffFrequency = 0; // Global, dB, -20->40, 0 kLowPassParam_Resonance = 1; // Parameters for the AUHighShelfFilter unit const // Global, Hz, 10000->(SampleRate/2), 10000 kHighShelfParam_CutOffFrequency = 0; // Global, dB, -40->40, 0 kHighShelfParam_Gain = 1; // Parameters for the AULowShelfFilter unit const // Global, Hz, 10->200, 80 kAULowShelfParam_CutoffFrequency = 0; // Global, dB, -40->40, 0 kAULowShelfParam_Gain = 1; // Parameters for the AUParametricEQ unit const // Global, Hz, 20->(SampleRate/2), 2000 kParametricEQParam_CenterFreq = 0; // Global, Hz, 0.1->20, 1.0 kParametricEQParam_Q = 1; // Global, dB, -20->20, 0 kParametricEQParam_Gain = 2; // Parameters for the AUPeakLimiter unit const // Global, Secs, 0.001->0.03, 0.012 kLimiterParam_AttackTime = 0; // Global, Secs, 0.001->0.06, 0.024 kLimiterParam_DecayTime = 1; // Global, dB, -40->40, 0 kLimiterParam_PreGain = 2; // Parameters for the AUDynamicsProcessor unit // Note that the dynamics processor does not have fixed compression ratios. // Instead, kDynamicsProcessorParam_HeadRoom adjusts the amount of compression. // Lower kDynamicsProcessorParam_HeadRoom values results in higher compression. // The compression ratio is automatically adjusted to not exceed kDynamicsProcessorParam_Threshold + kDynamicsProcessorParam_HeadRoom values. const // Global, dB, -40->20, -20 kDynamicsProcessorParam_Threshold = 0; // Global, dB, 0.1->40.0, 5 kDynamicsProcessorParam_HeadRoom = 1; // Global, rate, 1->50.0, 2 kDynamicsProcessorParam_ExpansionRatio = 2; // Global, dB kDynamicsProcessorParam_ExpansionThreshold = 3; // Global, secs, 0.0001->0.2, 0.001 kDynamicsProcessorParam_AttackTime = 4; // Global, secs, 0.01->3, 0.05 kDynamicsProcessorParam_ReleaseTime = 5; // Global, dB, -40->40, 0 kDynamicsProcessorParam_MasterGain = 6; // Global, dB, read-only parameter kDynamicsProcessorParam_CompressionAmount = 1000; kDynamicsProcessorParam_InputAmplitude = 2000; kDynamicsProcessorParam_OutputAmplitude = 3000; // Parameters for the AUVarispeed unit const // Global, Rate, 0.25 -> 4.0, 1.0 kVarispeedParam_PlaybackRate = 0; // Global, Cents, -2400 -> 2400, 0.0 kVarispeedParam_PlaybackCents = 1; // Parameters for the Distortion unit const // Global, Milliseconds, 0.1 -> 500, 0.1 kDistortionParam_Delay = 0; // Global, Rate, 0.1 -> 50, 1.0 kDistortionParam_Decay = 1; // Global, Percent, 0 -> 100, 50 kDistortionParam_DelayMix = 2; // Global, Percent, 0 -> 100 kDistortionParam_Decimation = 3; // Global, Percent, 0 -> 100, 0 kDistortionParam_Rounding = 4; // Global, Percent, 0 -> 100, 50 kDistortionParam_DecimationMix = 5; // Global, Linear Gain, 0 -> 1, 1 kDistortionParam_LinearTerm = 6; // Global, Linear Gain, 0 -> 20, 0 kDistortionParam_SquaredTerm = 7; // Global, Linear Gain, 0 -> 20, 0 kDistortionParam_CubicTerm = 8; // Global, Percent, 0 -> 100, 50 kDistortionParam_PolynomialMix = 9; // Global, Hertz, 0.5 -> 8000, 100 kDistortionParam_RingModFreq1 = 10; // Global, Hertz, 0.5 -> 8000, 100 kDistortionParam_RingModFreq2 = 11; // Global, Percent, 0 -> 100, 50 kDistortionParam_RingModBalance = 12; // Global, Percent, 0 -> 100, 0 kDistortionParam_RingModMix = 13; // Global, dB, -80 -> 20, -6 kDistortionParam_SoftClipGain = 14; // Global, Percent, 0 -> 100, 50 kDistortionParam_FinalMix = 15; // Parameters for the AUDelay unit const // Global, EqPow Crossfade, 0->100, 50 kDelayParam_WetDryMix = 0; // Global, Secs, 0->2, 1 kDelayParam_DelayTime = 1; // Global, Percent, -100->100, 50 kDelayParam_Feedback = 2; // Global, Hz, 10->(SampleRate/2), 15000 kDelayParam_LopassCutoff = 3; // Parameters for the AUNBandEQ unit // Note that the parameter IDs listed correspond to band 0 (zero) of the unit. The parameter IDs for // higher bands can be obtained by adding the zero-indexed band number to the corresponding band 0 // parameter ID up to the number of bands minus one, where the number of bands is described by the // AUNBandEQ property kAUNBandEQProperty_NumberOfBands. For example, the parameter ID corresponding // to the filter type of band 4 would be kAUNBandEQParam_FilterType + 3. // kAUNBandEQParam_GlobalsGain is an overall gain and does not have a band. const // Global, dB, -96->24, 0 kAUNBandEQParam_GlobalGain = 0; // Global, Boolean, 0 or 1, 1 kAUNBandEQParam_BypassBand = 1000; // Global, Indexed, 0->kNumAUNBandEQFilterTypes-1, 0 kAUNBandEQParam_FilterType = 2000; // Global, Hz, 20->(SampleRate/2), 1000 kAUNBandEQParam_Frequency = 3000; // Global, dB, -96->24, 0 kAUNBandEQParam_Gain = 4000; // Global, octaves, 0.05->5.0, 0.5 kAUNBandEQParam_Bandwidth = 5000; {! @enum AUNBandEQ filter types @discussion Constants available as values for the kAUNBandEQParam_FilterType parameter defined above @constant kAUNBandEQFilterType_Parametric Parametric filter based on Butterworth analog prototype. Uses parameterization where the bandwidth is specifed as the relationship of the upper bandedge frequency to the lower bandedge frequency in octaves, where the upper and lower bandedge frequencies are the respective frequencies above and below the center frequency at which the gain is equal to half the peak gain. Applicable parameters: - kAUNBandEQParam_Frequency (center frequency) - kAUNBandEQParam_Gain (peak gain) - kAUNBandEQParam_Bandwidth @constant kAUNBandEQFilterType_2ndOrderButterworthLowPass Simple Butterworth 2nd order low pass filter Applicable parameters: - kAUNBandEQParam_Frequency (-3 dB cutoff frequency) @constant kAUNBandEQFilterType_2ndOrderButterworthHighPass Simple Butterworth 2nd order high pass filter Applicable parameters: - kAUNBandEQParam_Frequency (-3 dB cutoff frequency) @constant kAUNBandEQFilterType_ResonantLowPass Low pass filter with resonance support (via bandwidth parameter) Applicable parameters: - kAUNBandEQParam_Frequency (-3 dB cutoff frequency) - kAUNBandEQParam_Bandwidth @constant kAUNBandEQFilterType_ResonantHighPass High pass filter with resonance support (via bandwidth parameter) Applicable parameters: - kAUNBandEQParam_Frequency (-3 dB cutoff frequency) - kAUNBandEQParam_Bandwidth @constant kAUNBandEQFilterType_BandPass Band pass filter Applicable parameters: - kAUNBandEQParam_Frequency (center frequency) - kAUNBandEQParam_Bandwidth @constant kAUNBandEQFilterType_BandStop Band stop filter (aka "notch filter") Applicable parameters: - kAUNBandEQParam_Frequency (center frequency) - kAUNBandEQParam_Bandwidth @constant kAUNBandEQFilterType_LowShelf Low shelf filter Applicable parameters: - kAUNBandEQParam_Frequency (center frequency) - kAUNBandEQParam_Gain (shelf gain) @constant kAUNBandEQFilterType_HighShelf High shelf filter Applicable parameters: - kAUNBandEQParam_Frequency (center frequency) - kAUNBandEQParam_Gain (shelf gain) @constant kAUNBandEQFilterType_ResonantLowShelf Low shelf filter with resonance support (via bandwidth parameter) Applicable parameters: - kAUNBandEQParam_Frequency (center frequency) - kAUNBandEQParam_Gain (shelf gain) - kAUNBandEQParam_Bandwidth @constant kAUNBandEQFilterType_ResonantHighShelf High shelf filter with resonance support (via bandwidth parameter) Applicable parameters: - kAUNBandEQParam_Frequency (center frequency) - kAUNBandEQParam_Gain (shelf gain) - kAUNBandEQParam_Bandwidth } const kAUNBandEQFilterType_Parametric = 0; kAUNBandEQFilterType_2ndOrderButterworthLowPass = 1; kAUNBandEQFilterType_2ndOrderButterworthHighPass = 2; kAUNBandEQFilterType_ResonantLowPass = 3; kAUNBandEQFilterType_ResonantHighPass = 4; kAUNBandEQFilterType_BandPass = 5; kAUNBandEQFilterType_BandStop = 6; kAUNBandEQFilterType_LowShelf = 7; kAUNBandEQFilterType_HighShelf = 8; kAUNBandEQFilterType_ResonantLowShelf = 9; kAUNBandEQFilterType_ResonantHighShelf = 10; kNumAUNBandEQFilterTypes = 11; // Parameters for the AURoundTripAACParam unit const // Global, indexed : AAC, HE-AAC, HE-AACv2 kRoundTripAACParam_Format = 0; // Global, indexed kRoundTripAACParam_EncodingStrategy = 1; // Global, indexed kRoundTripAACParam_RateOrQuality = 2; // These are deprecated: kRoundTripAACParam_BitRate = 1; kRoundTripAACParam_Quality = 2; kRoundTripAACParam_CompressedFormatSampleRate = 3; //#pragma mark Apple Specific - Desktop {$ifc TARGET_OS_MAC} // Some parameters for the AUGraphicEQ unit const // Global, Indexed, currently either 10 or 31 kGraphicEQParam_NumberOfBands = 10000; // Parameters for the AUMatrixReverb unit const // Global, EqPow CrossFade, 0->100, 100 kReverbParam_DryWetMix = 0; // Global, EqPow CrossFade, 0->100, 50 kReverbParam_SmallLargeMix = 1; // Global, Secs, 0.005->0.020, 0.06 kReverbParam_SmallSize = 2; // Global, Secs, 0.4->10.0, 3.07 kReverbParam_LargeSize = 3; // Global, Secs, 0.001->0.03, 0.025 kReverbParam_PreDelay = 4; // Global, Secs, 0.001->0.1, 0.035 kReverbParam_LargeDelay = 5; // Global, Genr, 0->1, 0.28 kReverbParam_SmallDensity = 6; // Global, Genr, 0->1, 0.82 kReverbParam_LargeDensity = 7; // Global, Genr, 0->1, 0.3 kReverbParam_LargeDelayRange = 8; // Global, Genr, 0.1->1, 0.96 kReverbParam_SmallBrightness = 9; // Global, Genr, 0.1->1, 0.49 kReverbParam_LargeBrightness = 10; // Global, Genr, 0->1 0.5 kReverbParam_SmallDelayRange = 11; // Global, Hz, 0.001->2.0, 1.0 kReverbParam_ModulationRate = 12; // Global, Genr, 0.0 -> 1.0, 0.2 kReverbParam_ModulationDepth = 13; // Parameters for the AUMultibandCompressor unit const // Global, dB, -40 -> 40, 0 kMultibandCompressorParam_Pregain = 0; // Global, dB, -40 -> 40, 0 kMultibandCompressorParam_Postgain = 1; // Global, Hertz, 20 -> (SampleRate/2), 120.0 kMultibandCompressorParam_Crossover1 = 2; // Global, Hertz, 20 -> (SampleRate/2), 700.0 kMultibandCompressorParam_Crossover2 = 3; // Global, Hertz, 20 -> (SampleRate/2), 3000.0 kMultibandCompressorParam_Crossover3 = 4; // Global, dB, -100.0 -> 0.0, -22.0 kMultibandCompressorParam_Threshold1 = 5; // Global, dB, -100.0 -> 0.0, -32.0 kMultibandCompressorParam_Threshold2 = 6; // Global, dB, -100.0 -> 0.0, -33.0 kMultibandCompressorParam_Threshold3 = 7; // Global, dB, -100.0 -> 0.0, -36.0 kMultibandCompressorParam_Threshold4 = 8; // Global, dB, 0.1 -> 40.0, 5.0 kMultibandCompressorParam_Headroom1 = 9; // Global, dB, 0.1 -> 40.0, 12.0 kMultibandCompressorParam_Headroom2 = 10; // Global, dB, 0.1 -> 40.0, 5.0 kMultibandCompressorParam_Headroom3 = 11; // Global, dB, 0.1 -> 40.0, 7.5 kMultibandCompressorParam_Headroom4 = 12; // Global, Secs, 0.001 -> 0.200, 0.080 kMultibandCompressorParam_AttackTime = 13; // Global, Secs, 0.010 -> 3.0, 0.120 kMultibandCompressorParam_ReleaseTime = 14; // Global, dB, -20 -> 20, 0 kMultibandCompressorParam_EQ1 = 15; // Global, dB, -20 -> 20, 0 kMultibandCompressorParam_EQ2 = 16; // Global, dB, -20 -> 20, 0 kMultibandCompressorParam_EQ3 = 17; // Global, dB, -20 -> 20, 0 kMultibandCompressorParam_EQ4 = 18; // read-only parameters // Global, dB, 0 -> 20 kMultibandCompressorParam_CompressionAmount1 = 1000; // Global, dB, 0 -> 20 kMultibandCompressorParam_CompressionAmount2 = 2000; // Global, dB, 0 -> 20 kMultibandCompressorParam_CompressionAmount3 = 3000; // Global, dB, 0 -> 20 kMultibandCompressorParam_CompressionAmount4 = 4000; // Global, dB, -120 -> 20 kMultibandCompressorParam_InputAmplitude1 = 5000; // Global, dB, -120 -> 20 kMultibandCompressorParam_InputAmplitude2 = 6000; // Global, dB, -120 -> 20 kMultibandCompressorParam_InputAmplitude3 = 7000; // Global, dB, -120 -> 20 kMultibandCompressorParam_InputAmplitude4 = 8000; // Global, dB, -120 -> 20 kMultibandCompressorParam_OutputAmplitude1 = 9000; // Global, dB, -120 -> 20 kMultibandCompressorParam_OutputAmplitude2 = 10000; // Global, dB, -120 -> 20 kMultibandCompressorParam_OutputAmplitude3 = 11000; // Global, dB, -120 -> 20 kMultibandCompressorParam_OutputAmplitude4 = 12000; // Parameters for the AUFilter unit const // Global, indexed, 0 -> 1, 0 kMultibandFilter_LowFilterType = 0; // Global, Hertz, 10 -> (SampleRate/2), 100 kMultibandFilter_LowFrequency = 1; // Global, dB, -18 -> +18, 0 kMultibandFilter_LowGain = 2; // Global, Hertz, 10 -> (SampleRate/2), 100 kMultibandFilter_CenterFreq1 = 3; // Global, dB, -18 -> +18, 0 kMultibandFilter_CenterGain1 = 4; // Global, Octaves, 0.05 -> 3.0, 2.0 kMultibandFilter_Bandwidth1 = 5; // Global, Hertz, 10 -> (SampleRate/2), 100 kMultibandFilter_CenterFreq2 = 6; // Global, dB, -18 -> +18, 0 kMultibandFilter_CenterGain2 = 7; // Global, Octaves, 0.05 -> 3.0, 2.0 kMultibandFilter_Bandwidth2 = 8; // Global, Hertz, 10 -> (SampleRate/2), 100 kMultibandFilter_CenterFreq3 = 9; // Global, dB, -18 -> +18, 0 kMultibandFilter_CenterGain3 = 10; // Global, Octaves, 0.05 -> 3.0, 2.0 kMultibandFilter_Bandwidth3 = 11; // Global, indexed, 0 -> 1, 0 kMultibandFilter_HighFilterType = 12; // Global, Hertz, 10 -> (SampleRate/2), 100 kMultibandFilter_HighFrequency = 13; // Global, dB, -18 -> +18, 0 kMultibandFilter_HighGain = 14; // Parameters for AURogerBeep const // Global, dB, -80 -> 0, -6 kRogerBeepParam_InGateThreshold = 0; // Global, Milliseconds, 0 -> 1000, 1000 kRogerBeepParam_InGateThresholdTime = 1; // Global, dB, -80 -> 0, -6 kRogerBeepParam_OutGateThreshold = 2; // Global, Milliseconds, 0 -> 1000, 1000 kRogerBeepParam_OutGateThresholdTime = 3; // Global, indexed, 0 -> 2, 2 kRogerBeepParam_Sensitivity = 4; // Global, indexed, 0 -> 2, 0 kRogerBeepParam_RogerType = 5; // Global, dB, -80 -> 20, -6 kRogerBeepParam_RogerGain = 6; // Mixer Units // Parameters for the Stereo Mixer unit const // Input/Output, Mixer Fader Curve, 0->1, 1 kStereoMixerParam_Volume = 0; // Input, Pan, 0->1, 0.5 kStereoMixerParam_Pan = 1; // read-only // // For each of the following, use the parameter ID for the left channel // and the parameter ID plus one for the right channel. // For example, kStereoMixerParam_PostAveragePower indicates the left channel // while kStereiMixerParam_PostAveragePower + 1 indicates the right channel. kStereoMixerParam_PreAveragePower = 1000; kStereoMixerParam_PrePeakHoldLevel = 2000; kStereoMixerParam_PostAveragePower = 3000; kStereoMixerParam_PostPeakHoldLevel = 4000; // Parameters for the AUNetReceive unit const // Global, indexed, 0 -> 5, read only kAUNetReceiveParam_Status = 0; kAUNetReceiveParam_NumParameters = 1; // Parameters for the AUNetSend unit const // Global, indexed, 0 -> 5, read only kAUNetSendParam_Status = 0; kAUNetSendParam_NumParameters = 1; // Status values for the AUNetSend and AUNetReceive units const kAUNetStatus_NotConnected = 0; kAUNetStatus_Connected = 1; kAUNetStatus_Overflow = 2; kAUNetStatus_Underflow = 3; kAUNetStatus_Connecting = 4; kAUNetStatus_Listening = 5; // Music Device // Parameters for the DLSMusicDevice unit - defined and reported in the global scope const // Global, Cents, -1200, 1200, 0 kMusicDeviceParam_Tuning = 0; // Global, dB, -120->40, 0 kMusicDeviceParam_Volume = 1; // Global, dB, -120->40, 0 kMusicDeviceParam_ReverbVolume = 2; // In Mac OS X v10.5, the DLSMusicDevice audio unit does not report parameters in the Group scope. // However, parameter values can be set in Group scope that correspond to controller values defined // by the MIDI specification. This includes the standard MIDI Controller values (such as Volume and // Mod Wheel) as well as MIDI status messages (such as Pitch Bend and Channel Pressure) and the // MIDI RPN control messages. // For MIDI status messages, use a value of 0 for the "channel part" (lower four bits) when setting // these parameters. This allows audio units to distinguish these IDs from the 0-127 // values used by MIDI controllers in the first byte of status messages. // // The element ID represents the group or channel number. // // You can use the MusicDeviceMIDIEvent function to send a MIDI formatted control command to a device. // // You can use the SetParameter API calls, declared in the AUComponent.h header file, as follows: // // scope == kAudioUnitScope_Group // element == groupID -> in MIDI equivalent to channel number 0->15, // but this is not a limitation of the MusicDevice and values greater than 15 can be specified // paramID == midi controller value (0->127), (status bytes corresponding to pitch bend, channel pressure) // value == typically the range associated with the corresponding MIDI message (7 bit, 0->127) // pitch bend is specified as a 14 bit value // See the MusicDevice.h header file for more about using the extended control semantics // of this API. // `Analog' AudioUnits // Parameters for the AURandom unit const kRandomParam_BoundA = 0; kRandomParam_BoundB = 1; kRandomParam_Curve = 2; {$endc} {TARGET_OS_MAC} //#pragma mark Apple Specific - iOS {$ifc TARGET_OS_IPHONE} // Parameters for the iOS reverb unit const // Global, CrossFade, 0->100, 100 kReverb2Param_DryWetMix = 0; // Global, Decibels, -20->20, 0 kReverb2Param_Gain = 1; // Global, Secs, 0.0001->1.0, 0.008 kReverb2Param_MinDelayTime = 2; // Global, Secs, 0.0001->1.0, 0.050 kReverb2Param_MaxDelayTime = 3; // Global, Secs, 0.001->20.0, 1.0 kReverb2Param_DecayTimeAt0Hz = 4; // Global, Secs, 0.001->20.0, 0.5 kReverb2Param_DecayTimeAtNyquist = 5; // Global, Integer, 1->1000 kReverb2Param_RandomizeReflections = 6; {$endc} {TARGET_OS_IPHONE} {$ifc not defined MACOSALLINCLUDE or not MACOSALLINCLUDE} end. {$endc} {not MACOSALLINCLUDE}