JUCE-7.0.12-0-g4f43011b96 JUCE-7.0.12-0-g4f43011b96
JUCE — C++ application framework with suport for VST, VST3, LV2 audio plug-ins

« « « Anklang Documentation
Loading...
Searching...
No Matches
juce_CoreAudioFormat.h
Go to the documentation of this file.
1 /*
2 ==============================================================================
3
4 This file is part of the JUCE library.
5 Copyright (c) 2022 - Raw Material Software Limited
6
7 JUCE is an open source library subject to commercial or open-source
8 licensing.
9
10 By using JUCE, you agree to the terms of both the JUCE 7 End-User License
11 Agreement and JUCE Privacy Policy.
12
13 End User License Agreement: www.juce.com/juce-7-licence
14 Privacy Policy: www.juce.com/juce-privacy-policy
15
16 Or: You may also use this code under the terms of the GPL v3 (see
17 www.gnu.org/licenses).
18
19 JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
20 EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
21 DISCLAIMED.
22
23 ==============================================================================
24*/
25
26namespace juce
27{
28
29#if JUCE_MAC || JUCE_IOS || DOXYGEN
30
31//==============================================================================
42class JUCE_API CoreAudioFormat : public AudioFormat
43{
44public:
46 enum class StreamKind
47 {
48 kNone,
49 kAiff,
50 kAifc,
51 kWave,
52 kSoundDesigner2,
53 kNext,
54 kMp3,
55 kMp2,
56 kMp1,
57 kAc3,
58 kAacAdts,
59 kMpeg4,
60 kM4a,
61 kM4b,
62 kCaf,
63 k3gp,
64 k3gp2,
65 kAmr,
66 };
67
68 //==============================================================================
71
76
78 ~CoreAudioFormat() override;
79
80 //==============================================================================
82 static const char* const midiDataBase64;
84 static const char* const tempo;
86 static const char* const timeSig;
88 static const char* const keySig;
89
90 //==============================================================================
93 bool canDoStereo() override;
94 bool canDoMono() override;
95
96 //==============================================================================
98 bool deleteStreamIfOpeningFails) override;
99
101 double sampleRateToUse,
102 unsigned int numberOfChannels,
103 int bitsPerSample,
104 const StringPairArray& metadataValues,
105 int qualityOptionIndex) override;
106 using AudioFormat::createWriterFor;
107
108private:
109 StreamKind streamKind = StreamKind::kNone;
110
112};
113
114#endif
115
116} // namespace juce
Holds a resizable array of primitive or copy-by-value objects.
Definition juce_Array.h:56
Reads samples from an audio file stream.
Writes samples to an audio file stream.
Subclasses of AudioFormat are used to read and write different audio file formats.
OSX and iOS only - This uses the AudioToolbox framework to read any audio format that the system has ...
static const char *const keySig
Metadata property name used when reading a caf file time signature information.
bool canDoMono() override
Returns true if the format can do 1-channel audio.
static const char *const midiDataBase64
Metadata property name used when reading a caf file with a MIDI chunk.
static const char *const timeSig
Metadata property name used when reading a caf file time signature information.
static const char *const tempo
Metadata property name used when reading a caf file with tempo information.
CoreAudioFormat()
Creates a format object.
~CoreAudioFormat() override
Destructor.
bool canDoStereo() override
Returns true if the format can do 2-channel audio.
AudioFormatReader * createReaderFor(InputStream *, bool deleteStreamIfOpeningFails) override
Tries to create an object that can read from a stream containing audio data in this format.
CoreAudioFormat(StreamKind)
Creates a format object and provides a hint as to the format of data to be read or written.
Array< int > getPossibleSampleRates() override
Returns a set of sample rates that the format can read and write.
AudioFormatWriter * createWriterFor(OutputStream *, double sampleRateToUse, unsigned int numberOfChannels, int bitsPerSample, const StringPairArray &metadataValues, int qualityOptionIndex) override
Tries to create an object that can write to a stream with this audio format.
Array< int > getPossibleBitDepths() override
Returns a set of bit depths that the format can read and write.
The base class for streams that read data.
The base class for streams that write data to some kind of destination.
A container for holding a set of strings which are keyed by another string.
#define JUCE_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR(className)
This is a shorthand way of writing both a JUCE_DECLARE_NON_COPYABLE and JUCE_LEAK_DETECTOR macro for ...
JUCE Namespace.