summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/imports/multimedia/qdeclarativeaudio.cpp2
-rw-r--r--src/imports/multimedia/qdeclarativecamerarecorder.cpp2
-rw-r--r--src/plugins/android/jar/jar.pri2
-rw-r--r--src/plugins/android/jar/src/org/qtproject/qt5/android/multimedia/QtSurfaceTextureListener.java (renamed from src/plugins/android/jar/src/org/qtproject/qt5/android/multimedia/QtSurfaceTexture.java)8
-rw-r--r--src/plugins/android/src/common/qandroidvideorendercontrol.cpp16
-rw-r--r--src/plugins/android/src/common/qandroidvideorendercontrol.h3
-rw-r--r--src/plugins/android/src/mediaplayer/qandroidmediaplayercontrol.cpp8
-rw-r--r--src/plugins/android/src/mediaplayer/qandroidmetadatareadercontrol.cpp7
-rw-r--r--src/plugins/android/src/qandroidmediaserviceplugin.cpp6
-rw-r--r--src/plugins/android/src/wrappers/jmediametadataretriever.cpp41
-rw-r--r--src/plugins/android/src/wrappers/jmediametadataretriever.h4
-rw-r--r--src/plugins/android/src/wrappers/jmultimediautils.cpp43
-rw-r--r--src/plugins/android/src/wrappers/jmultimediautils.h7
-rw-r--r--src/plugins/android/src/wrappers/jsurfacetexture.cpp83
-rw-r--r--src/plugins/android/src/wrappers/jsurfacetexture.h6
-rw-r--r--src/plugins/android/src/wrappers/wrappers.pri2
-rw-r--r--src/plugins/coreaudio/coreaudiodeviceinfo.mm6
-rw-r--r--src/plugins/coreaudio/coreaudioutils.mm2
-rw-r--r--src/plugins/gstreamer/mediaplayer/qgstreamerplayercontrol.cpp2
-rw-r--r--src/plugins/qnx/bbserviceplugin.cpp16
-rw-r--r--src/plugins/qnx/bbserviceplugin.h5
-rw-r--r--src/plugins/qnx/camera/bbcamerainfocontrol.cpp (renamed from src/plugins/android/src/wrappers/jsurfacetextureholder.cpp)42
-rw-r--r--src/plugins/qnx/camera/bbcamerainfocontrol.h (renamed from src/plugins/android/src/wrappers/jsurfacetextureholder.h)22
-rw-r--r--src/plugins/qnx/camera/bbcameraservice.cpp4
-rw-r--r--src/plugins/qnx/camera/bbcameraservice.h2
-rw-r--r--src/plugins/qnx/camera/bbvideodeviceselectorcontrol.cpp5
-rw-r--r--src/plugins/qnx/camera/bbvideodeviceselectorcontrol.h1
-rw-r--r--src/plugins/qnx/camera/camera.pri2
28 files changed, 213 insertions, 136 deletions
diff --git a/src/imports/multimedia/qdeclarativeaudio.cpp b/src/imports/multimedia/qdeclarativeaudio.cpp
index 589c45dae..16828a4d1 100644
--- a/src/imports/multimedia/qdeclarativeaudio.cpp
+++ b/src/imports/multimedia/qdeclarativeaudio.cpp
@@ -1188,7 +1188,7 @@ void QDeclarativeAudio::_q_statusChanged()
}
VideoOutput {
- anchors: parent.fill
+ anchors.fill: parent
source: mediaplayer
}
diff --git a/src/imports/multimedia/qdeclarativecamerarecorder.cpp b/src/imports/multimedia/qdeclarativecamerarecorder.cpp
index 0f4004677..896470b73 100644
--- a/src/imports/multimedia/qdeclarativecamerarecorder.cpp
+++ b/src/imports/multimedia/qdeclarativecamerarecorder.cpp
@@ -58,7 +58,7 @@ QT_BEGIN_NAMESPACE
settings and metadata for videos.
It should not be constructed separately, instead the
- \c videRecorder property of a \l Camera should be used.
+ \c videoRecorder property of a \l Camera should be used.
\qml
Camera {
diff --git a/src/plugins/android/jar/jar.pri b/src/plugins/android/jar/jar.pri
index 9e235144b..e56e3d966 100644
--- a/src/plugins/android/jar/jar.pri
+++ b/src/plugins/android/jar/jar.pri
@@ -7,7 +7,7 @@ JAVACLASSPATH += $$PWD/src
JAVASOURCES += $$PWD/src/org/qtproject/qt5/android/multimedia/QtAndroidMediaPlayer.java \
$$PWD/src/org/qtproject/qt5/android/multimedia/QtCamera.java \
- $$PWD/src/org/qtproject/qt5/android/multimedia/QtSurfaceTexture.java \
+ $$PWD/src/org/qtproject/qt5/android/multimedia/QtSurfaceTextureListener.java \
$$PWD/src/org/qtproject/qt5/android/multimedia/QtSurfaceTextureHolder.java \
$$PWD/src/org/qtproject/qt5/android/multimedia/QtMultimediaUtils.java \
$$PWD/src/org/qtproject/qt5/android/multimedia/QtMediaRecorder.java
diff --git a/src/plugins/android/jar/src/org/qtproject/qt5/android/multimedia/QtSurfaceTexture.java b/src/plugins/android/jar/src/org/qtproject/qt5/android/multimedia/QtSurfaceTextureListener.java
index 7632abd2d..00619b725 100644
--- a/src/plugins/android/jar/src/org/qtproject/qt5/android/multimedia/QtSurfaceTexture.java
+++ b/src/plugins/android/jar/src/org/qtproject/qt5/android/multimedia/QtSurfaceTextureListener.java
@@ -43,15 +43,13 @@ package org.qtproject.qt5.android.multimedia;
import android.graphics.SurfaceTexture;
-public class QtSurfaceTexture extends SurfaceTexture implements SurfaceTexture.OnFrameAvailableListener
+public class QtSurfaceTextureListener implements SurfaceTexture.OnFrameAvailableListener
{
- private int texID;
+ private final int texID;
- public QtSurfaceTexture(int texName)
+ public QtSurfaceTextureListener(int texName)
{
- super(texName);
texID = texName;
- setOnFrameAvailableListener(this);
}
@Override
diff --git a/src/plugins/android/src/common/qandroidvideorendercontrol.cpp b/src/plugins/android/src/common/qandroidvideorendercontrol.cpp
index b737e8a42..5f14a4691 100644
--- a/src/plugins/android/src/common/qandroidvideorendercontrol.cpp
+++ b/src/plugins/android/src/common/qandroidvideorendercontrol.cpp
@@ -42,7 +42,6 @@
#include "qandroidvideorendercontrol.h"
#include <QtCore/private/qjni_p.h>
-#include "jsurfacetextureholder.h"
#include <QAbstractVideoSurface>
#include <QVideoSurfaceFormat>
#include <qevent.h>
@@ -51,6 +50,7 @@
#include <qopenglfunctions.h>
#include <qopenglshaderprogram.h>
#include <qopenglframebufferobject.h>
+#include <QtCore/private/qjnihelpers_p.h>
QT_BEGIN_NAMESPACE
@@ -177,7 +177,7 @@ bool QAndroidVideoRendererControl::initSurfaceTexture()
m_surfaceTexture = new JSurfaceTexture(m_externalTex);
- if (m_surfaceTexture->isValid()) {
+ if (m_surfaceTexture->object()) {
connect(m_surfaceTexture, SIGNAL(frameAvailable()), this, SLOT(onFrameAvailable()));
} else {
delete m_surfaceTexture;
@@ -193,12 +193,12 @@ bool QAndroidVideoRendererControl::initSurfaceTexture()
void QAndroidVideoRendererControl::clearSurfaceTexture()
{
if (m_surfaceTexture) {
- m_surfaceTexture->callMethod<void>("release");
delete m_surfaceTexture;
m_surfaceTexture = 0;
}
if (m_androidSurface) {
- m_androidSurface->callMethod<void>("release");
+ if (QtAndroidPrivate::androidSdkVersion() > 13)
+ m_androidSurface->callMethod<void>("release");
delete m_androidSurface;
m_androidSurface = 0;
}
@@ -215,10 +215,12 @@ jobject QAndroidVideoRendererControl::surfaceHolder()
if (!m_surfaceHolder) {
m_androidSurface = new QJNIObjectPrivate("android/view/Surface",
- "(Landroid/graphics/SurfaceTexture;)V",
- m_surfaceTexture->object());
+ "(Landroid/graphics/SurfaceTexture;)V",
+ m_surfaceTexture->object());
- m_surfaceHolder = new JSurfaceTextureHolder(m_androidSurface->object());
+ m_surfaceHolder = new QJNIObjectPrivate("org/qtproject/qt5/android/multimedia/QtSurfaceTextureHolder",
+ "(Landroid/view/Surface;)V",
+ m_androidSurface->object());
}
return m_surfaceHolder->object();
diff --git a/src/plugins/android/src/common/qandroidvideorendercontrol.h b/src/plugins/android/src/common/qandroidvideorendercontrol.h
index 56407d5de..75fd7ef12 100644
--- a/src/plugins/android/src/common/qandroidvideorendercontrol.h
+++ b/src/plugins/android/src/common/qandroidvideorendercontrol.h
@@ -49,7 +49,6 @@
QT_BEGIN_NAMESPACE
-class JSurfaceTextureHolder;
class QOpenGLTexture;
class QOpenGLFramebufferObject;
class QOpenGLShaderProgram;
@@ -115,7 +114,7 @@ private:
QJNIObjectPrivate *m_androidSurface;
JSurfaceTexture *m_surfaceTexture;
- JSurfaceTextureHolder *m_surfaceHolder;
+ QJNIObjectPrivate *m_surfaceHolder;
quint32 m_externalTex;
QOpenGLFramebufferObject *m_fbo;
diff --git a/src/plugins/android/src/mediaplayer/qandroidmediaplayercontrol.cpp b/src/plugins/android/src/mediaplayer/qandroidmediaplayercontrol.cpp
index 4b836ddf4..f5614a57a 100644
--- a/src/plugins/android/src/mediaplayer/qandroidmediaplayercontrol.cpp
+++ b/src/plugins/android/src/mediaplayer/qandroidmediaplayercontrol.cpp
@@ -289,7 +289,9 @@ void QAndroidMediaPlayerControl::setMedia(const QMediaContent &mediaContent,
mMediaStream = stream;
}
- mMediaPlayer->release();
+ // Release the mediaplayer if it's not in in Idle or Uninitialized state
+ if ((mState & (JMediaPlayer::Idle | JMediaPlayer::Uninitialized)) == 0)
+ mMediaPlayer->release();
if (mediaContent.isNull()) {
setMediaStatus(QMediaPlayer::NoMedia);
@@ -510,8 +512,10 @@ void QAndroidMediaPlayerControl::onVideoSizeChanged(qint32 width, qint32 height)
void QAndroidMediaPlayerControl::onStateChanged(qint32 state)
{
// If reloading, don't report state changes unless the new state is Prepared or Error.
- if ((mState & JMediaPlayer::Stopped) && !(state & (JMediaPlayer::Prepared | JMediaPlayer::Error)))
+ if ((mState & JMediaPlayer::Stopped)
+ && (state & (JMediaPlayer::Prepared | JMediaPlayer::Error | JMediaPlayer::Uninitialized)) == 0) {
return;
+ }
mState = state;
switch (mState) {
diff --git a/src/plugins/android/src/mediaplayer/qandroidmetadatareadercontrol.cpp b/src/plugins/android/src/mediaplayer/qandroidmetadatareadercontrol.cpp
index b6ef6c4bc..dcc3dfbe0 100644
--- a/src/plugins/android/src/mediaplayer/qandroidmetadatareadercontrol.cpp
+++ b/src/plugins/android/src/mediaplayer/qandroidmetadatareadercontrol.cpp
@@ -74,13 +74,8 @@ static const char* qt_ID3GenreNames[] =
QAndroidMetaDataReaderControl::QAndroidMetaDataReaderControl(QObject *parent)
: QMetaDataReaderControl(parent)
, m_available(false)
- , m_retriever(0)
+ , m_retriever(new JMediaMetadataRetriever)
{
- m_retriever = new JMediaMetadataRetriever;
- if (!m_retriever->isValid()) {
- delete m_retriever;
- m_retriever = 0;
- }
}
QAndroidMetaDataReaderControl::~QAndroidMetaDataReaderControl()
diff --git a/src/plugins/android/src/qandroidmediaserviceplugin.cpp b/src/plugins/android/src/qandroidmediaserviceplugin.cpp
index 005def8cf..0af43210f 100644
--- a/src/plugins/android/src/qandroidmediaserviceplugin.cpp
+++ b/src/plugins/android/src/qandroidmediaserviceplugin.cpp
@@ -48,7 +48,6 @@
#include "qandroidcamerasession.h"
#include "jmediaplayer.h"
#include "jsurfacetexture.h"
-#include "jsurfacetextureholder.h"
#include "jcamera.h"
#include "jmultimediautils.h"
#include "jmediarecorder.h"
@@ -165,14 +164,13 @@ Q_DECL_EXPORT jint JNICALL JNI_OnLoad(JavaVM *vm, void * /*reserved*/)
JNIEnv *jniEnv = uenv.nativeEnvironment;
if (!JMediaPlayer::initJNI(jniEnv) ||
- !JSurfaceTexture::initJNI(jniEnv) ||
- !JSurfaceTextureHolder::initJNI(jniEnv) ||
!JCamera::initJNI(jniEnv) ||
- !JMultimediaUtils::initJNI(jniEnv) ||
!JMediaRecorder::initJNI(jniEnv)) {
return JNI_ERR;
}
+ JSurfaceTexture::initJNI(jniEnv);
+
return JNI_VERSION_1_4;
}
diff --git a/src/plugins/android/src/wrappers/jmediametadataretriever.cpp b/src/plugins/android/src/wrappers/jmediametadataretriever.cpp
index 91c40905c..93b77ecb1 100644
--- a/src/plugins/android/src/wrappers/jmediametadataretriever.cpp
+++ b/src/plugins/android/src/wrappers/jmediametadataretriever.cpp
@@ -47,8 +47,8 @@
QT_BEGIN_NAMESPACE
JMediaMetadataRetriever::JMediaMetadataRetriever()
- : QJNIObjectPrivate("android/media/MediaMetadataRetriever")
{
+ m_metadataRetriever = QJNIObjectPrivate("android/media/MediaMetadataRetriever");
}
JMediaMetadataRetriever::~JMediaMetadataRetriever()
@@ -59,9 +59,9 @@ QString JMediaMetadataRetriever::extractMetadata(MetadataKey key)
{
QString value;
- QJNIObjectPrivate metadata = callObjectMethod("extractMetadata",
- "(I)Ljava/lang/String;",
- jint(key));
+ QJNIObjectPrivate metadata = m_metadataRetriever.callObjectMethod("extractMetadata",
+ "(I)Ljava/lang/String;",
+ jint(key));
if (metadata.isValid())
value = metadata.toString();
@@ -70,28 +70,34 @@ QString JMediaMetadataRetriever::extractMetadata(MetadataKey key)
void JMediaMetadataRetriever::release()
{
- callMethod<void>("release");
+ if (!m_metadataRetriever.isValid())
+ return;
+
+ m_metadataRetriever.callMethod<void>("release");
}
bool JMediaMetadataRetriever::setDataSource(const QUrl &url)
{
+ if (!m_metadataRetriever.isValid())
+ return false;
+
QJNIEnvironmentPrivate env;
bool loaded = false;
QJNIObjectPrivate string = QJNIObjectPrivate::fromString(url.toString());
- QJNIObjectPrivate uri = callStaticObjectMethod("android/net/Uri",
- "parse",
- "(Ljava/lang/String;)Landroid/net/Uri;",
- string.object());
+ QJNIObjectPrivate uri = m_metadataRetriever.callStaticObjectMethod("android/net/Uri",
+ "parse",
+ "(Ljava/lang/String;)Landroid/net/Uri;",
+ string.object());
if (env->ExceptionCheck()) {
env->ExceptionClear();
} else {
- callMethod<void>("setDataSource",
- "(Landroid/content/Context;Landroid/net/Uri;)V",
- QtAndroidPrivate::activity(),
- uri.object());
+ m_metadataRetriever.callMethod<void>("setDataSource",
+ "(Landroid/content/Context;Landroid/net/Uri;)V",
+ QtAndroidPrivate::activity(),
+ uri.object());
if (env->ExceptionCheck())
env->ExceptionClear();
else
@@ -103,13 +109,16 @@ bool JMediaMetadataRetriever::setDataSource(const QUrl &url)
bool JMediaMetadataRetriever::setDataSource(const QString &path)
{
+ if (!m_metadataRetriever.isValid())
+ return false;
+
QJNIEnvironmentPrivate env;
bool loaded = false;
- callMethod<void>("setDataSource",
- "(Ljava/lang/String;)V",
- QJNIObjectPrivate::fromString(path).object());
+ m_metadataRetriever.callMethod<void>("setDataSource",
+ "(Ljava/lang/String;)V",
+ QJNIObjectPrivate::fromString(path).object());
if (env->ExceptionCheck())
env->ExceptionClear();
else
diff --git a/src/plugins/android/src/wrappers/jmediametadataretriever.h b/src/plugins/android/src/wrappers/jmediametadataretriever.h
index 7b22c955d..7b0340c0d 100644
--- a/src/plugins/android/src/wrappers/jmediametadataretriever.h
+++ b/src/plugins/android/src/wrappers/jmediametadataretriever.h
@@ -47,7 +47,7 @@
QT_BEGIN_NAMESPACE
-class JMediaMetadataRetriever : public QJNIObjectPrivate
+class JMediaMetadataRetriever
{
public:
enum MetadataKey {
@@ -84,6 +84,8 @@ public:
bool setDataSource(const QUrl &url);
bool setDataSource(const QString &path);
+private:
+ QJNIObjectPrivate m_metadataRetriever;
};
QT_END_NAMESPACE
diff --git a/src/plugins/android/src/wrappers/jmultimediautils.cpp b/src/plugins/android/src/wrappers/jmultimediautils.cpp
index a20d54477..d1b0830c7 100644
--- a/src/plugins/android/src/wrappers/jmultimediautils.cpp
+++ b/src/plugins/android/src/wrappers/jmultimediautils.cpp
@@ -45,51 +45,36 @@
QT_BEGIN_NAMESPACE
-static jclass g_qtMultimediaUtilsClass = 0;
-
-JMultimediaUtils::JMultimediaUtils()
- : QObject()
- , QJNIObjectPrivate(g_qtMultimediaUtilsClass)
-{
-}
void JMultimediaUtils::enableOrientationListener(bool enable)
{
- callStaticMethod<void>(g_qtMultimediaUtilsClass, "enableOrientationListener", "(Z)V", enable);
+ QJNIObjectPrivate::callStaticMethod<void>("org/qtproject/qt5/android/multimedia/QtMultimediaUtils",
+ "enableOrientationListener",
+ "(Z)V",
+ enable);
}
int JMultimediaUtils::getDeviceOrientation()
{
- return callStaticMethod<jint>(g_qtMultimediaUtilsClass, "getDeviceOrientation");
+ return QJNIObjectPrivate::callStaticMethod<jint>("org/qtproject/qt5/android/multimedia/QtMultimediaUtils",
+ "getDeviceOrientation");
}
QString JMultimediaUtils::getDefaultMediaDirectory(MediaType type)
{
- QJNIObjectPrivate path = callStaticObjectMethod(g_qtMultimediaUtilsClass,
- "getDefaultMediaDirectory",
- "(I)Ljava/lang/String;",
- jint(type));
+ QJNIObjectPrivate path = QJNIObjectPrivate::callStaticObjectMethod("org/qtproject/qt5/android/multimedia/QtMultimediaUtils",
+ "getDefaultMediaDirectory",
+ "(I)Ljava/lang/String;",
+ jint(type));
return path.toString();
}
void JMultimediaUtils::registerMediaFile(const QString &file)
{
- callStaticMethod<void>(g_qtMultimediaUtilsClass,
- "registerMediaFile",
- "(Ljava/lang/String;)V",
- QJNIObjectPrivate::fromString(file).object());
-}
-
-bool JMultimediaUtils::initJNI(JNIEnv *env)
-{
- jclass clazz = env->FindClass("org/qtproject/qt5/android/multimedia/QtMultimediaUtils");
- if (env->ExceptionCheck())
- env->ExceptionClear();
-
- if (clazz)
- g_qtMultimediaUtilsClass = static_cast<jclass>(env->NewGlobalRef(clazz));
-
- return true;
+ QJNIObjectPrivate::callStaticMethod<void>("org/qtproject/qt5/android/multimedia/QtMultimediaUtils",
+ "registerMediaFile",
+ "(Ljava/lang/String;)V",
+ QJNIObjectPrivate::fromString(file).object());
}
QT_END_NAMESPACE
diff --git a/src/plugins/android/src/wrappers/jmultimediautils.h b/src/plugins/android/src/wrappers/jmultimediautils.h
index 9896f7f31..b80ef4236 100644
--- a/src/plugins/android/src/wrappers/jmultimediautils.h
+++ b/src/plugins/android/src/wrappers/jmultimediautils.h
@@ -47,9 +47,8 @@
QT_BEGIN_NAMESPACE
-class JMultimediaUtils : public QObject, public QJNIObjectPrivate
+class JMultimediaUtils
{
- Q_OBJECT
public:
enum MediaType {
Music = 0,
@@ -58,14 +57,10 @@ public:
Sounds = 3
};
- JMultimediaUtils();
-
static void enableOrientationListener(bool enable);
static int getDeviceOrientation();
static QString getDefaultMediaDirectory(MediaType type);
static void registerMediaFile(const QString &file);
-
- static bool initJNI(JNIEnv *env);
};
QT_END_NAMESPACE
diff --git a/src/plugins/android/src/wrappers/jsurfacetexture.cpp b/src/plugins/android/src/wrappers/jsurfacetexture.cpp
index 47487f104..2b16ebd66 100644
--- a/src/plugins/android/src/wrappers/jsurfacetexture.cpp
+++ b/src/plugins/android/src/wrappers/jsurfacetexture.cpp
@@ -41,10 +41,11 @@
#include "jsurfacetexture.h"
#include <QtCore/private/qjni_p.h>
+#include <QtCore/private/qjnihelpers_p.h>
QT_BEGIN_NAMESPACE
-static jclass g_qtSurfaceTextureClass = 0;
+static jclass g_qtSurfaceTextureListenerClass = 0;
static QMap<int, JSurfaceTexture*> g_objectMap;
// native method for QtSurfaceTexture.java
@@ -57,37 +58,75 @@ static void notifyFrameAvailable(JNIEnv* , jobject, int id)
JSurfaceTexture::JSurfaceTexture(unsigned int texName)
: QObject()
- , QJNIObjectPrivate(g_qtSurfaceTextureClass, "(I)V", jint(texName))
, m_texID(int(texName))
{
- if (isValid())
- g_objectMap.insert(int(texName), this);
- else // If the class is not available, it means the Android version is < 3.0
+ // API level 11 or higher is required
+ if (QtAndroidPrivate::androidSdkVersion() < 11) {
qWarning("Camera preview and video playback require Android 3.0 (API level 11) or later.");
+ return;
+ }
+
+ QJNIEnvironmentPrivate env;
+ m_surfaceTexture = QJNIObjectPrivate("android/graphics/SurfaceTexture", "(I)V", jint(texName));
+ if (env->ExceptionCheck()) {
+#ifdef QT_DEBUG
+ env->ExceptionDescribe();
+#endif // QT_DEBUG
+ env->ExceptionClear();
+ }
+
+ if (m_surfaceTexture.isValid())
+ g_objectMap.insert(int(texName), this);
+
+ QJNIObjectPrivate listener(g_qtSurfaceTextureListenerClass, "(I)V", jint(texName));
+ m_surfaceTexture.callMethod<void>("setOnFrameAvailableListener",
+ "(Landroid/graphics/SurfaceTexture$OnFrameAvailableListener;)V",
+ listener.object());
}
JSurfaceTexture::~JSurfaceTexture()
{
- if (isValid())
+ if (m_surfaceTexture.isValid()) {
+ release();
g_objectMap.remove(m_texID);
+ }
}
QMatrix4x4 JSurfaceTexture::getTransformMatrix()
{
+ QMatrix4x4 matrix;
+ if (!m_surfaceTexture.isValid())
+ return matrix;
+
QJNIEnvironmentPrivate env;
- QMatrix4x4 matrix;
jfloatArray array = env->NewFloatArray(16);
- callMethod<void>("getTransformMatrix", "([F)V", array);
+ m_surfaceTexture.callMethod<void>("getTransformMatrix", "([F)V", array);
env->GetFloatArrayRegion(array, 0, 16, matrix.data());
env->DeleteLocalRef(array);
return matrix;
}
+void JSurfaceTexture::release()
+{
+ if (QtAndroidPrivate::androidSdkVersion() < 14)
+ return;
+
+ m_surfaceTexture.callMethod<void>("release");
+}
+
void JSurfaceTexture::updateTexImage()
{
- callMethod<void>("updateTexImage");
+ if (!m_surfaceTexture.isValid())
+ return;
+
+ m_surfaceTexture.callMethod<void>("updateTexImage");
+}
+
+jobject JSurfaceTexture::object()
+{
+ return m_surfaceTexture.object();
}
static JNINativeMethod methods[] = {
@@ -96,24 +135,20 @@ static JNINativeMethod methods[] = {
bool JSurfaceTexture::initJNI(JNIEnv *env)
{
- // SurfaceTexture is available since API 11, try to find it first before loading
- // our custom class
- jclass surfaceTextureClass = env->FindClass("android/graphics/SurfaceTexture");
+ // SurfaceTexture is available since API 11.
+ if (QtAndroidPrivate::androidSdkVersion() < 11)
+ return false;
+
+ jclass clazz = env->FindClass("org/qtproject/qt5/android/multimedia/QtSurfaceTextureListener");
if (env->ExceptionCheck())
env->ExceptionClear();
- if (surfaceTextureClass) {
- jclass clazz = env->FindClass("org/qtproject/qt5/android/multimedia/QtSurfaceTexture");
- if (env->ExceptionCheck())
- env->ExceptionClear();
-
- if (clazz) {
- g_qtSurfaceTextureClass = static_cast<jclass>(env->NewGlobalRef(clazz));
- if (env->RegisterNatives(g_qtSurfaceTextureClass,
- methods,
- sizeof(methods) / sizeof(methods[0])) < 0) {
- return false;
- }
+ if (clazz) {
+ g_qtSurfaceTextureListenerClass = static_cast<jclass>(env->NewGlobalRef(clazz));
+ if (env->RegisterNatives(g_qtSurfaceTextureListenerClass,
+ methods,
+ sizeof(methods) / sizeof(methods[0])) < 0) {
+ return false;
}
}
diff --git a/src/plugins/android/src/wrappers/jsurfacetexture.h b/src/plugins/android/src/wrappers/jsurfacetexture.h
index ea53b68ba..d53290a71 100644
--- a/src/plugins/android/src/wrappers/jsurfacetexture.h
+++ b/src/plugins/android/src/wrappers/jsurfacetexture.h
@@ -49,7 +49,7 @@
QT_BEGIN_NAMESPACE
-class JSurfaceTexture : public QObject, public QJNIObjectPrivate
+class JSurfaceTexture : public QObject
{
Q_OBJECT
public:
@@ -57,7 +57,10 @@ public:
~JSurfaceTexture();
int textureID() const { return m_texID; }
+ jobject object();
+
QMatrix4x4 getTransformMatrix();
+ void release(); // API level 14
void updateTexImage();
static bool initJNI(JNIEnv *env);
@@ -67,6 +70,7 @@ Q_SIGNALS:
private:
int m_texID;
+ QJNIObjectPrivate m_surfaceTexture;
};
QT_END_NAMESPACE
diff --git a/src/plugins/android/src/wrappers/wrappers.pri b/src/plugins/android/src/wrappers/wrappers.pri
index b2faa5b79..126cfd0c1 100644
--- a/src/plugins/android/src/wrappers/wrappers.pri
+++ b/src/plugins/android/src/wrappers/wrappers.pri
@@ -5,7 +5,6 @@ INCLUDEPATH += $$PWD
HEADERS += \
$$PWD/jmediaplayer.h \
$$PWD/jsurfacetexture.h \
- $$PWD/jsurfacetextureholder.h \
$$PWD/jmediametadataretriever.h \
$$PWD/jcamera.h \
$$PWD/jmultimediautils.h \
@@ -14,7 +13,6 @@ HEADERS += \
SOURCES += \
$$PWD/jmediaplayer.cpp \
$$PWD/jsurfacetexture.cpp \
- $$PWD/jsurfacetextureholder.cpp \
$$PWD/jmediametadataretriever.cpp \
$$PWD/jcamera.cpp \
$$PWD/jmultimediautils.cpp \
diff --git a/src/plugins/coreaudio/coreaudiodeviceinfo.mm b/src/plugins/coreaudio/coreaudiodeviceinfo.mm
index 74a692c10..56765cafd 100644
--- a/src/plugins/coreaudio/coreaudiodeviceinfo.mm
+++ b/src/plugins/coreaudio/coreaudiodeviceinfo.mm
@@ -110,7 +110,7 @@ QAudioFormat CoreAudioDeviceInfo::preferredFormat() const
}
}
- delete streams;
+ delete[] streams;
}
}
#else //iOS
@@ -180,7 +180,7 @@ QList<int> CoreAudioDeviceInfo::supportedSampleRates()
}
}
- delete vr;
+ delete[] vr;
}
}
#else //iOS
@@ -380,7 +380,7 @@ QList<QByteArray> CoreAudioDeviceInfo::availableDevices(QAudio::Mode mode)
}
}
- delete audioDevices;
+ delete[] audioDevices;
}
}
#else //iOS
diff --git a/src/plugins/coreaudio/coreaudioutils.mm b/src/plugins/coreaudio/coreaudioutils.mm
index d43303a1d..e626561d1 100644
--- a/src/plugins/coreaudio/coreaudioutils.mm
+++ b/src/plugins/coreaudio/coreaudioutils.mm
@@ -125,7 +125,7 @@ CoreAudioRingBuffer::CoreAudioRingBuffer(int bufferSize):
CoreAudioRingBuffer::~CoreAudioRingBuffer()
{
- delete m_buffer;
+ delete[] m_buffer;
}
CoreAudioRingBuffer::Region CoreAudioRingBuffer::acquireReadRegion(int size)
diff --git a/src/plugins/gstreamer/mediaplayer/qgstreamerplayercontrol.cpp b/src/plugins/gstreamer/mediaplayer/qgstreamerplayercontrol.cpp
index e028e6d7a..ff99aa3ff 100644
--- a/src/plugins/gstreamer/mediaplayer/qgstreamerplayercontrol.cpp
+++ b/src/plugins/gstreamer/mediaplayer/qgstreamerplayercontrol.cpp
@@ -630,7 +630,7 @@ void QGstreamerPlayerControl::popAndNotifyState()
if (m_stateStack.isEmpty()) {
if (m_currentState != oldState) {
#ifdef DEBUG_PLAYBIN
- qDebug() << "State changed:" << m_state;
+ qDebug() << "State changed:" << m_currentState;
#endif
emit stateChanged(m_currentState);
}
diff --git a/src/plugins/qnx/bbserviceplugin.cpp b/src/plugins/qnx/bbserviceplugin.cpp
index 2351e5730..a0eade602 100644
--- a/src/plugins/qnx/bbserviceplugin.cpp
+++ b/src/plugins/qnx/bbserviceplugin.cpp
@@ -40,7 +40,9 @@
****************************************************************************/
#include "bbserviceplugin.h"
+#include "bbcamerainfocontrol.h"
#include "bbcameraservice.h"
+#include "bbcamerasession.h"
#include "bbvideodeviceselectorcontrol.h"
#include "mmrenderermediaplayerservice.h"
@@ -120,8 +122,20 @@ void BbServicePlugin::updateDevices() const
if (m_cameraDevices.isEmpty()) {
qWarning() << "No camera devices found";
} else {
- m_defaultCameraDevice = m_cameraDevices.first();
+ m_defaultCameraDevice = m_cameraDevices.contains(BbCameraSession::cameraIdentifierRear())
+ ? BbCameraSession::cameraIdentifierRear()
+ : m_cameraDevices.first();
}
}
+QCamera::Position BbServicePlugin::cameraPosition(const QByteArray &device) const
+{
+ return BbCameraInfoControl::position(device);
+}
+
+int BbServicePlugin::cameraOrientation(const QByteArray &device) const
+{
+ return BbCameraInfoControl::orientation(device);
+}
+
QT_END_NAMESPACE
diff --git a/src/plugins/qnx/bbserviceplugin.h b/src/plugins/qnx/bbserviceplugin.h
index 45ea4cc6f..f6a20b8f0 100644
--- a/src/plugins/qnx/bbserviceplugin.h
+++ b/src/plugins/qnx/bbserviceplugin.h
@@ -49,11 +49,13 @@ class BbServicePlugin
: public QMediaServiceProviderPlugin,
public QMediaServiceSupportedDevicesInterface,
public QMediaServiceDefaultDeviceInterface,
+ public QMediaServiceCameraInfoInterface,
public QMediaServiceFeaturesInterface
{
Q_OBJECT
Q_INTERFACES(QMediaServiceSupportedDevicesInterface)
Q_INTERFACES(QMediaServiceDefaultDeviceInterface)
+ Q_INTERFACES(QMediaServiceCameraInfoInterface)
Q_INTERFACES(QMediaServiceFeaturesInterface)
Q_PLUGIN_METADATA(IID "org.qt-project.qt.mediaserviceproviderfactory/5.0" FILE "blackberry_mediaservice.json")
public:
@@ -68,6 +70,9 @@ public:
QString deviceDescription(const QByteArray &service, const QByteArray &device) Q_DECL_OVERRIDE;
QVariant deviceProperty(const QByteArray &service, const QByteArray &device, const QByteArray &property) Q_DECL_OVERRIDE;
+ QCamera::Position cameraPosition(const QByteArray &device) const Q_DECL_OVERRIDE;
+ int cameraOrientation(const QByteArray &device) const Q_DECL_OVERRIDE;
+
private:
void updateDevices() const;
diff --git a/src/plugins/android/src/wrappers/jsurfacetextureholder.cpp b/src/plugins/qnx/camera/bbcamerainfocontrol.cpp
index b6d1433d1..366495dd5 100644
--- a/src/plugins/android/src/wrappers/jsurfacetextureholder.cpp
+++ b/src/plugins/qnx/camera/bbcamerainfocontrol.cpp
@@ -1,6 +1,6 @@
/****************************************************************************
**
-** Copyright (C) 2013 Digia Plc and/or its subsidiary(-ies).
+** Copyright (C) 2014 Digia Plc and/or its subsidiary(-ies).
** Contact: http://www.qt-project.org/legal
**
** This file is part of the Qt Toolkit.
@@ -39,27 +39,45 @@
**
****************************************************************************/
-#include "jsurfacetextureholder.h"
+#include "bbcamerainfocontrol.h"
+
+#include "bbcamerasession.h"
QT_BEGIN_NAMESPACE
-static jclass g_qtSurfaceTextureHolderClass = 0;
+BbCameraInfoControl::BbCameraInfoControl(QObject *parent)
+ : QCameraInfoControl(parent)
+{
+}
-JSurfaceTextureHolder::JSurfaceTextureHolder(jobject surface)
- : QJNIObjectPrivate(g_qtSurfaceTextureHolderClass, "(Landroid/view/Surface;)V", surface)
+QCamera::Position BbCameraInfoControl::position(const QString &deviceName)
{
+ if (deviceName == QString::fromUtf8(BbCameraSession::cameraIdentifierFront()))
+ return QCamera::FrontFace;
+ else if (deviceName == QString::fromUtf8(BbCameraSession::cameraIdentifierRear()))
+ return QCamera::BackFace;
+ else
+ return QCamera::UnspecifiedPosition;
}
-bool JSurfaceTextureHolder::initJNI(JNIEnv *env)
+int BbCameraInfoControl::orientation(const QString &deviceName)
{
- jclass clazz = env->FindClass("org/qtproject/qt5/android/multimedia/QtSurfaceTextureHolder");
- if (env->ExceptionCheck())
- env->ExceptionClear();
+ // The camera sensor orientation could be retrieved with camera_get_native_orientation()
+ // but since the sensor angular offset is compensated with camera_set_videovf_property() and
+ // camera_set_photovf_property() we should always return 0 here.
+ Q_UNUSED(deviceName);
+ return 0;
+}
- if (clazz)
- g_qtSurfaceTextureHolderClass = static_cast<jclass>(env->NewGlobalRef(clazz));
+QCamera::Position BbCameraInfoControl::cameraPosition(const QString &deviceName) const
+{
+ return position(deviceName);
+}
- return true;
+int BbCameraInfoControl::cameraOrientation(const QString &deviceName) const
+{
+ return orientation(deviceName);
}
QT_END_NAMESPACE
+
diff --git a/src/plugins/android/src/wrappers/jsurfacetextureholder.h b/src/plugins/qnx/camera/bbcamerainfocontrol.h
index 556cb4a40..a083bbf35 100644
--- a/src/plugins/android/src/wrappers/jsurfacetextureholder.h
+++ b/src/plugins/qnx/camera/bbcamerainfocontrol.h
@@ -1,6 +1,6 @@
/****************************************************************************
**
-** Copyright (C) 2013 Digia Plc and/or its subsidiary(-ies).
+** Copyright (C) 2014 Digia Plc and/or its subsidiary(-ies).
** Contact: http://www.qt-project.org/legal
**
** This file is part of the Qt Toolkit.
@@ -39,21 +39,27 @@
**
****************************************************************************/
-#ifndef JSURFACETEXTUREHOLDER_H
-#define JSURFACETEXTUREHOLDER_H
+#ifndef BBCAMERAINFOCONTROL_H
+#define BBCAMERAINFOCONTROL_H
-#include <QtCore/private/qjni_p.h>
+#include <qcamerainfocontrol.h>
QT_BEGIN_NAMESPACE
-class JSurfaceTextureHolder : public QJNIObjectPrivate
+class BbCameraInfoControl : public QCameraInfoControl
{
+ Q_OBJECT
public:
- JSurfaceTextureHolder(jobject surface);
+ explicit BbCameraInfoControl(QObject *parent = 0);
- static bool initJNI(JNIEnv *env);
+ QCamera::Position cameraPosition(const QString &deviceName) const;
+ int cameraOrientation(const QString &deviceName) const;
+
+ static QCamera::Position position(const QString &deviceName);
+ static int orientation(const QString &deviceName);
};
QT_END_NAMESPACE
-#endif // JSURFACETEXTUREHOLDER_H
+#endif // BBCAMERAINFOCONTROL_H
+
diff --git a/src/plugins/qnx/camera/bbcameraservice.cpp b/src/plugins/qnx/camera/bbcameraservice.cpp
index d9adc7c9d..98feee5a1 100644
--- a/src/plugins/qnx/camera/bbcameraservice.cpp
+++ b/src/plugins/qnx/camera/bbcameraservice.cpp
@@ -49,6 +49,7 @@
#include "bbcamerafocuscontrol.h"
#include "bbcameraimagecapturecontrol.h"
#include "bbcameraimageprocessingcontrol.h"
+#include "bbcamerainfocontrol.h"
#include "bbcameralockscontrol.h"
#include "bbcameramediarecordercontrol.h"
#include "bbcamerasession.h"
@@ -76,6 +77,7 @@ BbCameraService::BbCameraService(QObject *parent)
, m_cameraFocusControl(new BbCameraFocusControl(m_cameraSession, this))
, m_cameraImageCaptureControl(new BbCameraImageCaptureControl(m_cameraSession, this))
, m_cameraImageProcessingControl(new BbCameraImageProcessingControl(m_cameraSession, this))
+ , m_cameraInfoControl(new BbCameraInfoControl(this))
, m_cameraLocksControl(new BbCameraLocksControl(m_cameraSession, this))
, m_cameraMediaRecorderControl(new BbCameraMediaRecorderControl(m_cameraSession, this))
, m_cameraVideoEncoderSettingsControl(new BbCameraVideoEncoderSettingsControl(m_cameraSession, this))
@@ -101,6 +103,8 @@ QMediaControl* BbCameraService::requestControl(const char *name)
return m_cameraCaptureDestinationControl;
else if (qstrcmp(name, QCameraControl_iid) == 0)
return m_cameraControl;
+ else if (qstrcmp(name, QCameraInfoControl_iid) == 0)
+ return m_cameraInfoControl;
else if (qstrcmp(name, QCameraExposureControl_iid) == 0)
return m_cameraExposureControl;
else if (qstrcmp(name, QCameraFlashControl_iid) == 0)
diff --git a/src/plugins/qnx/camera/bbcameraservice.h b/src/plugins/qnx/camera/bbcameraservice.h
index 374d03c36..f87dd0ab0 100644
--- a/src/plugins/qnx/camera/bbcameraservice.h
+++ b/src/plugins/qnx/camera/bbcameraservice.h
@@ -56,6 +56,7 @@ class BbCameraFlashControl;
class BbCameraFocusControl;
class BbCameraImageCaptureControl;
class BbCameraImageProcessingControl;
+class BbCameraInfoControl;
class BbCameraLocksControl;
class BbCameraMediaRecorderControl;
class BbCameraSession;
@@ -89,6 +90,7 @@ private:
BbCameraFocusControl* m_cameraFocusControl;
BbCameraImageCaptureControl* m_cameraImageCaptureControl;
BbCameraImageProcessingControl* m_cameraImageProcessingControl;
+ BbCameraInfoControl* m_cameraInfoControl;
BbCameraLocksControl* m_cameraLocksControl;
BbCameraMediaRecorderControl* m_cameraMediaRecorderControl;
BbCameraVideoEncoderSettingsControl* m_cameraVideoEncoderSettingsControl;
diff --git a/src/plugins/qnx/camera/bbvideodeviceselectorcontrol.cpp b/src/plugins/qnx/camera/bbvideodeviceselectorcontrol.cpp
index 6a6e9d3cd..f0221e10b 100644
--- a/src/plugins/qnx/camera/bbvideodeviceselectorcontrol.cpp
+++ b/src/plugins/qnx/camera/bbvideodeviceselectorcontrol.cpp
@@ -49,6 +49,7 @@ QT_BEGIN_NAMESPACE
BbVideoDeviceSelectorControl::BbVideoDeviceSelectorControl(BbCameraSession *session, QObject *parent)
: QVideoDeviceSelectorControl(parent)
, m_session(session)
+ , m_default(0)
, m_selected(0)
{
enumerateDevices(&m_devices, &m_descriptions);
@@ -56,7 +57,7 @@ BbVideoDeviceSelectorControl::BbVideoDeviceSelectorControl(BbCameraSession *sess
// pre-select the rear camera
const int index = m_devices.indexOf(BbCameraSession::cameraIdentifierRear());
if (index != -1)
- m_selected = index;
+ m_default = m_selected = index;
}
int BbVideoDeviceSelectorControl::deviceCount() const
@@ -82,7 +83,7 @@ QString BbVideoDeviceSelectorControl::deviceDescription(int index) const
int BbVideoDeviceSelectorControl::defaultDevice() const
{
- return 0;
+ return m_default;
}
int BbVideoDeviceSelectorControl::selectedDevice() const
diff --git a/src/plugins/qnx/camera/bbvideodeviceselectorcontrol.h b/src/plugins/qnx/camera/bbvideodeviceselectorcontrol.h
index 1987f5491..24396154a 100644
--- a/src/plugins/qnx/camera/bbvideodeviceselectorcontrol.h
+++ b/src/plugins/qnx/camera/bbvideodeviceselectorcontrol.h
@@ -71,6 +71,7 @@ private:
QList<QByteArray> m_devices;
QStringList m_descriptions;
+ int m_default;
int m_selected;
};
diff --git a/src/plugins/qnx/camera/camera.pri b/src/plugins/qnx/camera/camera.pri
index 6665573b0..7e5fbeb34 100644
--- a/src/plugins/qnx/camera/camera.pri
+++ b/src/plugins/qnx/camera/camera.pri
@@ -10,6 +10,7 @@ HEADERS += \
$$PWD/bbcamerafocuscontrol.h \
$$PWD/bbcameraimagecapturecontrol.h \
$$PWD/bbcameraimageprocessingcontrol.h \
+ $$PWD/bbcamerainfocontrol.h \
$$PWD/bbcameralockscontrol.h \
$$PWD/bbcameramediarecordercontrol.h \
$$PWD/bbcameraorientationhandler.h \
@@ -33,6 +34,7 @@ SOURCES += \
$$PWD/bbcamerafocuscontrol.cpp \
$$PWD/bbcameraimagecapturecontrol.cpp \
$$PWD/bbcameraimageprocessingcontrol.cpp \
+ $$PWD/bbcamerainfocontrol.cpp \
$$PWD/bbcameralockscontrol.cpp \
$$PWD/bbcameramediarecordercontrol.cpp \
$$PWD/bbcameraorientationhandler.cpp \