From f97729261a3abc27891843d933fc02eb079db391 Mon Sep 17 00:00:00 2001 From: "Tux3 / Mlkj / !Lev.uXFMLA" Date: Sat, 30 Aug 2014 15:15:23 +0200 Subject: [PATCH] Clean & remove old code and dependencies We don't use QtMultimedia and OpenCV_imgproc anymore Fixes #218 --- core.cpp | 2 + core.h | 6 +-- coreav.cpp | 1 + friendlist.cpp | 1 + qtox.pro | 8 ++- widget/camera.cpp | 3 -- widget/friendlistwidget.cpp | 1 + widget/selfcamview.cpp | 4 -- widget/videosurface.cpp | 103 ------------------------------------ widget/videosurface.h | 42 --------------- widget/widget.cpp | 17 +++++- 11 files changed, 25 insertions(+), 163 deletions(-) delete mode 100644 widget/videosurface.cpp delete mode 100644 widget/videosurface.h diff --git a/core.cpp b/core.cpp index 4709a3ee8..9c76975b0 100644 --- a/core.cpp +++ b/core.cpp @@ -78,6 +78,8 @@ Core::Core(Camera* cam, QThread *coreThread) : qWarning() << "Core: Cannot create output audio context"; alcCloseDevice(alOutDev); } + else + alGenSources(1, &alMainSource); } alInDev = alcCaptureOpenDevice(NULL,av_DefaultSettings.audio_sample_rate, AL_FORMAT_MONO16, (av_DefaultSettings.audio_frame_duration * av_DefaultSettings.audio_sample_rate * 4) / 1000); diff --git a/core.h b/core.h index 32c34c39d..d94f65473 100644 --- a/core.h +++ b/core.h @@ -31,10 +31,6 @@ #include #include #include -#include -#include -#include -#include #define TOXAV_MAX_CALLS 16 #define GROUPCHAT_MAX_SIZE 32 @@ -304,6 +300,8 @@ private: static ALCdevice* alOutDev, *alInDev; static ALCcontext* alContext; +public: + static ALuint alMainSource; }; #endif // CORE_HPP diff --git a/coreav.cpp b/coreav.cpp index cb4a518be..2b18e37d4 100644 --- a/coreav.cpp +++ b/coreav.cpp @@ -8,6 +8,7 @@ int Core::videoBusyness; ALCdevice* Core::alOutDev, *Core::alInDev; ALCcontext* Core::alContext; +ALuint Core::alMainSource; void Core::prepareCall(int friendId, int callId, ToxAv* toxav, bool videoEnabled) { diff --git a/friendlist.cpp b/friendlist.cpp index 08ecb903d..6547c408c 100644 --- a/friendlist.cpp +++ b/friendlist.cpp @@ -17,6 +17,7 @@ #include "friend.h" #include "friendlist.h" #include +#include QList FriendList::friendList; diff --git a/qtox.pro b/qtox.pro index 9a38dccda..26cb6e0f1 100644 --- a/qtox.pro +++ b/qtox.pro @@ -20,7 +20,7 @@ # See the COPYING file for more details. -QT += core gui network multimedia multimediawidgets xml +QT += core gui network xml greaterThan(QT_MAJOR_VERSION, 4): QT += widgets TARGET = qtox @@ -43,9 +43,9 @@ INCLUDEPATH += libs/include win32 { LIBS += $$PWD/libs/lib/libtoxav.a $$PWD/libs/lib/libopus.a $$PWD/libs/lib/libvpx.a $$PWD/libs/lib/libopenal32.a $$PWD/libs/lib/libtoxcore.a -lws2_32 $$PWD/libs/lib/libsodium.a -lpthread -liphlpapi } macx { - LIBS += -L$$PWD/libs/lib/ -ltoxcore -ltoxav -lsodium -lvpx -framework OpenAL -lopencv_core -lopencv_highgui -lopencv_imgproc + LIBS += -L$$PWD/libs/lib/ -ltoxcore -ltoxav -lsodium -lvpx -framework OpenAL -lopencv_core -lopencv_highgui } else { - LIBS += -L$$PWD/libs/lib/ -ltoxcore -ltoxav -lsodium -lvpx -lopenal -lopencv_core -lopencv_highgui -lopencv_imgproc + LIBS += -L$$PWD/libs/lib/ -ltoxcore -ltoxav -lsodium -lvpx -lopenal -lopencv_core -lopencv_highgui } #### Static linux build @@ -82,7 +82,6 @@ HEADERS += widget/form/addfriendform.h \ cdata.h \ cstring.h \ widget/selfcamview.h \ - widget/videosurface.h \ widget/camera.h \ widget/netcamview.h \ widget/tool/clickablelabel.h \ @@ -119,7 +118,6 @@ SOURCES += \ cdata.cpp \ cstring.cpp \ widget/selfcamview.cpp \ - widget/videosurface.cpp \ widget/camera.cpp \ widget/netcamview.cpp \ widget/tool/clickablelabel.cpp \ diff --git a/widget/camera.cpp b/widget/camera.cpp index 600376035..e4a6010c7 100644 --- a/widget/camera.cpp +++ b/widget/camera.cpp @@ -15,10 +15,7 @@ */ #include "camera.h" -#include #include -#include -#include using namespace cv; diff --git a/widget/friendlistwidget.cpp b/widget/friendlistwidget.cpp index 1792e00c5..aced0f297 100644 --- a/widget/friendlistwidget.cpp +++ b/widget/friendlistwidget.cpp @@ -14,6 +14,7 @@ See the COPYING file for more details. */ #include "friendlistwidget.h" +#include FriendListWidget::FriendListWidget(QWidget *parent) : QWidget(parent) diff --git a/widget/selfcamview.cpp b/widget/selfcamview.cpp index 74cd18a39..2d46e99bb 100644 --- a/widget/selfcamview.cpp +++ b/widget/selfcamview.cpp @@ -15,13 +15,9 @@ */ #include "selfcamview.h" -#include -#include #include #include -#include -#include "videosurface.h" #include "widget.h" using namespace cv; diff --git a/widget/videosurface.cpp b/widget/videosurface.cpp deleted file mode 100644 index 68ec9ff49..000000000 --- a/widget/videosurface.cpp +++ /dev/null @@ -1,103 +0,0 @@ -/* - Copyright (C) 2014 by Project Tox - - This file is part of qTox, a Qt-based graphical interface for Tox. - - This program is libre software: you can redistribute it and/or modify - it under the terms of the GNU General Public License as published by - the Free Software Foundation, either version 3 of the License, or - (at your option) any later version. - This program is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. - - See the COPYING file for more details. -*/ - -#include "videosurface.h" -#include "core.h" -#include -#include - -VideoSurface::VideoSurface() - : QAbstractVideoSurface() -{ - vpx_img_alloc(&input, VPX_IMG_FMT_YV12, TOXAV_MAX_VIDEO_WIDTH, TOXAV_MAX_VIDEO_HEIGHT, 1); -} - -bool VideoSurface::start(const QVideoSurfaceFormat &format) -{ - mVideoFormat = format; - //start only if format is UYVY, dont handle other format now - if( format.pixelFormat() == QVideoFrame::Format_YV12 ){ - QAbstractVideoSurface::start(format); - return true; - } else { - return false; - } -} - -bool VideoSurface::present(const QVideoFrame&) -{ - /* - mFrame = frame; - - qDebug() << QString("Video: Frame format is %1").arg(mFrame.pixelFormat()); - - stop(); - - //this is necessary to get valid data from frame - mFrame.map(QAbstractVideoBuffer::ReadOnly); - - uchar* data = new uchar[frame.mappedBytes()]; - memcpy(data, frame.bits(), frame.mappedBytes()); - - input.planes[VPX_PLANE_Y] = data; - input.planes[VPX_PLANE_U] = data + (frame.bytesPerLine() * frame.height()); - input.planes[VPX_PLANE_V] = input.planes[VPX_PLANE_U] + (frame.bytesPerLine()/2 * frame.height()/2); - input.planes[VPX_PLANE_ALPHA] = nullptr; - - //qDebug() << QString("Got %1 bytes, first plane is %2 bytes long") - // .arg(frame.mappedBytes()).arg(frame.bytesPerLine() * frame.height()); - - // Slots MUST be called with a direct or blocking connection, or input may die before they return ! - emit videoFrameReady(input); - - - QImage lastImage( mFrame.size(), QImage::Format_RGB16); - const uchar *src = mFrame.bits(); - uchar *dst = lastImage.bits(); - const int srcLineStep = mFrame.bytesPerLine(); - const int dstLineStep = lastImage.bytesPerLine(); - const int h = mFrame.height(); - const int w = mFrame.width(); - - for (int y=0; y < h; y++) { - //this function you can find in qgraphicsvideoitem_maemo5.cpp, - //link is mentioned above - uyvy422_to_rgb16_line_neon(dst, src, w); - src += srcLineStep; - dst += dstLineStep; - } - - mLastFrame = QPixmap::fromImage(lastImage); - //emit signal, other can handle it and do necessary processing - emit frameUpdated(mLastFrame); - - delete[] data; - mFrame.unmap(); - -*/ - return true; -} - -QList VideoSurface::supportedPixelFormats(QAbstractVideoBuffer::HandleType handleType) const -{ - if (handleType == QAbstractVideoBuffer::NoHandle) { - qDebug() << "Video: No handle"; - return QList() << QVideoFrame::Format_YV12; - } else { - qDebug() << "Video: Handle type is not NoHandle"; - return QList(); - } -} diff --git a/widget/videosurface.h b/widget/videosurface.h deleted file mode 100644 index c93ed2c8f..000000000 --- a/widget/videosurface.h +++ /dev/null @@ -1,42 +0,0 @@ -/* - Copyright (C) 2014 by Project Tox - - This file is part of qTox, a Qt-based graphical interface for Tox. - - This program is libre software: you can redistribute it and/or modify - it under the terms of the GNU General Public License as published by - the Free Software Foundation, either version 3 of the License, or - (at your option) any later version. - This program is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. - - See the COPYING file for more details. -*/ - -#ifndef VIDEOSURFACE_H -#define VIDEOSURFACE_H - -#include -#include -#include "vpx/vpx_image.h" - -class VideoSurface : public QAbstractVideoSurface -{ - Q_OBJECT -public: - VideoSurface(); - bool start(const QVideoSurfaceFormat &format); - bool present(const QVideoFrame &frame); - QList supportedPixelFormats(QAbstractVideoBuffer::HandleType handleType) const; - -signals: - // Slots MUST be called with a direct or blocking connection, or img may die before they return ! - void videoFrameReady(vpx_image img); - -private: - QVideoSurfaceFormat mVideoFormat; - vpx_image_t input; -}; - -#endif // VIDEOSURFACE_H diff --git a/widget/widget.cpp b/widget/widget.cpp index 58a1724dc..cfba03b09 100644 --- a/widget/widget.cpp +++ b/widget/widget.cpp @@ -28,7 +28,6 @@ #include "style.h" #include #include -#include #include #include #include @@ -569,7 +568,21 @@ void Widget::updateFriendStatusLights(int friendId) void Widget::newMessageAlert() { QApplication::alert(this); - QSound::play(":audio/notification.wav"); + + static QFile sndFile(":audio/notification.wav"); + static QByteArray sndData; + if (sndData.isEmpty()) + { + sndFile.open(QIODevice::ReadOnly); + sndData = sndFile.readAll(); + sndFile.close(); + } + + ALuint buffer; + alGenBuffers(1, &buffer); + alBufferData(buffer, AL_FORMAT_STEREO16, sndData.data(), sndData.size(), 44100); + alSourcei(core->alMainSource, AL_BUFFER, buffer); + alSourcePlay(core->alMainSource); } void Widget::onFriendRequestReceived(const QString& userId, const QString& message)