我想使用QAudioRecorder
来录制用户的音频,然后将音频输出文件用于语音到文本。我可以成功运行和录制此示例中的音频http://doc.qt.io/qt-5/qtmultimedia-multimedia-audiorecorder-example.html。
但我的问题是,我需要检测用户是否在QAudioRecorder
正在主动录制音频时停止发言。所以QAudioRecorder
应该只在用户不说话时停止。
我可以使用QAudioRecorder
停止QTimer
固定秒数,如下所示:
void AudioRecorder::toggleRecord()
{
if (audioRecorder->state() == QMediaRecorder::StoppedState) {
audioRecorder->setAudioInput(boxValue(ui->audioDeviceBox).toString());
QAudioEncoderSettings settings;
settings.setCodec(boxValue(ui->audioCodecBox).toString());
settings.setSampleRate(boxValue(ui->sampleRateBox).toInt());
settings.setBitRate(boxValue(ui->bitrateBox).toInt());
settings.setChannelCount(boxValue(ui->channelsBox).toInt());
settings.setQuality(QMultimedia::EncodingQuality(ui->qualitySlider->value()));
settings.setEncodingMode(ui->constantQualityRadioButton->isChecked() ?
QMultimedia::ConstantQualityEncoding :
QMultimedia::ConstantBitRateEncoding);
QString container = boxValue(ui->containerBox).toString();
audioRecorder->setEncodingSettings(settings, QVideoEncoderSettings(), container);
audioRecorder->record();
this->recordTimeout();
}
else {
this->stopRecording();
}
}
void AudioRecorder::recordTimeout()
{
QTimer* mTimer = new QTimer(this);
mTimer->setSingleShot(true);
connect(mTimer, SIGNAL(timeout()), SLOT(stopRecording()));
mTimer->start(6000);
}
void AudioRecorder::stopRecording()
{
audioRecorder->stop();
}
但是,当用户不说话时,它应该停止录制。 QAudioProbe
类具有此信号audioBufferProbed(QAudioBuffer)
,这可能有助于检查音频级别但我不知道如何使用它以及可以使用什么级别来检测用户是否在说话。
答案 0 :(得分:0)
我一直试图或多或少地做同样的事情。有一个示例 - https://doc.qt.io/qt-5/qtdatavisualization-audiolevels-example.html向您展示如何实现一个应该有用的音频电平表。该示例使用QAudioInput
。具体来说,它使用QAudioInput::start(QIODevice * device)
并传递自定义QIODevice
来实现音频电平表。使用QAudioInput
的这种方法的问题是,一旦你获得了数据,就不容易对其进行编码并将其写入文件,而QAudioRecorder
则很简单。
无论如何...如果你想用QAudioProbe
录制简单的方法,那么你的权利QAudioRecorder
是最好的选择。我调整了Qt音频电平表示例以使用QAudioProbe
代替QAudioInput
/ QIODevice
。见 - https://gist.github.com/sam-at-github/bf66e84105cc3e23e7113cca5e3b1772。
关卡需要QAudioFormat
的一个小问题,但QAudioRecorder
只能为您提供QEncoderSettings
(应该修复使用后者的代码。我不知道为什么 QEncoderSettings
和QAudioFormat
都需要存在...)。您只需为使用的设备获取QAudioDeviceInfo
,然后使用QAudioDeviceInfo::preferredFormat()
。
相关帖子: Qt: API to write raw QAudioInput data to file just like QAudioRecorder