Qt
Internal/Contributor docs for the Qt SDK. <b>Note:</b> These are NOT official API docs; those are found <a href='https://doc.qt.io/'>here</a>.
Loading...
Searching...
No Matches
qdarwinaudiosink_p.h
Go to the documentation of this file.
1// Copyright (C) 2016 The Qt Company Ltd.
2// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
3#ifndef IOSAUDIOOUTPUT_H
4#define IOSAUDIOOUTPUT_H
5
6//
7// W A R N I N G
8// -------------
9//
10// This file is not part of the Qt API. It exists purely as an
11// implementation detail. This header file may change from version to
12// version without notice, or even be removed.
13//
14// We mean it.
15//
16
17#include <private/qaudiosystem_p.h>
18#include <private/qaudiostatemachine_p.h>
19
20#if defined(Q_OS_MACOS)
21# include <CoreAudio/CoreAudio.h>
22#endif
23#include <AudioUnit/AudioUnit.h>
24#include <CoreAudio/CoreAudioTypes.h>
25
26#include <QtCore/QIODevice>
28#include <qsemaphore.h>
29
31
33class QTimer;
36
38{
40
41public:
42 QDarwinAudioSinkBuffer(int bufferSize, int maxPeriodSize, QAudioFormat const& audioFormat);
44
45 qint64 readFrames(char *data, qint64 maxFrames);
46 qint64 writeBytes(const char *data, qint64 maxSize);
47
48 int available() const;
49
50 bool deviceAtEnd() const;
51
52 void reset();
53
55
57
58 void setFillingEnabled(bool enabled);
59
61 void readyRead();
62
63private slots:
64 void fillBuffer();
65
66private:
67 bool m_deviceError = false;
68 bool m_fillingEnabled = false;
69 bool m_deviceAtEnd = false;
70 const int m_maxPeriodSize = 0;
71 const int m_bytesPerFrame = 0;
72 const int m_periodTime = 0;
73 QIODevice *m_device = nullptr;
74 QTimer *m_fillTimer = nullptr;
75 std::unique_ptr<CoreAudioRingBuffer> m_buffer;
76};
77
79{
80public:
82
84 qint64 writeData(const char *data, qint64 len);
85
86 bool isSequential() const { return true; }
87
88private:
89 QDarwinAudioSinkBuffer *m_audioBuffer;
90};
91
92
94{
96
97public:
100
101 void start(QIODevice *device);
102 QIODevice *start();
103 void stop();
104 void reset();
105 void suspend();
106 void resume();
107 qsizetype bytesFree() const;
109 qsizetype bufferSize() const;
110 qint64 processedUSecs() const;
111 QAudio::Error error() const;
112 QAudio::State state() const;
113 void setFormat(const QAudioFormat &format);
114 QAudioFormat format() const;
115
116 void setVolume(qreal volume);
117 qreal volume() const;
118
119private slots:
120 void inputReady();
121 void updateAudioDevice();
122
123private:
124 enum ThreadState { Running, Draining, Stopped };
125
126 static OSStatus renderCallback(void *inRefCon,
127 AudioUnitRenderActionFlags *ioActionFlags,
128 const AudioTimeStamp *inTimeStamp,
129 UInt32 inBusNumber,
130 UInt32 inNumberFrames,
131 AudioBufferList *ioData);
132
133 bool open();
134 void close();
135 void onAudioDeviceIdle();
136 void onAudioDeviceError();
137 void onAudioDeviceDrained();
138
139 QAudioDevice m_audioDeviceInfo;
140 QByteArray m_device;
141
142 static constexpr int DEFAULT_BUFFER_SIZE = 8 * 1024;
143
144 bool m_isOpen = false;
145 int m_internalBufferSize = DEFAULT_BUFFER_SIZE;
146 int m_periodSizeBytes = 0;
147 qint64 m_totalFrames = 0;
148 QAudioFormat m_audioFormat;
149 QIODevice *m_audioIO = nullptr;
150#if defined(Q_OS_MACOS)
151 AudioDeviceID m_audioDeviceId;
152#endif
153 AudioUnit m_audioUnit = 0;
154 bool m_audioUnitStarted = false;
155 Float64 m_clockFrequency = 0;
156 AudioStreamBasicDescription m_streamFormat;
157 std::unique_ptr<QDarwinAudioSinkBuffer> m_audioBuffer;
158 qreal m_cachedVolume = 1.;
159#if defined(Q_OS_MACOS)
160 qreal m_volume = 1.;
161#endif
162 bool m_pullMode = false;
163
164 QAudioStateMachine m_stateMachine;
165 QSemaphore m_drainSemaphore;
166};
167
169
170#endif // IOSAUDIOOUTPUT_H
IOBluetoothDevice * device
The QAudioDevice class provides an information about audio devices and their functionality.
The QAudioFormat class stores audio stream parameter information.
\inmodule QtCore
Definition qbytearray.h:57
void setFillingEnabled(bool enabled)
qint64 readFrames(char *data, qint64 maxFrames)
qint64 writeBytes(const char *data, qint64 maxSize)
void setPrefetchDevice(QIODevice *device)
QDarwinAudioSinkBuffer(int bufferSize, int maxPeriodSize, QAudioFormat const &audioFormat)
QIODevice * prefetchDevice() const
QDarwinAudioSinkDevice(QDarwinAudioSinkBuffer *audioBuffer, QObject *parent)
bool isSequential() const
Returns true if this device is sequential; otherwise returns false.
qint64 writeData(const char *data, qint64 len)
Writes up to maxSize bytes from data to the device.
void setFormat(const QAudioFormat &format)
qint64 processedUSecs() const
QAudioFormat format() const
QDarwinAudioSink(const QAudioDevice &device, QObject *parent)
void setBufferSize(qsizetype value)
QAudio::State state() const
QAudio::Error error() const
void setVolume(qreal volume)
qsizetype bytesFree() const
qsizetype bufferSize() const
\inmodule QtCore \reentrant
Definition qiodevice.h:34
\inmodule QtCore
Definition qobject.h:103
QObject * parent() const
Returns a pointer to the parent object.
Definition qobject.h:346
\inmodule QtCore
Definition qsemaphore.h:18
\inmodule QtCore
Definition qtimer.h:20
State
Definition qaudio.h:29
Error
Definition qaudio.h:28
Combined button and popup list for selecting options.
EGLOutputLayerEXT EGLint EGLAttrib value
[5]
GLint GLsizei GLsizei GLenum GLenum GLsizei void * data
GLenum GLenum GLsizei const GLuint GLboolean enabled
GLint GLsizei GLsizei GLenum format
GLenum GLsizei len
#define Q_OBJECT
#define slots
#define signals
ptrdiff_t qsizetype
Definition qtypes.h:165
long long qint64
Definition qtypes.h:60
double qreal
Definition qtypes.h:187
QByteArray readData()