QAudioSink Class

QAudioSinkクラスは、オーディオデータをオーディオ出力デバイスに送信するためのインターフェースを提供します。詳細...

Header: #include <QAudioSink>
CMake: find_package(Qt6 REQUIRED COMPONENTS Multimedia)
target_link_libraries(mytarget PRIVATE Qt6::Multimedia)
qmake: QT += multimedia
Inherits: QObject

パブリック関数

QAudioSink(const QAudioFormat &format = QAudioFormat(), QObject *parent = nullptr)
QAudioSink(const QAudioDevice &audioDevice, const QAudioFormat &format = QAudioFormat(), QObject *parent = nullptr)
virtual ~QAudioSink()
qsizetype bufferSize() const
qsizetype bytesFree() const
qint64 elapsedUSecs() const
QtAudio::Error error() const
QAudioFormat format() const
bool isNull() const
qint64 processedUSecs() const
void reset()
void resume()
void setBufferSize(qsizetype value)
void setVolume(qreal volume)
QIODevice *start()
void start(QIODevice *device)
QtAudio::State state() const
void stop()
void suspend()
qreal volume() const

シグナル

void stateChanged(QtAudio::State state)

詳細説明

システムのデフォルト・オーディオ出力デバイスでオーディオ出力を構築できます。また、特定のQAudioDevice で QAudioSink を作成することも可能です。オーディオ出力を作成する際、再生に使用するQAudioFormat も送信する必要があります(詳細はQAudioFormat クラスの説明を参照してください)。

ファイルを再生する

start QIODeviceQAudioSinkは、ioデバイスから必要なデータをフェッチします。つまり、オーディオファイルの再生は、次のように簡単です:

QFile sourceFile;   // class member.
QAudioSink* audio; // class member.
{
    sourceFile.setFileName("/tmp/test.raw");
    sourceFile.open(QIODevice::ReadOnly);

    QAudioFormat format;
    // Set up the format, eg.
    format.setSampleRate(8000);
    format.setChannelCount(1);
    format.setSampleFormat(QAudioFormat::UInt8);

    QAudioDevice info(QMediaDevices::defaultAudioOutput());
    if (!info.isFormatSupported(format)) {
        qWarning() << "Raw audio format not supported by backend, cannot play audio.";
        return;
    }

    audio = new QAudioSink(format, this);
    connect(audio, QAudioSink::stateChanged, this, &AudioInputExample::handleStateChanged);
    audio->start(&sourceFile);
}

オーディオシステムと出力デバイスが対応していれば、ファイルの再生が始まります。運が悪ければ、error ()関数で確認してください。

ファイルの再生が終わったら、デバイスを停止する必要がある:

void AudioOutputExample::stopAudioOutput()
{
    audio->stop();
    sourceFile.close();
    delete audio;
}

いつでも、QAudioSinkは4つの状態のうちの1つになります:アクティブ、サスペンド、ストップ、アイドル。これらの状態は、QtAudio::State enumで記述されています。状態の変更は、stateChanged()シグナルを通して報告されます。このシグナルを使用して、例えばアプリケーションのGUIを更新することができる。ここではありふれた例として、play/pause ボタンの状態を変更する。suspend ()、stop ()、reset ()、resume ()、start ()で直接状態変更を要求する。

エラーが発生した場合は、error ()関数でerror type 。報告される可能性のあるエラーの説明については、QtAudio::Error enumを参照のこと。QtAudio::UnderrunError に遭遇すると、状態はQtAudio::IdleState に変化し、別のエラーに遭遇すると、状態はQtAudio::StoppedState に変化する。stateChanged() シグナルに接続することで、エラーをチェックすることができる:

void AudioOutputExample::handleStateChanged(QAudio::State newState)
{
    switch (newState) {
        case QAudio::IdleState:
            // Finished playing (no more data)
            AudioOutputExample::stopAudioOutput();
            break;

        case QAudio::StoppedState:
            // Stopped for other reasons
            if (audio->error() != QAudio::NoError) {
                // Error handling
            }
            break;

        default:
            // ... other cases as appropriate
            break;
    }
}

QAudioSource およびQAudioDeviceも参照のこと

メンバー関数ドキュメント

[explicit] QAudioSink::QAudioSink(const QAudioFormat &format = QAudioFormat(), QObject *parent = nullptr)

新しいオーディオ出力を構築し、それをparent にアタッチする。 デフォルトのオーディオ出力デバイスは、出力format パラメータで使用される。

[explicit] QAudioSink::QAudioSink(const QAudioDevice &audioDevice, const QAudioFormat &format = QAudioFormat(), QObject *parent = nullptr)

新しいオーディオ出力を構築し、parent にアタッチします。audioDevice によって参照されるデバイスが、outputformat パラメータで使用されます。

[virtual noexcept] QAudioSink::~QAudioSink()

このオーディオ出力を破棄します。

これにより、使用されているシステムリソースが解放され、バッファが解放されます。

qsizetype QAudioSink::bufferSize() const

オーディオバッファサイズをバイト単位で返します。

start() の前に呼ばれた場合は、プラットフォームのデフォルト値を返します。start() の前に呼び出されたが、setBufferSize() がその前に呼び出された場合、setBufferSize() で設定された値を返す。start() の後に呼び出された場合、実際に使用されているバッファ・サイズを返す。これは、setBufferSize() で設定された値とは異なる可能性がある。

setBufferSize()も参照

