diff --git a/cdata.cpp b/cdata.cpp index 24cdccf33..3ab947a51 100644 --- a/cdata.cpp +++ b/cdata.cpp @@ -20,7 +20,7 @@ CData::CData(const QString &data, uint16_t byteSize) { - cData = new uint8_t[byteSize]; + cData = new uint8_t[byteSize+1]; cDataSize = fromString(data, cData); } diff --git a/core.cpp b/core.cpp index b9b343128..7261181a4 100644 --- a/core.cpp +++ b/core.cpp @@ -1116,8 +1116,13 @@ void Core::prepareCall(int friendId, int callId, ToxAv* toxav, bool videoEnabled // Go /// BUG: TODO: Memory corryption and crashes atexit when playCallAudio is threaded - if (calls[callId].audioOutput != nullptr) - calls[callId].playFuture = QtConcurrent::run(playCallAudio, callId, toxav); + //if (calls[callId].audioOutput != nullptr) + // calls[callId].playFuture = QtConcurrent::run(playCallAudio, callId, toxav); + + calls[callId].playAudioTimer.setInterval(5); + calls[callId].playAudioTimer.setSingleShot(true); + connect(&calls[callId].playAudioTimer, &QTimer::timeout, [=](){playCallAudio(callId,toxav);}); + calls[callId].playAudioTimer.start(); if (calls[callId].audioInput != nullptr) calls[callId].recordFuture = QtConcurrent::run(sendCallAudio, callId, toxav); calls[callId].active = true; @@ -1138,43 +1143,43 @@ void Core::cleanupCall(int callId) void Core::playCallAudio(int callId, ToxAv* toxav) { - while (calls[callId].active) + if (!calls[callId].active) + return; + int framesize = (calls[callId].codecSettings.audio_frame_duration * calls[callId].codecSettings.audio_sample_rate) / 1000; + uint8_t buf[framesize*2]; + int len = toxav_recv_audio(toxav, callId, framesize, (int16_t*)buf); + if (len < 0) { - int framesize = (calls[callId].codecSettings.audio_frame_duration * calls[callId].codecSettings.audio_sample_rate) / 1000; - uint8_t buf[framesize*2]; - int len = toxav_recv_audio(toxav, callId, framesize, (int16_t*)buf); - if (len < 0) + if (len == -3) // Not in call ! { - if (len == -3) // Not in call ! - { - qWarning("Core: Trying to play audio in an inactive call!"); - return; - } - qDebug() << QString("Core::playCallAudio: Error receiving audio: %1").arg(len); - QThread::msleep(5); - continue; + qWarning("Core: Trying to play audio in an inactive call!"); + return; } - if (len == 0) - { - QThread::msleep(5); /// BUG: Another thread crashed with corruption while we slept here - continue; - } - //qDebug() << QString("Core: Received %1 bytes, %2 audio bytes free, %3 core buffer size") - // .arg(len*2).arg(calls[callId].audioOutput->bytesFree()).arg(calls[callId].audioBuffer.bufferSize()); - calls[callId].audioBuffer.writeData((char*)buf, len*2); - int state = calls[callId].audioOutput->state(); - if (state != QAudio::ActiveState) - { - qDebug() << QString("Core: Audio state is %1").arg(state); - if (state == 3) - calls[callId].audioOutput->start(&calls[callId].audioBuffer); - } - int error = calls[callId].audioOutput->error(); - if (error != QAudio::NoError) - qWarning() << QString("Core::playCallAudio: Error: %1").arg(error); - - QThread::msleep(5); + qDebug() << QString("Core::playCallAudio: Error receiving audio: %1").arg(len); + calls[callId].playAudioTimer.start(); + return; } + if (len == 0) + { + calls[callId].playAudioTimer.start(); + return; + } + //qDebug() << QString("Core: Received %1 bytes, %2 audio bytes free, %3 core buffer size") + // .arg(len*2).arg(calls[callId].audioOutput->bytesFree()).arg(calls[callId].audioBuffer.bufferSize()); + calls[callId].audioBuffer.writeData((char*)buf, len*2); + int state = calls[callId].audioOutput->state(); + if (state != QAudio::ActiveState) + { + qDebug() << QString("Core: Audio state is %1").arg(state); + if (state == 3 && calls[callId].audioBuffer.bytesAvailable() >= framesize*2) + calls[callId].audioOutput->start(&calls[callId].audioBuffer); + } + int error = calls[callId].audioOutput->error(); + if (error != QAudio::NoError) + qWarning() << QString("Core::playCallAudio: Error: %1").arg(error); + + + calls[callId].playAudioTimer.start(); } void Core::sendCallAudio(int callId, ToxAv* toxav) diff --git a/core.h b/core.h index be7ebdd1b..8a5bf8a24 100644 --- a/core.h +++ b/core.h @@ -93,6 +93,7 @@ public: QAudioInput* audioInput; QIODevice* audioInputDevice; ToxAvCodecSettings codecSettings; + QTimer playAudioTimer, sendAudioTimer; int callId; int friendId; bool videoEnabled; diff --git a/main.cpp b/main.cpp index 84406c265..a0bc52ad0 100644 --- a/main.cpp +++ b/main.cpp @@ -1,11 +1,16 @@ #include "widget/widget.h" #include +#include int main(int argc, char *argv[]) { QApplication a(argc, argv); a.setApplicationName("Toxgui"); a.setOrganizationName("Tox"); + + // install Unicode 6.1 supporting font + QFontDatabase::addApplicationFont("://DejaVuSans.ttf"); + Widget* w = Widget::getInstance(); w->show(); diff --git a/res.qrc b/res.qrc index e56d4179e..cd4405d34 100644 --- a/res.qrc +++ b/res.qrc @@ -2,4 +2,7 @@ res/settings.ini + + res/DejaVuSans.ttf + diff --git a/res/DejaVuSans.ttf b/res/DejaVuSans.ttf new file mode 100644 index 000000000..9d40c3256 Binary files /dev/null and b/res/DejaVuSans.ttf differ