qsizetype QAudioSink::bytesFree() const

オーディオ・バッファで使用可能な空きバイト数を返します。

注意: 返される値は、QtAudio::ActiveState またはQtAudio::IdleState の状態にあるときのみ有効で、それ以外の場合は 0 を返す。

qint64 QAudioSink::elapsedUSecs() const

start() が呼び出されてからのマイクロ秒を返す。アイドル状態およびサスペンド状態にあった時間も含まれる。

QtAudio::Error QAudioSink::error() const

エラー状態を返す。

QAudioFormat QAudioSink::format() const

使用されているQAudioFormat を返す。

bool QAudioSink::isNull() const

QAudioSink インスタンスがnull の場合はtrue を返し、そうでない場合はfalse を返す。

qint64 QAudioSink::processedUSecs() const

start() が呼び出されてから処理された音声データ量を返す(単位はマイクロ秒)。

void QAudioSink::reset()

バッファ内のすべてのオーディオ・データを削除し、バッファをゼロにリセットする。

void QAudioSink::resume()

suspend() の後にオーディオ・データの処理を再開する。

state() をsuspend() が呼び出されたときのシンクの状態に設定し、error() を QAudioError::NoError に設定する。オーディオシンクの状態がQtAudio::SuspendedState でない場合、この関数は何もしない。

void QAudioSink::setBufferSize(qsizetype value)

オーディオ・バッファ・サイズをバイト単位でvalue に設定します。

注意: この関数はstart() の前であればいつでも呼び出すことができます。start() 以降の呼び出しは無視される。設定されたバッファ・サイズが実際に使用されるバッファ・サイズであると仮定してはならない。start() の後でいつでもbufferSize() を呼び出して、実際に使用されるバッファ・サイズを返すようにする。

bufferSize()も参照

void QAudioSink::setVolume(qreal volume)

出力ボリュームをvolume に設定する。

音量は、0.0 (無音)から1.0 (フル音量)まで、直線的にスケーリングされる。この範囲外の値はクランプされます。

デフォルトの音量は1.0 です。

注: 音量の調整は、グローバル音量ではなく、このオーディオストリームの音量を変更します。

UIの音量コントロールは通常、非線形にスケーリングする必要があります。例えば、対数スケールを使用すると、知覚されるラウドネスが直線的に変化します。詳しくはQtAudio::convertVolume() を参照。

volume()も参照

QIODevice *QAudioSink::start()

システムのオーディオ出力へのデータ転送に使用されている内部QIODevice へのポインタを返します。このデバイスはすでにオープンされており、write() はそこに直接データを書き込むことができる。

注意: このポインタは、ストリームを停止した後や、別のストリームを開始した後には無効となる。

QAudioSink がシステムのオーディオ・デバイスにアクセスできた場合、state() はQtAudio::IdleState を返し、error() はQtAudio::NoError を返し、stateChanged() シグナルが発せられる。

この処理中に問題が発生した場合、error() はQtAudio::OpenError を返し、state() はQtAudio::StoppedState を返し、stateChanged() シグナルが発せられる。

QIODeviceも参照

void QAudioSink::start(QIODevice *device)

device からシステムのオーディオ出力へのオーディオ・データの転送を開始する。deviceReadOnly またはReadWrite モードでオープンされていなければならない。

QAudioSink が正常に音声データを出力できた場合、state() はQtAudio::ActiveState を返し、error() はQtAudio::NoError を返し、stateChanged() シグナルが発せられる。

この処理中に問題が発生した場合、error() はQtAudio::OpenError を返し、state() はQtAudio::StoppedState を返し、stateChanged() シグナルが発せられる。

QIODeviceも参照のこと

QtAudio::State QAudioSink::state() const

オーディオ処理の状態を返す。

[signal] void QAudioSink::stateChanged(QtAudio::State state)

このシグナルは、デバイスstate が変更されたときに発せられる。これはオーディオ出力の現在の状態です。

注意: Qt 6.6 までは、QtAudio 名前空間は QAudio という名前でした。このシグナルへの文字列ベースの接続は、パラメータタイプとしてQAudio::State を使用する必要があります:connect(source, SIGNAL(stateChanged(QAudio::State)), ...);

void QAudioSink::stop()

音声出力を停止し、システムリソースから切り離します。

error() をQtAudio::NoError に、state() をQtAudio::StoppedState に設定し、stateChanged() シグナルを発信します。

注: LinuxおよびDarwinでは、この操作は同期的に基礎となるオーディオ・バッファを流出させるため、バッファのペイロードに応じて遅延が発生する可能性があります。すべてのバッファを即座にリセットするには、代わりにreset

reset()も参照

void QAudioSink::suspend()

オーディオデータの処理を停止し、バッファリングされたオーディオデータを保持します。

error() をQtAudio::NoError に、state() をQtAudio::SuspendedState に設定し、stateChanged() シグナルを出力する。

qreal QAudioSink::volume() const

0.0 から 1.0 の間の音量を返します。

setVolume()も参照してください

©2024 The Qt Company Ltd. 本書に含まれる文書の著作権は、それぞれの所有者に帰属します。 本書で提供されるドキュメントは、Free Software Foundation が発行したGNU Free Documentation License version 1.3に基づいてライセンスされています。 Qtおよびそれぞれのロゴは、フィンランドおよびその他の国におけるThe Qt Company Ltd.の 商標です。その他すべての商標は、それぞれの所有者に帰属します。