aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCory Fields <theuni-nospam-@xbmc.org>2013-08-08 20:48:55 -0400
committerCory Fields <theuni-nospam-@xbmc.org>2013-08-08 21:01:51 -0400
commit433f3560ef11f791993d74762e0180da1156908c (patch)
treee0de978a6d4bab6b512b5a3be8beaae8e67946d6
parent2a6328dd2a2ba2d35aa9551228d01490cb80fcb8 (diff)
jni: add new classes
-rw-r--r--xbmc/android/jni/Buffer.cpp129
-rw-r--r--xbmc/android/jni/Buffer.h48
-rw-r--r--xbmc/android/jni/Build.cpp74
-rw-r--r--xbmc/android/jni/Build.h55
-rw-r--r--xbmc/android/jni/ByteBuffer.cpp189
-rw-r--r--xbmc/android/jni/ByteBuffer.h57
-rw-r--r--xbmc/android/jni/Makefile.in11
-rw-r--r--xbmc/android/jni/MediaCodec.cpp248
-rw-r--r--xbmc/android/jni/MediaCodec.h79
-rw-r--r--xbmc/android/jni/MediaCodecBufferInfo.cpp60
-rw-r--r--xbmc/android/jni/MediaCodecBufferInfo.h35
-rw-r--r--xbmc/android/jni/MediaCodecCryptoInfo.cpp127
-rw-r--r--xbmc/android/jni/MediaCodecCryptoInfo.h45
-rw-r--r--xbmc/android/jni/MediaCodecInfo.cpp349
-rw-r--r--xbmc/android/jni/MediaCodecInfo.h203
-rw-r--r--xbmc/android/jni/MediaCodecList.cpp41
-rw-r--r--xbmc/android/jni/MediaCodecList.h38
-rw-r--r--xbmc/android/jni/MediaCrypto.h29
-rw-r--r--xbmc/android/jni/MediaFormat.cpp166
-rw-r--r--xbmc/android/jni/MediaFormat.h68
-rw-r--r--xbmc/android/jni/View.cpp131
-rw-r--r--xbmc/android/jni/View.h76
-rw-r--r--xbmc/android/jni/Window.cpp32
-rw-r--r--xbmc/android/jni/Window.h32
24 files changed, 2322 insertions, 0 deletions
diff --git a/xbmc/android/jni/Buffer.cpp b/xbmc/android/jni/Buffer.cpp
new file mode 100644
index 0000000000..868989405a
--- /dev/null
+++ b/xbmc/android/jni/Buffer.cpp
@@ -0,0 +1,129 @@
+/*
+ * Copyright (C) 2013 Team XBMC
+ * http://www.xbmc.org
+ *
+ * This Program is free 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 2, 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
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with XBMC; see the file COPYING. If not, see
+ * <http://www.gnu.org/licenses/>.
+ *
+ */
+
+#include "Buffer.h"
+#include "jutils/jutils-details.hpp"
+
+using namespace jni;
+
+int CJNIBuffer::capacity()
+{
+ return call_method<int>(m_object,
+ "capacity", "()I");
+}
+
+int CJNIBuffer::position()
+{
+ return call_method<int>(m_object,
+ "position", "()I");
+}
+
+CJNIBuffer CJNIBuffer::position(int newPosition)
+{
+ return call_method<jhobject>(m_object,
+ "position", "(I)Ljava/nio/Buffer;",
+ newPosition);
+}
+
+int CJNIBuffer::limit()
+{
+ return call_method<int>(m_object,
+ "limit", "()I");
+}
+
+CJNIBuffer CJNIBuffer::limit(int newLimit)
+{
+ return call_method<jhobject>(m_object,
+ "limit", "(I)Ljava/nio/Buffer;",
+ newLimit);
+}
+
+CJNIBuffer CJNIBuffer::mark()
+{
+ return call_method<jhobject>(m_object,
+ "mark", "()Ljava/nio/Buffer;");
+}
+
+CJNIBuffer CJNIBuffer::reset()
+{
+ return call_method<jhobject>(m_object,
+ "reset", "()Ljava/nio/Buffer;");
+}
+
+CJNIBuffer CJNIBuffer::clear()
+{
+ return call_method<jhobject>(m_object,
+ "clear", "()Ljava/nio/Buffer;");
+}
+
+CJNIBuffer CJNIBuffer::flip()
+{
+ return call_method<jhobject>(m_object,
+ "flip", "()Ljava/nio/Buffer;");
+}
+
+CJNIBuffer CJNIBuffer::rewind()
+{
+ return call_method<jhobject>(m_object,
+ "rewind", "()Ljava/nio/Buffer;");
+}
+
+int CJNIBuffer::remaining()
+{
+ return call_method<int>(m_object,
+ "remaining", "()I");
+}
+
+bool CJNIBuffer::hasRemaining()
+{
+ return call_method<jboolean>(m_object,
+ "hasRemaining", "()Z");
+}
+
+bool CJNIBuffer::isReadOnly()
+{
+ return call_method<jboolean>(m_object,
+ "isReadOnly", "()Z");
+}
+
+bool CJNIBuffer::hasArray()
+{
+ return call_method<jboolean>(m_object,
+ "hasArray", "()Z");
+}
+
+/*
+CJNIObject CJNIBuffer::array()
+{
+}
+*/
+
+int CJNIBuffer::arrayOffset()
+{
+ return call_method<int>(m_object,
+ "arrayOffset", "()I");
+}
+
+bool CJNIBuffer::isDirect()
+{
+ return call_method<jboolean>(m_object,
+ "isDirect", "()Z");
+}
+
diff --git a/xbmc/android/jni/Buffer.h b/xbmc/android/jni/Buffer.h
new file mode 100644
index 0000000000..dd07564060
--- /dev/null
+++ b/xbmc/android/jni/Buffer.h
@@ -0,0 +1,48 @@
+#pragma once
+/*
+ * Copyright (C) 2013 Team XBMC
+ * http://www.xbmc.org
+ *
+ * This Program is free 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 2, 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
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with XBMC; see the file COPYING. If not, see
+ * <http://www.gnu.org/licenses/>.
+ *
+ */
+
+#include "JNIBase.h"
+
+class CJNIBuffer : public CJNIBase
+{
+protected:
+ CJNIBuffer(const jni::jhobject &object) : CJNIBase(object) {};
+ ~CJNIBuffer() {};
+
+ int capacity();
+ int position();
+ CJNIBuffer position(int newPosition);
+ int limit();
+ CJNIBuffer limit(int newLimit);
+ CJNIBuffer mark();
+ CJNIBuffer reset();
+ CJNIBuffer clear();
+ CJNIBuffer flip();
+ CJNIBuffer rewind();
+ int remaining();
+ bool hasRemaining();
+
+ virtual bool isReadOnly();
+ virtual bool hasArray();
+//virtual CJNIObject array();
+ virtual int arrayOffset();
+ virtual bool isDirect();
+};
diff --git a/xbmc/android/jni/Build.cpp b/xbmc/android/jni/Build.cpp
new file mode 100644
index 0000000000..a400dcd438
--- /dev/null
+++ b/xbmc/android/jni/Build.cpp
@@ -0,0 +1,74 @@
+/*
+ * Copyright (C) 2013 Team XBMC
+ * http://www.xbmc.org
+ *
+ * This Program is free 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 2, 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
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with XBMC; see the file COPYING. If not, see
+ * <http://www.gnu.org/licenses/>.
+ *
+ */
+
+#include "Build.h"
+#include "jutils/jutils-details.hpp"
+
+using namespace jni;
+const char *CJNIBuild::m_classname = "android/os/Build";
+
+std::string CJNIBuild::UNKNOWN;
+std::string CJNIBuild::DISPLAY;
+std::string CJNIBuild::PRODUCT;
+std::string CJNIBuild::DEVICE;
+std::string CJNIBuild::BOARD;
+std::string CJNIBuild::CPU_ABI;
+std::string CJNIBuild::CPU_ABI2;
+std::string CJNIBuild::MANUFACTURER;
+std::string CJNIBuild::BRAND;
+std::string CJNIBuild::MODEL;
+std::string CJNIBuild::BOOTLOADER;
+std::string CJNIBuild::RADIO;
+std::string CJNIBuild::HARDWARE;
+std::string CJNIBuild::SERIAL;
+std::string CJNIBuild::TAGS;
+std::string CJNIBuild::FINGERPRINT;
+int64_t CJNIBuild::TIME;
+std::string CJNIBuild::USER;
+std::string CJNIBuild::HOST;
+
+void CJNIBuild::PopulateStaticFields()
+{
+ UNKNOWN = jcast<std::string>(get_static_field<jhstring>(m_classname,"UNKNOWN"));
+ DISPLAY = jcast<std::string>(get_static_field<jhstring>(m_classname,"DISPLAY"));
+ PRODUCT = jcast<std::string>(get_static_field<jhstring>(m_classname,"PRODUCT"));
+ DEVICE = jcast<std::string>(get_static_field<jhstring>(m_classname,"DEVICE"));
+ BOARD = jcast<std::string>(get_static_field<jhstring>(m_classname,"BOARD"));
+ CPU_ABI = jcast<std::string>(get_static_field<jhstring>(m_classname,"CPU_ABI"));
+ CPU_ABI2 = jcast<std::string>(get_static_field<jhstring>(m_classname,"CPU_ABI2"));
+ MANUFACTURER = jcast<std::string>(get_static_field<jhstring>(m_classname,"MANUFACTURER"));
+ BRAND = jcast<std::string>(get_static_field<jhstring>(m_classname,"BRAND"));
+ MODEL = jcast<std::string>(get_static_field<jhstring>(m_classname,"MODEL"));
+ BOOTLOADER = jcast<std::string>(get_static_field<jhstring>(m_classname,"BOOTLOADER"));
+ RADIO = jcast<std::string>(get_static_field<jhstring>(m_classname,"RADIO"));
+ HARDWARE = jcast<std::string>(get_static_field<jhstring>(m_classname,"HARDWARE"));
+ SERIAL = jcast<std::string>(get_static_field<jhstring>(m_classname,"SERIAL"));
+ TAGS = jcast<std::string>(get_static_field<jhstring>(m_classname,"TAGS"));
+ FINGERPRINT = jcast<std::string>(get_static_field<jhstring>(m_classname,"FINGERPRINT"));
+ TIME = get_static_field<jlong>(m_classname,"TIME");
+ USER = jcast<std::string>(get_static_field<jhstring>(m_classname,"USER"));
+ HOST = jcast<std::string>(get_static_field<jhstring>(m_classname,"HOST"));
+}
+
+std::string CJNIBuild::getRadioVersion()
+{
+ return jcast<std::string>(call_static_method<jhstring>(m_classname,
+ "getRadioVersion", "()Ljava/lang/String;"));
+}
diff --git a/xbmc/android/jni/Build.h b/xbmc/android/jni/Build.h
new file mode 100644
index 0000000000..2032787e8f
--- /dev/null
+++ b/xbmc/android/jni/Build.h
@@ -0,0 +1,55 @@
+#pragma once
+/*
+ * Copyright (C) 2013 Team XBMC
+ * http://www.xbmc.org
+ *
+ * This Program is free 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 2, 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
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with XBMC; see the file COPYING. If not, see
+ * <http://www.gnu.org/licenses/>.
+ *
+ */
+
+#include "JNIBase.h"
+
+class CJNIBuild
+{
+public:
+ static std::string UNKNOWN;
+ static std::string ID;
+ static std::string DISPLAY;
+ static std::string PRODUCT;
+ static std::string DEVICE;
+ static std::string BOARD;
+ static std::string CPU_ABI;
+ static std::string CPU_ABI2;
+ static std::string MANUFACTURER;
+ static std::string BRAND;
+ static std::string MODEL;
+ static std::string BOOTLOADER;
+ static std::string RADIO;
+ static std::string HARDWARE;
+ static std::string SERIAL;
+ static std::string TYPE;
+ static std::string TAGS;
+ static std::string FINGERPRINT;
+ static int64_t TIME;
+ static std::string USER;
+ static std::string HOST;
+ static std::string getRadioVersion();
+
+ static void PopulateStaticFields();
+private:
+ CJNIBuild();
+ ~CJNIBuild() {};
+ static const char *m_classname;
+};
diff --git a/xbmc/android/jni/ByteBuffer.cpp b/xbmc/android/jni/ByteBuffer.cpp
new file mode 100644
index 0000000000..19ef08f5d7
--- /dev/null
+++ b/xbmc/android/jni/ByteBuffer.cpp
@@ -0,0 +1,189 @@
+/*
+ * Copyright (C) 2013 Team XBMC
+ * http://www.xbmc.org
+ *
+ * This Program is free 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 2, 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
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with XBMC; see the file COPYING. If not, see
+ * <http://www.gnu.org/licenses/>.
+ *
+ */
+
+#include "ByteBuffer.h"
+#include "jutils/jutils-details.hpp"
+
+using namespace jni;
+
+const char* CJNIByteBuffer::m_classname = "java/nio/ByteBuffer";
+
+CJNIByteBuffer CJNIByteBuffer::CJNIByteBuffer::allocateDirect(int capacity)
+{
+ return CJNIByteBuffer(call_static_method<jhobject>(m_classname,
+ "allocateDirect", "(I)Ljava/nio/ByteBuffer;",
+ capacity));
+}
+
+CJNIByteBuffer CJNIByteBuffer::allocate(int capacity)
+{
+ return CJNIByteBuffer(call_static_method<jhobject>(m_classname,
+ "allocate", "(I)Ljava/nio/ByteBuffer;",
+ capacity));
+}
+
+CJNIByteBuffer CJNIByteBuffer::wrap(const std::vector<char> &array, int start, int byteCount)
+{
+ JNIEnv *env = xbmc_jnienv();
+ jsize size = array.size();
+ jbyteArray bytearray = env->NewByteArray(size);
+ env->SetByteArrayRegion(bytearray, 0, size, (jbyte*)&array[0]);
+
+ return CJNIByteBuffer(call_static_method<jhobject>(m_classname,
+ "wrap","([BII)Ljava/nio/ByteBuffer;",
+ bytearray, start, byteCount));
+}
+
+CJNIByteBuffer CJNIByteBuffer::wrap(const std::vector<char> &array)
+{
+ JNIEnv *env = xbmc_jnienv();
+ jsize size = array.size();
+ jbyteArray bytearray = env->NewByteArray(size);
+ env->SetByteArrayRegion(bytearray, 0, size, (jbyte*)&array[0]);
+
+ return CJNIByteBuffer(call_static_method<jhobject>(m_classname,
+ "wrap","([B)Ljava/nio/ByteBuffer;",
+ bytearray));
+}
+
+CJNIByteBuffer CJNIByteBuffer::get(const std::vector<char> &dst, int dstOffset, int byteCount)
+{
+ JNIEnv *env = xbmc_jnienv();
+ jsize size = dst.size();
+ jbyteArray bytearray = env->NewByteArray(size);
+ env->SetByteArrayRegion(bytearray, 0, size, (jbyte*)&dst[0]);
+
+ return CJNIByteBuffer(call_method<jhobject>(m_object,
+ "get","([BII)Ljava/nio/ByteBuffer;",
+ bytearray, dstOffset, byteCount));
+}
+
+CJNIByteBuffer CJNIByteBuffer::get(const std::vector<char> &dst)
+{
+ JNIEnv *env = xbmc_jnienv();
+ jsize size = dst.size();
+ jbyteArray bytearray = env->NewByteArray(size);
+ env->SetByteArrayRegion(bytearray, 0, size, (jbyte*)&dst[0]);
+
+ return CJNIByteBuffer(call_method<jhobject>(m_object,
+ "get","([B)Ljava/nio/ByteBuffer;",
+ bytearray));
+}
+
+CJNIByteBuffer CJNIByteBuffer::put(const CJNIByteBuffer &src)
+{
+ return CJNIByteBuffer(call_method<jhobject>(m_object,
+ "put","(Ljava/nio/ByteBuffer;)Ljava/nio/ByteBuffer;",
+ src.get_raw()));
+}
+
+CJNIByteBuffer CJNIByteBuffer::put(const std::vector<char> &src, int srcOffset, int byteCount)
+{
+ JNIEnv *env = xbmc_jnienv();
+ jsize size = src.size();
+ jbyteArray bytearray = env->NewByteArray(size);
+ env->SetByteArrayRegion(bytearray, 0, size, (jbyte*)&src[0]);
+
+ return CJNIByteBuffer(call_method<jhobject>(m_object,
+ "put","([BII)Ljava/nio/ByteBuffer;",
+ bytearray, srcOffset, byteCount));
+}
+
+CJNIByteBuffer CJNIByteBuffer::put(const std::vector<char> &src)
+{
+ JNIEnv *env = xbmc_jnienv();
+ jsize size = src.size();
+ jbyteArray bytearray = env->NewByteArray(size);
+ env->SetByteArrayRegion(bytearray, 0, size, (jbyte*)&src[0]);
+
+ return CJNIByteBuffer(call_method<jhobject>(m_object,
+ "put","([B)Ljava/nio/ByteBuffer;",
+ bytearray));
+}
+
+bool CJNIByteBuffer::hasArray()
+{
+ return call_method<jboolean>(m_object,
+ "hasArray", "()Z");
+}
+
+std::vector<char> CJNIByteBuffer::array()
+{
+ JNIEnv *env = xbmc_jnienv();
+ jhbyteArray array = call_method<jhbyteArray>(m_object,
+ "array", "()[B");
+
+ jsize size = env->GetArrayLength(array.get());
+
+ std::vector<char> result;
+ result.resize(size);
+ env->GetByteArrayRegion(array.get(), 0, size, (jbyte*)result.data());
+
+ return result;
+}
+
+int CJNIByteBuffer::arrayOffset()
+{
+ return call_method<int>(m_object,
+ "arrayOffset", "()I");
+}
+
+std::string CJNIByteBuffer::toString()
+{
+ return jcast<std::string>(call_method<jhstring>(m_object,
+ "toString", "()Ljava/lang/String;"));
+}
+
+int CJNIByteBuffer::hashCode()
+{
+ return call_method<int>(m_object,
+ "hashCode", "()I");
+}
+
+/*
+bool CJNIByteBuffer::equals(CJNIObject other)
+{
+}
+*/
+
+int CJNIByteBuffer::compareTo(const CJNIByteBuffer &otherBuffer)
+{
+ return call_method<int>(m_object,
+ "compareTo","(Ljava/nio/ByteBuffer;)I",
+ otherBuffer.get_raw());
+}
+
+/*
+CJNIByteOrder CJNIByteBuffer::order()
+{
+}
+
+CJNIByteBuffer CJNIByteBuffer::order(CJNIByteOrder byteOrder)
+{
+}
+
+CJNIObject CJNIByteBuffer::array()
+{
+}
+
+int CJNIByteBuffer::compareTo(const CJNIObject &otherBuffer)
+{
+}
+*/
diff --git a/xbmc/android/jni/ByteBuffer.h b/xbmc/android/jni/ByteBuffer.h
new file mode 100644
index 0000000000..335384a49a
--- /dev/null
+++ b/xbmc/android/jni/ByteBuffer.h
@@ -0,0 +1,57 @@
+#pragma once
+/*
+ * Copyright (C) 2013 Team XBMC
+ * http://www.xbmc.org
+ *
+ * This Program is free 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 2, 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
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with XBMC; see the file COPYING. If not, see
+ * <http://www.gnu.org/licenses/>.
+ *
+ */
+
+#include "Buffer.h"
+
+class CJNIByteBuffer : public CJNIBuffer
+{
+public:
+ CJNIByteBuffer(const jni::jhobject &object) : CJNIBuffer(object) {};
+ ~CJNIByteBuffer(){};
+
+ static CJNIByteBuffer allocateDirect(int capacity);
+ static CJNIByteBuffer allocate(int capacity);
+ static CJNIByteBuffer wrap(const std::vector<char> &array, int start, int byteCount);
+ static CJNIByteBuffer wrap(const std::vector<char> &array);
+
+ CJNIByteBuffer get(const std::vector<char> &dst, int dstOffset, int byteCount);
+ CJNIByteBuffer get(const std::vector<char> &dst);
+ CJNIByteBuffer put(const CJNIByteBuffer &src);
+ CJNIByteBuffer put(const std::vector<char> &src, int srcOffset, int byteCount);
+ CJNIByteBuffer put(const std::vector<char> &src);
+
+ bool hasArray();
+ std::vector<char> array();
+ int arrayOffset();
+ std::string toString();
+ int hashCode();
+ //bool equals(const CJNIObject &other);
+ int compareTo(const CJNIByteBuffer &otherBuffer);
+ //CJNIByteOrder order();
+ //CJNIByteBuffer order(const CJNIByteOrder &byteOrder);
+ //CJNIObject array();
+ //int compareTo(const CJNIObject &otherBuffer);
+
+private:
+ static const char *m_classname;
+};
+
+typedef std::vector<CJNIByteBuffer> CJNIByteBuffers;
diff --git a/xbmc/android/jni/Makefile.in b/xbmc/android/jni/Makefile.in
index 728b046d92..35cb84002c 100644
--- a/xbmc/android/jni/Makefile.in
+++ b/xbmc/android/jni/Makefile.in
@@ -32,10 +32,21 @@ SRCS += BitmapDrawable.cpp
SRCS += CharSequence.cpp
SRCS += ContentResolver.cpp
SRCS += Cursor.cpp
+SRCS += Buffer.cpp
+SRCS += ByteBuffer.cpp
SRCS += BaseColumns.cpp
SRCS += MediaStore.cpp
SRCS += Surface.cpp
+SRCS += MediaCodec.cpp
+SRCS += MediaCodecBufferInfo.cpp
+SRCS += MediaCodecCryptoInfo.cpp
+SRCS += MediaCodecInfo.cpp
+SRCS += MediaCodecList.cpp
+SRCS += MediaFormat.cpp
SRCS += SurfaceTexture.cpp
+SRCS += View.cpp
+SRCS += Window.cpp
+SRCS += Build.cpp
LIB = jni.a
diff --git a/xbmc/android/jni/MediaCodec.cpp b/xbmc/android/jni/MediaCodec.cpp
new file mode 100644
index 0000000000..10eb216c06
--- /dev/null
+++ b/xbmc/android/jni/MediaCodec.cpp
@@ -0,0 +1,248 @@
+/*
+ * Copyright (C) 2013 Team XBMC
+ * http://www.xbmc.org
+ *
+ * This Program is free 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 2, 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
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with XBMC; see the file COPYING. If not, see
+ * <http://www.gnu.org/licenses/>.
+ *
+ */
+
+#include "MediaCodec.h"
+#include "MediaCrypto.h"
+#include "MediaCodecCryptoInfo.h"
+#include "NetworkInfo.h"
+#include "Surface.h"
+
+#include "jutils/jutils-details.hpp"
+
+using namespace jni;
+
+int CJNIMediaCodec::BUFFER_FLAG_CODEC_CONFIG(2);
+int CJNIMediaCodec::BUFFER_FLAG_END_OF_STREAM(4);
+int CJNIMediaCodec::BUFFER_FLAG_SYNC_FRAME(1);
+int CJNIMediaCodec::CONFIGURE_FLAG_ENCODE(1);
+int CJNIMediaCodec::CONFIGURE_FLAG_DECODE(0);
+int CJNIMediaCodec::CRYPTO_MODE_AES_CTR(1);
+int CJNIMediaCodec::CRYPTO_MODE_UNENCRYPTED(0);
+int CJNIMediaCodec::INFO_OUTPUT_BUFFERS_CHANGED(-3);
+int CJNIMediaCodec::INFO_OUTPUT_FORMAT_CHANGED(-2);
+int CJNIMediaCodec::INFO_TRY_AGAIN_LATER(-1);
+int CJNIMediaCodec::VIDEO_SCALING_MODE_SCALE_TO_FIT(1);
+int CJNIMediaCodec::VIDEO_SCALING_MODE_SCALE_TO_FIT_WITH_CROPPING(2);
+const char *CJNIMediaCodec::m_classname = "android/media/MediaCodec";
+
+void CJNIMediaCodec::PopulateStaticFields()
+{
+ if(GetSDKVersion() >= 16)
+ {
+ jhclass clazz = find_class("android/media/MediaCodec");
+ BUFFER_FLAG_CODEC_CONFIG = (get_static_field<int>(clazz, "BUFFER_FLAG_CODEC_CONFIG"));
+ BUFFER_FLAG_END_OF_STREAM = (get_static_field<int>(clazz, "BUFFER_FLAG_END_OF_STREAM"));
+ BUFFER_FLAG_SYNC_FRAME = (get_static_field<int>(clazz, "BUFFER_FLAG_SYNC_FRAME"));
+ CONFIGURE_FLAG_ENCODE = (get_static_field<int>(clazz, "CONFIGURE_FLAG_ENCODE"));
+ // CONFIGURE_FLAG_DECODE is ours to make it easy on params
+ CRYPTO_MODE_AES_CTR = (get_static_field<int>(clazz, "CRYPTO_MODE_AES_CTR"));
+ CRYPTO_MODE_UNENCRYPTED = (get_static_field<int>(clazz, "CRYPTO_MODE_UNENCRYPTED"));
+ INFO_OUTPUT_BUFFERS_CHANGED = (get_static_field<int>(clazz, "INFO_OUTPUT_BUFFERS_CHANGED"));
+ INFO_OUTPUT_FORMAT_CHANGED= (get_static_field<int>(clazz, "INFO_OUTPUT_FORMAT_CHANGED"));
+ INFO_TRY_AGAIN_LATER = (get_static_field<int>(clazz, "INFO_TRY_AGAIN_LATER"));
+ VIDEO_SCALING_MODE_SCALE_TO_FIT = (get_static_field<int>(clazz, "VIDEO_SCALING_MODE_SCALE_TO_FIT"));
+ VIDEO_SCALING_MODE_SCALE_TO_FIT_WITH_CROPPING = (get_static_field<int>(clazz, "VIDEO_SCALING_MODE_SCALE_TO_FIT_WITH_CROPPING"));
+ }
+}
+
+const CJNIMediaCodec CJNIMediaCodec::createDecoderByType(const std::string &type)
+{
+ // This method doesn't handle errors nicely, it crashes if the codec isn't found.
+ // This is fixed in latest AOSP, but not in current 4.1 devices.
+ return call_static_method<jhobject>(m_classname,
+ "createDecoderByType", "(Ljava/lang/String;)Landroid/media/MediaCodec;",
+ jcast<jhstring>(type));
+}
+
+const CJNIMediaCodec CJNIMediaCodec::createEncoderByType(const std::string &type)
+{
+ // This method doesn't handle errors nicely, it crashes if the codec isn't found.
+ // This is fixed in latest AOSP, but not in current 4.1 devices.
+ return call_static_method<jhobject>(m_classname,
+ "createEncoderByType", "(Ljava/lang/String;)Landroid/media/MediaCodec;",
+ jcast<jhstring>(type));
+}
+
+const CJNIMediaCodec CJNIMediaCodec::createByCodecName(const std::string &name)
+{
+ // This method doesn't handle errors nicely, it crashes if the codec isn't found.
+ // This is fixed in latest AOSP, but not in current 4.1 devices.
+ return call_static_method<jhobject>(m_classname,
+ "createByCodecName", "(Ljava/lang/String;)Landroid/media/MediaCodec;",
+ jcast<jhstring>(name));
+}
+
+void CJNIMediaCodec::release()
+{
+ call_method<void>(m_object,
+ "release", "()V");
+}
+
+void CJNIMediaCodec::configure(const CJNIMediaFormat &format, const CJNISurface &surface, const CJNIMediaCrypto &crypto, int flags)
+{
+ call_method<void>(m_object,
+ "configure", "(Landroid/media/MediaFormat;Landroid/view/Surface;Landroid/media/MediaCrypto;I)V",
+ format.get_raw(), surface.get_raw(), crypto.get_raw(), flags);
+}
+
+void CJNIMediaCodec::start()
+{
+ call_method<void>(m_object,
+ "start", "()V");
+}
+
+void CJNIMediaCodec::stop()
+{
+ call_method<void>(m_object,
+ "stop", "()V");
+}
+
+void CJNIMediaCodec::flush()
+{
+ call_method<void>(m_object,
+ "flush", "()V");
+}
+
+void CJNIMediaCodec::queueInputBuffer(int index, int offset, int size, int64_t presentationTimeUs, int flags)
+{
+ call_method<void>(m_object,
+ "queueInputBuffer", "(IIIJI)V",
+ index, offset, size, presentationTimeUs, flags);
+}
+
+void CJNIMediaCodec::queueSecureInputBuffer(int index, int offset, const CJNIMediaCodecCryptoInfo &info, int64_t presentationTimeUs, int flags)
+{
+ call_method<void>(m_object,
+ "queueSecureInputBuffer", "(IILandroid/media/MediaCodec$CryptoInfo;JI)V",
+ index, offset, info.get_raw(), presentationTimeUs, flags);
+}
+
+int CJNIMediaCodec::dequeueInputBuffer(int64_t timeoutUs)
+{
+ return call_method<int>(m_object,
+ "dequeueInputBuffer", "(J)I",
+ timeoutUs);
+}
+
+int CJNIMediaCodec::dequeueOutputBuffer(const CJNIMediaCodecBufferInfo &info, int64_t timeoutUs)
+{
+ return call_method<int>(m_object,
+ "dequeueOutputBuffer", "(Landroid/media/MediaCodec$BufferInfo;J)I",
+ info.get_raw(), timeoutUs);
+}
+
+void CJNIMediaCodec::releaseOutputBuffer(int index, bool render)
+{
+ jboolean jboolean_render = (jboolean)render;
+ call_method<void>(m_object,
+ "releaseOutputBuffer", "(IZ)V",
+ index, jboolean_render);
+}
+
+const CJNIMediaFormat CJNIMediaCodec::getOutputFormat()
+{
+ return call_method<jhobject>(m_object,
+ "getOutputFormat", "()Landroid/media/MediaFormat;");
+}
+
+std::vector<CJNIByteBuffer> CJNIMediaCodec::getInputBuffers()
+{
+ jhobjectArray oByteBuffers = call_method<jhobjectArray>(m_object,
+ "getInputBuffers", "()[Ljava/nio/ByteBuffer;");
+
+ JNIEnv *env = xbmc_jnienv();
+ jsize size = env->GetArrayLength(oByteBuffers.get());
+
+ CJNIByteBuffers buffers;
+ buffers.reserve(size);
+
+ for (int i = 0; i < size; i++)
+ {
+ jobject j_object = env->GetObjectArrayElement(oByteBuffers.get(), i);
+ CJNIByteBuffer buffer = CJNIByteBuffer(jhobject(xbmc_jnienv()->NewGlobalRef(j_object)));
+ buffers.push_back(buffer);
+ }
+
+ return buffers;
+}
+
+std::vector<CJNIByteBuffer> CJNIMediaCodec::getOutputBuffers()
+{
+ jhobjectArray oByteBuffers = call_method<jhobjectArray>(m_object,
+ "getOutputBuffers", "()[Ljava/nio/ByteBuffer;");
+
+ JNIEnv *env = xbmc_jnienv();
+ jsize size = env->GetArrayLength(oByteBuffers.get());
+
+ CJNIByteBuffers buffers;
+ buffers.reserve(size);
+
+ for (int i = 0; i < size; i++)
+ {
+ jobject j_object = env->GetObjectArrayElement(oByteBuffers.get(), i);
+ CJNIByteBuffer buffer = CJNIByteBuffer(jhobject(xbmc_jnienv()->NewGlobalRef(j_object)));
+ buffers.push_back(buffer);
+ }
+
+ return buffers;
+}
+
+int CJNIMediaCodec::getInputBufferSize()
+{
+ jhobjectArray oByteBuffers = call_method<jhobjectArray>(m_object,
+ "getInputBuffers", "()[Ljava/nio/ByteBuffer;");
+
+ JNIEnv *env = xbmc_jnienv();
+ return env->GetArrayLength(oByteBuffers.get());
+}
+
+int CJNIMediaCodec::getOutputBufferSize()
+{
+ jhobjectArray oByteBuffers = call_method<jhobjectArray>(m_object,
+ "getOutputBuffers", "()[Ljava/nio/ByteBuffer;");
+
+ JNIEnv *env = xbmc_jnienv();
+ return env->GetArrayLength(oByteBuffers.get());
+}
+
+const CJNIByteBuffer CJNIMediaCodec::getInputBuffer(int index)
+{
+ jhobjectArray oByteBuffers = call_method<jhobjectArray>(m_object,
+ "getInputBuffers", "()[Ljava/nio/ByteBuffer;");
+
+ JNIEnv *env = xbmc_jnienv();
+ return CJNIByteBuffer(jhobject(env->GetObjectArrayElement(oByteBuffers.get(), index)));
+}
+
+const CJNIByteBuffer CJNIMediaCodec::getOutputBuffer(int index)
+{
+ jhobjectArray oByteBuffers = call_method<jhobjectArray>(m_object,
+ "getOutputBuffers", "()[Ljava/nio/ByteBuffer;");
+
+ JNIEnv *env = xbmc_jnienv();
+ return CJNIByteBuffer(jhobject(env->GetObjectArrayElement(oByteBuffers.get(), index)));
+}
+
+void CJNIMediaCodec::setVideoScalingMode(int mode)
+{
+ call_method<void>(m_object,
+ "setVideoScalingMode", "(I)V",
+ mode);
+}
diff --git a/xbmc/android/jni/MediaCodec.h b/xbmc/android/jni/MediaCodec.h
new file mode 100644
index 0000000000..2f365b5ab5
--- /dev/null
+++ b/xbmc/android/jni/MediaCodec.h
@@ -0,0 +1,79 @@
+#pragma once
+/*
+ * Copyright (C) 2013 Team XBMC
+ * http://www.xbmc.org
+ *
+ * This Program is free 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 2, 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
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with XBMC; see the file COPYING. If not, see
+ * <http://www.gnu.org/licenses/>.
+ *
+ */
+
+#include "JNIBase.h"
+#include "ByteBuffer.h"
+#include "MediaCodecBufferInfo.h"
+#include "MediaFormat.h"
+
+class CJNISurface;
+class CJNIMediaCodec;
+class CJNIMediaCrypto;
+class CJNIMediaCodecCryptoInfo;
+
+class CJNIMediaCodec : public CJNIBase
+{
+public:
+ CJNIMediaCodec(const jni::jhobject &object) : CJNIBase(object) {};
+ //~CJNIMediaCodec() {};
+
+ void release();
+ void configure(const CJNIMediaFormat &format, const CJNISurface &surface, const CJNIMediaCrypto &crypto, int flags);
+ void start();
+ void stop();
+ void flush();
+ void queueInputBuffer(int index, int offset, int size, int64_t presentationTimeUs, int flags);
+ void queueSecureInputBuffer(int index, int offset, const CJNIMediaCodecCryptoInfo &info, int64_t presentationTimeUs, int flags);
+ int dequeueInputBuffer(int64_t timeoutUs);
+ int dequeueOutputBuffer(const CJNIMediaCodecBufferInfo &info, int64_t timeoutUs);
+ void releaseOutputBuffer(int index, bool render);
+ const CJNIMediaFormat getOutputFormat();
+ std::vector<CJNIByteBuffer> getInputBuffers();
+ std::vector<CJNIByteBuffer> getOutputBuffers();
+ int getInputBufferSize();
+ int getOutputBufferSize();
+ const CJNIByteBuffer getInputBuffer(int index);
+ const CJNIByteBuffer getOutputBuffer(int index);
+ void setVideoScalingMode(int mode);
+
+ static void PopulateStaticFields();
+ static const CJNIMediaCodec createDecoderByType(const std::string &type);
+ static const CJNIMediaCodec createEncoderByType(const std::string &type);
+ static const CJNIMediaCodec createByCodecName( const std::string &name);
+
+ static int BUFFER_FLAG_CODEC_CONFIG;
+ static int BUFFER_FLAG_END_OF_STREAM;
+ static int BUFFER_FLAG_SYNC_FRAME;
+ static int CONFIGURE_FLAG_ENCODE;
+ static int CONFIGURE_FLAG_DECODE;
+ static int CRYPTO_MODE_AES_CTR;
+ static int CRYPTO_MODE_UNENCRYPTED;
+ static int INFO_OUTPUT_BUFFERS_CHANGED;
+ static int INFO_OUTPUT_FORMAT_CHANGED;
+ static int INFO_TRY_AGAIN_LATER;
+ static int VIDEO_SCALING_MODE_SCALE_TO_FIT;
+ static int VIDEO_SCALING_MODE_SCALE_TO_FIT_WITH_CROPPING;
+
+private:
+ CJNIMediaCodec();
+
+ static const char *m_classname;
+};
diff --git a/xbmc/android/jni/MediaCodecBufferInfo.cpp b/xbmc/android/jni/MediaCodecBufferInfo.cpp
new file mode 100644
index 0000000000..1a4a408957
--- /dev/null
+++ b/xbmc/android/jni/MediaCodecBufferInfo.cpp
@@ -0,0 +1,60 @@
+/*
+ * Copyright (C) 2013 Team XBMC
+ * http://www.xbmc.org
+ *
+ * This Program is free 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 2, 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
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with XBMC; see the file COPYING. If not, see
+ * <http://www.gnu.org/licenses/>.
+ *
+ */
+
+#include "MediaCodecBufferInfo.h"
+#include "Context.h"
+#include "ClassLoader.h"
+
+#include "jutils/jutils-details.hpp"
+
+using namespace jni;
+
+CJNIMediaCodecBufferInfo::CJNIMediaCodecBufferInfo() : CJNIBase("android/media/MediaCodec$BufferInfo")
+{
+ m_object = new_object(GetClassName(), "<init>", "()V");
+ //m_object.setGlobal();
+}
+
+void CJNIMediaCodecBufferInfo::set(int newOffset, int newSize, int64_t newTimeUs, int newFlags)
+{
+ call_method<void>(m_object,
+ "set", "(IIJI)V",
+ newOffset, newSize, newTimeUs, newFlags);
+}
+
+int CJNIMediaCodecBufferInfo::offset() const
+{
+ return get_field<int>(m_object, "offset");
+}
+
+int CJNIMediaCodecBufferInfo::size() const
+{
+ return get_field<int>(m_object, "size");
+}
+
+int64_t CJNIMediaCodecBufferInfo::presentationTimeUs() const
+{
+ return get_field<jlong>(m_object, "presentationTimeUs");
+}
+
+int CJNIMediaCodecBufferInfo::flags() const
+{
+ return get_field<int>(m_object, "flags");
+}
diff --git a/xbmc/android/jni/MediaCodecBufferInfo.h b/xbmc/android/jni/MediaCodecBufferInfo.h
new file mode 100644
index 0000000000..4b53a73ab4
--- /dev/null
+++ b/xbmc/android/jni/MediaCodecBufferInfo.h
@@ -0,0 +1,35 @@
+#pragma once
+/*
+ * Copyright (C) 2013 Team XBMC
+ * http://www.xbmc.org
+ *
+ * This Program is free 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 2, 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
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with XBMC; see the file COPYING. If not, see
+ * <http://www.gnu.org/licenses/>.
+ *
+ */
+
+#include "JNIBase.h"
+
+class CJNIMediaCodecBufferInfo : public CJNIBase
+{
+public:
+ CJNIMediaCodecBufferInfo();
+ //~CJNIMediaCodecBufferInfo() {};
+
+ void set(int newOffset, int newSize, int64_t newTimeUs, int newFlags);
+ int offset() const;
+ int size() const;
+ int64_t presentationTimeUs() const;
+ int flags() const;
+};
diff --git a/xbmc/android/jni/MediaCodecCryptoInfo.cpp b/xbmc/android/jni/MediaCodecCryptoInfo.cpp
new file mode 100644
index 0000000000..6ee2bcb5ed
--- /dev/null
+++ b/xbmc/android/jni/MediaCodecCryptoInfo.cpp
@@ -0,0 +1,127 @@
+/*
+ * Copyright (C) 2013 Team XBMC
+ * http://www.xbmc.org
+ *
+ * This Program is free 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 2, 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
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with XBMC; see the file COPYING. If not, see
+ * <http://www.gnu.org/licenses/>.
+ *
+ */
+
+#include "MediaCodecCryptoInfo.h"
+
+#include "jutils/jutils-details.hpp"
+
+using namespace jni;
+
+int CJNIMediaCodecCryptoInfo::numSubSamples() const
+{
+ return get_field<int>(m_object, "numSubSamples");
+}
+
+std::vector<int> CJNIMediaCodecCryptoInfo::numBytesOfClearData() const
+{
+ JNIEnv *env = xbmc_jnienv();
+
+ jhintArray numBytesOfClearData = get_field<jhintArray>(m_object, "numBytesOfClearData");
+ jsize size = env->GetArrayLength(numBytesOfClearData.get());
+ std::vector<int> intarray;
+ intarray.resize(size);
+ env->GetIntArrayRegion(numBytesOfClearData.get(), 0, size, (jint*)intarray.data());
+
+ return intarray;
+}
+
+std::vector<int> CJNIMediaCodecCryptoInfo::numBytesOfEncryptedData() const
+{
+ JNIEnv *env = xbmc_jnienv();
+
+ jhintArray numBytesOfEncryptedData = get_field<jhintArray>(m_object, "numBytesOfEncryptedData");
+ jsize size = env->GetArrayLength(numBytesOfEncryptedData.get());
+ std::vector<int> intarray;
+ intarray.resize(size);
+ env->GetIntArrayRegion(numBytesOfEncryptedData.get(), 0, size, (jint*)intarray.data());
+
+ return intarray;
+}
+
+std::vector<char> CJNIMediaCodecCryptoInfo::key() const
+{
+ JNIEnv *env = xbmc_jnienv();
+
+ jhbyteArray key = get_field<jhbyteArray>(m_object, "key");
+ jsize size = env->GetArrayLength(key.get());
+ std::vector<char> chararray;
+ chararray.resize(size);
+ env->GetByteArrayRegion(key.get(), 0, size, (jbyte*)chararray.data());
+
+ return chararray;
+}
+
+std::vector<char> CJNIMediaCodecCryptoInfo::iv() const
+{
+ JNIEnv *env = xbmc_jnienv();
+
+ jhbyteArray iv = get_field<jhbyteArray>(m_object, "iv");
+ jsize size = env->GetArrayLength(iv.get());
+ std::vector<char> chararray;
+ chararray.resize(size);
+ env->GetByteArrayRegion(iv.get(), 0, size, (jbyte*)chararray.data());
+
+ return chararray;
+}
+
+int CJNIMediaCodecCryptoInfo::mode() const
+{
+ return get_field<int>(m_object, "mode");
+}
+
+void CJNIMediaCodecCryptoInfo::set(int newNumSubSamples,
+ const std::vector<int> &newNumBytesOfClearData,
+ const std::vector<int> &newNumBytesOfEncryptedData,
+ const std::vector<char> &newKey,
+ const std::vector<char> &newIV,
+ int newMode)
+{
+ jsize size;
+ JNIEnv *env = xbmc_jnienv();
+
+ size = newNumBytesOfClearData.size();
+ jintArray numBytesOfClearData = env->NewIntArray(size);
+ jint *intdata = (jint*)newNumBytesOfClearData.data();
+ env->SetIntArrayRegion(numBytesOfClearData, 0, size, intdata);
+
+ size = newNumBytesOfEncryptedData.size();
+ jintArray numBytesOfEncryptedData = env->NewIntArray(size);
+ intdata = (jint*)newNumBytesOfEncryptedData.data();
+ env->SetIntArrayRegion(numBytesOfEncryptedData, 0, size, intdata);
+
+ size = newKey.size();
+ jbyteArray Key = env->NewByteArray(size);
+ jbyte *bytedata = (jbyte*)newKey.data();
+ env->SetByteArrayRegion(Key, 0, size, bytedata);
+
+ size = newIV.size();
+ jbyteArray IV = env->NewByteArray(size);
+ bytedata = (jbyte*)newIV.data();
+ env->SetByteArrayRegion(IV, 0, size, bytedata);
+
+ call_method<void>(m_object,
+ "set", "(I[I[I[B[BI)V",
+ newNumSubSamples, numBytesOfClearData, numBytesOfEncryptedData, Key, IV, newMode);
+
+ env->DeleteLocalRef(numBytesOfClearData);
+ env->DeleteLocalRef(numBytesOfEncryptedData);
+ env->DeleteLocalRef(Key);
+ env->DeleteLocalRef(IV);
+}
diff --git a/xbmc/android/jni/MediaCodecCryptoInfo.h b/xbmc/android/jni/MediaCodecCryptoInfo.h
new file mode 100644
index 0000000000..658a8f9de7
--- /dev/null
+++ b/xbmc/android/jni/MediaCodecCryptoInfo.h
@@ -0,0 +1,45 @@
+#pragma once
+/*
+ * Copyright (C) 2013 Team XBMC
+ * http://www.xbmc.org
+ *
+ * This Program is free 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 2, 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
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with XBMC; see the file COPYING. If not, see
+ * <http://www.gnu.org/licenses/>.
+ *
+ */
+
+#include "JNIBase.h"
+
+class CJNIMediaCodecCryptoInfo : public CJNIBase
+{
+public:
+ CJNIMediaCodecCryptoInfo(const jni::jhobject &object) : CJNIBase(object) {};
+ //~CJNIMediaCodecCryptoInfo() {};
+
+ int numSubSamples() const;
+ std::vector<int> numBytesOfClearData() const;
+ std::vector<int> numBytesOfEncryptedData() const;
+ std::vector<char> key() const;
+ std::vector<char> iv() const;
+ int mode() const;
+ void set(int newNumSubSamples,
+ const std::vector<int> &newNumBytesOfClearData,
+ const std::vector<int> &newNumBytesOfEncryptedData,
+ const std::vector<char> &newKey,
+ const std::vector<char> &newIV,
+ int newMode);
+
+private:
+ CJNIMediaCodecCryptoInfo();
+};
diff --git a/xbmc/android/jni/MediaCodecInfo.cpp b/xbmc/android/jni/MediaCodecInfo.cpp
new file mode 100644
index 0000000000..731697b113
--- /dev/null
+++ b/xbmc/android/jni/MediaCodecInfo.cpp
@@ -0,0 +1,349 @@
+/*
+ * Copyright (C) 2013 Team XBMC
+ * http://www.xbmc.org
+ *
+ * This Program is free 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 2, 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
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with XBMC; see the file COPYING. If not, see
+ * <http://www.gnu.org/licenses/>.
+ *
+ */
+
+#include "MediaCodecInfo.h"
+
+#include "jutils/jutils-details.hpp"
+
+using namespace jni;
+
+int CJNIMediaCodecInfoCodecProfileLevel::AVCProfileBaseline(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AVCProfileMain(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AVCProfileExtended(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AVCProfileHigh(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AVCProfileHigh10(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AVCProfileHigh422(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AVCProfileHigh444(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AVCLevel1(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AVCLevel1b(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AVCLevel11(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AVCLevel12(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AVCLevel13(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AVCLevel2(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AVCLevel21(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AVCLevel22(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AVCLevel3(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AVCLevel31(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AVCLevel32(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AVCLevel4(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AVCLevel41(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AVCLevel42(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AVCLevel5(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AVCLevel51(0);
+int CJNIMediaCodecInfoCodecProfileLevel::H263ProfileBaseline(0);
+int CJNIMediaCodecInfoCodecProfileLevel::H263ProfileH320Coding(0);
+int CJNIMediaCodecInfoCodecProfileLevel::H263ProfileBackwardCompatible(0);
+int CJNIMediaCodecInfoCodecProfileLevel::H263ProfileISWV2(0);
+int CJNIMediaCodecInfoCodecProfileLevel::H263ProfileISWV3(0);
+int CJNIMediaCodecInfoCodecProfileLevel::H263ProfileHighCompression(0);
+int CJNIMediaCodecInfoCodecProfileLevel::H263ProfileInternet(0);
+int CJNIMediaCodecInfoCodecProfileLevel::H263ProfileInterlace(0);
+int CJNIMediaCodecInfoCodecProfileLevel::H263ProfileHighLatency(0);
+int CJNIMediaCodecInfoCodecProfileLevel::H263Level10(0);
+int CJNIMediaCodecInfoCodecProfileLevel::H263Level20(0);
+int CJNIMediaCodecInfoCodecProfileLevel::H263Level30(0);
+int CJNIMediaCodecInfoCodecProfileLevel::H263Level40(0);
+int CJNIMediaCodecInfoCodecProfileLevel::H263Level45(0);
+int CJNIMediaCodecInfoCodecProfileLevel::H263Level50(0);
+int CJNIMediaCodecInfoCodecProfileLevel::H263Level60(0);
+int CJNIMediaCodecInfoCodecProfileLevel::H263Level70(0);
+int CJNIMediaCodecInfoCodecProfileLevel::MPEG4ProfileSimple(0);
+int CJNIMediaCodecInfoCodecProfileLevel::MPEG4ProfileSimpleScalable(0);
+int CJNIMediaCodecInfoCodecProfileLevel::MPEG4ProfileCore(0);
+int CJNIMediaCodecInfoCodecProfileLevel::MPEG4ProfileMain(0);
+int CJNIMediaCodecInfoCodecProfileLevel::MPEG4ProfileNbit(0);
+int CJNIMediaCodecInfoCodecProfileLevel::MPEG4ProfileScalableTexture(0);
+int CJNIMediaCodecInfoCodecProfileLevel::MPEG4ProfileSimpleFace(0);
+int CJNIMediaCodecInfoCodecProfileLevel::MPEG4ProfileSimpleFBA(0);
+int CJNIMediaCodecInfoCodecProfileLevel::MPEG4ProfileBasicAnimated(0);
+int CJNIMediaCodecInfoCodecProfileLevel::MPEG4ProfileHybrid(0);
+int CJNIMediaCodecInfoCodecProfileLevel::MPEG4ProfileAdvancedRealTime(0);
+int CJNIMediaCodecInfoCodecProfileLevel::MPEG4ProfileCoreScalable(0);
+int CJNIMediaCodecInfoCodecProfileLevel::MPEG4ProfileAdvancedCoding(0);
+int CJNIMediaCodecInfoCodecProfileLevel::MPEG4ProfileAdvancedCore(0);
+int CJNIMediaCodecInfoCodecProfileLevel::MPEG4ProfileAdvancedScalable(0);
+int CJNIMediaCodecInfoCodecProfileLevel::MPEG4ProfileAdvancedSimple(0);
+int CJNIMediaCodecInfoCodecProfileLevel::MPEG4Level0(0);
+int CJNIMediaCodecInfoCodecProfileLevel::MPEG4Level0b(0);
+int CJNIMediaCodecInfoCodecProfileLevel::MPEG4Level1(0);
+int CJNIMediaCodecInfoCodecProfileLevel::MPEG4Level2(0);
+int CJNIMediaCodecInfoCodecProfileLevel::MPEG4Level3(0);
+int CJNIMediaCodecInfoCodecProfileLevel::MPEG4Level4(0);
+int CJNIMediaCodecInfoCodecProfileLevel::MPEG4Level4a(0);
+int CJNIMediaCodecInfoCodecProfileLevel::MPEG4Level5(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AACObjectMain(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AACObjectLC(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AACObjectSSR(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AACObjectLTP(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AACObjectHE(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AACObjectScalable(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AACObjectERLC(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AACObjectLD(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AACObjectHE_PS(0);
+int CJNIMediaCodecInfoCodecProfileLevel::AACObjectELD(0);
+const char *CJNIMediaCodecInfoCodecProfileLevel::m_classname = "android/media/MediaCodecInfo$CodecProfileLevel";
+
+void CJNIMediaCodecInfoCodecProfileLevel::PopulateStaticFields()
+{
+ if(GetSDKVersion() >= 16)
+ {
+ jhclass clazz = find_class(m_classname);
+ AVCProfileBaseline = (get_static_field<int>(clazz, "AVCProfileBaseline"));
+ AVCProfileMain = (get_static_field<int>(clazz, "AVCProfileMain"));
+ AVCProfileExtended = (get_static_field<int>(clazz, "AVCProfileExtended"));
+ AVCProfileHigh = (get_static_field<int>(clazz, "AVCProfileHigh"));
+ AVCProfileHigh10 = (get_static_field<int>(clazz, "AVCProfileHigh10"));
+ AVCProfileHigh422 = (get_static_field<int>(clazz, "AVCProfileHigh422"));
+ AVCProfileHigh444 = (get_static_field<int>(clazz, "AVCProfileHigh444"));
+ AVCLevel1 = (get_static_field<int>(clazz, "AVCLevel1"));
+ AVCLevel1b = (get_static_field<int>(clazz, "AVCLevel1b"));
+ AVCLevel11 = (get_static_field<int>(clazz, "AVCLevel11"));
+ AVCLevel12 = (get_static_field<int>(clazz, "AVCLevel12"));
+ AVCLevel13 = (get_static_field<int>(clazz, "AVCLevel13"));
+ AVCLevel2 = (get_static_field<int>(clazz, "AVCLevel2"));
+ AVCLevel21 = (get_static_field<int>(clazz, "AVCLevel21"));
+ AVCLevel22 = (get_static_field<int>(clazz, "AVCLevel22"));
+ AVCLevel3 = (get_static_field<int>(clazz, "AVCLevel3"));
+ AVCLevel31 = (get_static_field<int>(clazz, "AVCLevel31"));
+ AVCLevel32 = (get_static_field<int>(clazz, "AVCLevel32"));
+ AVCLevel4 = (get_static_field<int>(clazz, "AVCLevel4"));
+ AVCLevel41 = (get_static_field<int>(clazz, "AVCLevel41"));
+ AVCLevel42 = (get_static_field<int>(clazz, "AVCLevel42"));
+ AVCLevel5 = (get_static_field<int>(clazz, "AVCLevel5"));
+ AVCLevel51 = (get_static_field<int>(clazz, "AVCLevel51"));
+ H263ProfileBaseline = (get_static_field<int>(clazz, "H263ProfileBaseline"));
+ H263ProfileH320Coding = (get_static_field<int>(clazz, "H263ProfileH320Coding"));
+ H263ProfileBackwardCompatible = (get_static_field<int>(clazz, "H263ProfileBackwardCompatible"));
+ H263ProfileISWV2 = (get_static_field<int>(clazz, "H263ProfileISWV2"));
+ H263ProfileISWV3 = (get_static_field<int>(clazz, "H263ProfileISWV3"));
+ H263ProfileHighCompression = (get_static_field<int>(clazz, "H263ProfileHighCompression"));
+ H263ProfileInternet = (get_static_field<int>(clazz, "H263ProfileInternet"));
+ H263ProfileInterlace = (get_static_field<int>(clazz, "H263ProfileInterlace"));
+ H263ProfileHighLatency = (get_static_field<int>(clazz, "H263ProfileHighLatency"));
+ H263Level10 = (get_static_field<int>(clazz, "H263Level10"));
+ H263Level20 = (get_static_field<int>(clazz, "H263Level20"));
+ H263Level30 = (get_static_field<int>(clazz, "H263Level30"));
+ H263Level40 = (get_static_field<int>(clazz, "H263Level40"));
+ H263Level45 = (get_static_field<int>(clazz, "H263Level45"));
+ H263Level50 = (get_static_field<int>(clazz, "H263Level50"));
+ H263Level60 = (get_static_field<int>(clazz, "H263Level60"));
+ H263Level70 = (get_static_field<int>(clazz, "H263Level70"));
+ MPEG4ProfileSimple = (get_static_field<int>(clazz, "MPEG4ProfileSimple"));
+ MPEG4ProfileSimpleScalable = (get_static_field<int>(clazz, "MPEG4ProfileSimpleScalable"));
+ MPEG4ProfileCore = (get_static_field<int>(clazz, "MPEG4ProfileCore"));
+ MPEG4ProfileMain = (get_static_field<int>(clazz, "MPEG4ProfileMain"));
+ MPEG4ProfileNbit = (get_static_field<int>(clazz, "MPEG4ProfileNbit"));
+ MPEG4ProfileScalableTexture = (get_static_field<int>(clazz, "MPEG4ProfileScalableTexture"));
+ MPEG4ProfileSimpleFace = (get_static_field<int>(clazz, "MPEG4ProfileSimpleFace"));
+ MPEG4ProfileSimpleFBA = (get_static_field<int>(clazz, "MPEG4ProfileSimpleFBA"));
+ MPEG4ProfileBasicAnimated = (get_static_field<int>(clazz, "MPEG4ProfileBasicAnimated"));
+ MPEG4ProfileHybrid = (get_static_field<int>(clazz, "MPEG4ProfileHybrid"));
+ MPEG4ProfileAdvancedRealTime = (get_static_field<int>(clazz, "MPEG4ProfileAdvancedRealTime"));
+ MPEG4ProfileCoreScalable = (get_static_field<int>(clazz, "MPEG4ProfileCoreScalable"));
+ MPEG4ProfileAdvancedCoding = (get_static_field<int>(clazz, "MPEG4ProfileAdvancedCoding"));
+ MPEG4ProfileAdvancedCore = (get_static_field<int>(clazz, "MPEG4ProfileAdvancedCore"));
+ MPEG4ProfileAdvancedScalable= (get_static_field<int>(clazz, "MPEG4ProfileAdvancedScalable"));
+ MPEG4ProfileAdvancedSimple = (get_static_field<int>(clazz, "MPEG4ProfileAdvancedSimple"));
+ MPEG4Level0 = (get_static_field<int>(clazz, "MPEG4Level0"));
+ MPEG4Level0b = (get_static_field<int>(clazz, "MPEG4Level0b"));
+ MPEG4Level1 = (get_static_field<int>(clazz, "MPEG4Level1"));
+ MPEG4Level2 = (get_static_field<int>(clazz, "MPEG4Level2"));
+ MPEG4Level3 = (get_static_field<int>(clazz, "MPEG4Level3"));
+ MPEG4Level4 = (get_static_field<int>(clazz, "MPEG4Level4"));
+ MPEG4Level4a = (get_static_field<int>(clazz, "MPEG4Level4a"));
+ MPEG4Level5 = (get_static_field<int>(clazz, "MPEG4Level5"));
+ AACObjectMain = (get_static_field<int>(clazz, "AACObjectMain"));
+ AACObjectLC = (get_static_field<int>(clazz, "AACObjectLC"));
+ AACObjectSSR = (get_static_field<int>(clazz, "AACObjectSSR"));
+ AACObjectLTP = (get_static_field<int>(clazz, "AACObjectLTP"));
+ AACObjectHE = (get_static_field<int>(clazz, "AACObjectHE"));
+ AACObjectScalable = (get_static_field<int>(clazz, "AACObjectScalable"));
+ AACObjectERLC = (get_static_field<int>(clazz, "AACObjectERLC"));
+ AACObjectLD = (get_static_field<int>(clazz, "AACObjectLD"));
+ AACObjectHE_PS = (get_static_field<int>(clazz, "AACObjectHE_PS"));
+ AACObjectELD = (get_static_field<int>(clazz, "AACObjectELD"));
+ }
+}
+
+int CJNIMediaCodecInfoCodecProfileLevel::profile() const
+{
+ return get_field<int>(m_object, "profile");
+}
+
+int CJNIMediaCodecInfoCodecProfileLevel::level() const
+{
+ return get_field<int>(m_object, "level");
+}
+
+/**********************************************************************************/
+/**********************************************************************************/
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_FormatMonochrome(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_Format8bitRGB332(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_Format12bitRGB444(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_Format16bitARGB4444(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_Format16bitARGB1555(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_Format16bitRGB565(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_Format16bitBGR565(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_Format18bitRGB666(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_Format18bitARGB1665(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_Format19bitARGB1666(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_Format24bitRGB888(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_Format24bitBGR888(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_Format24bitARGB1887(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_Format25bitARGB1888(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_Format32bitBGRA8888(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_Format32bitARGB8888(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_FormatYUV411Planar(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_FormatYUV411PackedPlanar(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_FormatYUV420Planar(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_FormatYUV420PackedPlanar(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_FormatYUV420SemiPlanar(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_FormatYUV422Planar(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_FormatYUV422PackedPlanar(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_FormatYUV422SemiPlanar(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_FormatYCbYCr(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_FormatYCrYCb(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_FormatCbYCrY(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_FormatCrYCbY(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_FormatYUV444Interleaved(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_FormatRawBayer8bit(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_FormatRawBayer10bit(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_FormatRawBayer8bitcompressed(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_FormatL2(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_FormatL4(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_FormatL8(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_FormatL16(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_FormatL24(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_FormatL32(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_FormatYUV420PackedSemiPlanar(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_FormatYUV422PackedSemiPlanar(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_Format18BitBGR666(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_Format24BitARGB6666(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_Format24BitABGR6666(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_TI_FormatYUV420PackedSemiPlanar(0);
+int CJNIMediaCodecInfoCodecCapabilities::COLOR_QCOM_FormatYUV420SemiPlanar(0);
+const char *CJNIMediaCodecInfoCodecCapabilities::m_classname = "android/media/MediaCodecInfo$CodecCapabilities";
+
+void CJNIMediaCodecInfoCodecCapabilities::PopulateStaticFields()
+{
+ if(GetSDKVersion() >= 16)
+ {
+ jhclass clazz = find_class(m_classname);
+ COLOR_FormatMonochrome = (get_static_field<int>(clazz, "COLOR_FormatMonochrome"));
+ COLOR_Format8bitRGB332 = (get_static_field<int>(clazz, "COLOR_Format8bitRGB332"));
+ COLOR_Format12bitRGB444 = (get_static_field<int>(clazz, "COLOR_Format12bitRGB444"));
+ COLOR_Format16bitARGB4444 = (get_static_field<int>(clazz, "COLOR_Format16bitARGB4444"));
+ COLOR_Format16bitARGB1555 = (get_static_field<int>(clazz, "COLOR_Format16bitARGB1555"));
+ COLOR_Format16bitRGB565 = (get_static_field<int>(clazz, "COLOR_Format16bitRGB565"));
+ COLOR_Format16bitBGR565 = (get_static_field<int>(clazz, "COLOR_Format16bitBGR565"));
+ COLOR_Format18bitRGB666 = (get_static_field<int>(clazz, "COLOR_Format18bitRGB666"));
+ COLOR_Format18bitARGB1665 = (get_static_field<int>(clazz, "COLOR_Format18bitARGB1665"));
+ COLOR_Format19bitARGB1666 = (get_static_field<int>(clazz, "COLOR_Format19bitARGB1666"));
+ COLOR_Format24bitRGB888 = (get_static_field<int>(clazz, "COLOR_Format24bitRGB888"));
+ COLOR_Format24bitBGR888 = (get_static_field<int>(clazz, "COLOR_Format24bitBGR888"));
+ COLOR_Format24bitARGB1887 = (get_static_field<int>(clazz, "COLOR_Format24bitARGB1887"));
+ COLOR_Format25bitARGB1888 = (get_static_field<int>(clazz, "COLOR_Format25bitARGB1888"));
+ COLOR_Format32bitBGRA8888 = (get_static_field<int>(clazz, "COLOR_Format32bitBGRA8888"));
+ COLOR_Format32bitARGB8888 = (get_static_field<int>(clazz, "COLOR_Format32bitARGB8888"));
+ COLOR_FormatYUV411Planar = (get_static_field<int>(clazz, "COLOR_FormatYUV411Planar"));
+ COLOR_FormatYUV411PackedPlanar = (get_static_field<int>(clazz, "COLOR_FormatYUV411PackedPlanar"));
+ COLOR_FormatYUV420Planar = (get_static_field<int>(clazz, "COLOR_FormatYUV420Planar"));
+ COLOR_FormatYUV420PackedPlanar = (get_static_field<int>(clazz, "COLOR_FormatYUV420PackedPlanar"));
+ COLOR_FormatYUV420SemiPlanar = (get_static_field<int>(clazz, "COLOR_FormatYUV420SemiPlanar"));
+ COLOR_FormatYUV422Planar = (get_static_field<int>(clazz, "COLOR_FormatYUV422Planar"));
+ COLOR_FormatYUV422PackedPlanar = (get_static_field<int>(clazz, "COLOR_FormatYUV422PackedPlanar"));
+ COLOR_FormatYUV422SemiPlanar = (get_static_field<int>(clazz, "COLOR_FormatYUV422SemiPlanar"));
+ COLOR_FormatYCbYCr = (get_static_field<int>(clazz, "COLOR_FormatYCbYCr"));
+ COLOR_FormatYCrYCb = (get_static_field<int>(clazz, "COLOR_FormatYCrYCb"));
+ COLOR_FormatCbYCrY = (get_static_field<int>(clazz, "COLOR_FormatCbYCrY"));
+ COLOR_FormatCrYCbY = (get_static_field<int>(clazz, "COLOR_FormatCrYCbY"));
+ COLOR_FormatYUV444Interleaved = (get_static_field<int>(clazz, "COLOR_FormatYUV444Interleaved"));
+ COLOR_FormatRawBayer8bit = (get_static_field<int>(clazz, "COLOR_FormatRawBayer8bit"));
+ COLOR_FormatRawBayer10bit = (get_static_field<int>(clazz, "COLOR_FormatRawBayer10bit"));
+ COLOR_FormatRawBayer8bitcompressed= (get_static_field<int>(clazz, "COLOR_FormatRawBayer8bitcompressed"));
+ COLOR_FormatL2 = (get_static_field<int>(clazz, "COLOR_FormatL2"));
+ COLOR_FormatL4 = (get_static_field<int>(clazz, "COLOR_FormatL4"));
+ COLOR_FormatL8 = (get_static_field<int>(clazz, "COLOR_FormatL8"));
+ COLOR_FormatL16 = (get_static_field<int>(clazz, "COLOR_FormatL16"));
+ COLOR_FormatL24 = (get_static_field<int>(clazz, "COLOR_FormatL24"));
+ COLOR_FormatL32 = (get_static_field<int>(clazz, "COLOR_FormatL32"));
+ COLOR_FormatYUV420PackedSemiPlanar= (get_static_field<int>(clazz, "COLOR_FormatYUV420PackedSemiPlanar"));
+ COLOR_FormatYUV422PackedSemiPlanar= (get_static_field<int>(clazz, "COLOR_FormatYUV422PackedSemiPlanar"));
+ COLOR_Format18BitBGR666 = (get_static_field<int>(clazz, "COLOR_Format18BitBGR666"));
+ COLOR_Format24BitARGB6666 = (get_static_field<int>(clazz, "COLOR_Format24BitARGB6666"));
+ COLOR_Format24BitABGR6666 = (get_static_field<int>(clazz, "COLOR_Format24BitABGR6666"));
+ COLOR_TI_FormatYUV420PackedSemiPlanar = (get_static_field<int>(clazz, "COLOR_TI_FormatYUV420PackedSemiPlanar"));
+ COLOR_QCOM_FormatYUV420SemiPlanar = (get_static_field<int>(clazz, "COLOR_QCOM_FormatYUV420SemiPlanar"));
+ }
+}
+
+std::vector<int> CJNIMediaCodecInfoCodecCapabilities::colorFormats() const
+{
+ JNIEnv *env = xbmc_jnienv();
+
+ jhintArray colorFormats = get_field<jhintArray>(m_object, "numBytesOfEncryptedData");
+ jsize size = env->GetArrayLength(colorFormats.get());
+ std::vector<int> intarray;
+ intarray.resize(size);
+ env->GetIntArrayRegion(colorFormats.get(), 0, size, (jint*)intarray.data());
+
+ return intarray;
+}
+
+std::vector<CJNIMediaCodecInfoCodecProfileLevel> CJNIMediaCodecInfoCodecCapabilities::profileLevels() const
+{
+ JNIEnv *env = xbmc_jnienv();
+
+ jhobjectArray oprofileLevels = get_field<jhobjectArray>(m_object, "profileLevels");
+ jsize size = env->GetArrayLength(oprofileLevels.get());
+ std::vector<CJNIMediaCodecInfoCodecProfileLevel> profileLevels;
+ profileLevels.reserve(size);
+ for (int i = 0; i < size; i++)
+ profileLevels.push_back(CJNIMediaCodecInfoCodecProfileLevel(jhobject(env->GetObjectArrayElement(oprofileLevels.get(), i))));
+
+ return profileLevels;
+}
+
+/**********************************************************************************/
+/**********************************************************************************/
+std::string CJNIMediaCodecInfo::getName() const
+{
+ return jcast<std::string>(call_method<jhstring>(m_object,
+ "getName", "()Ljava/lang/String;"));
+}
+
+bool CJNIMediaCodecInfo::isEncoder() const
+{
+ return call_method<jboolean>(m_object,
+ "isEncoder", "()Z");
+}
+
+std::vector<std::string> CJNIMediaCodecInfo::getSupportedTypes() const
+{
+ return jcast<std::vector<std::string>>(call_method<jhobjectArray>(m_object,
+ "getSupportedTypes", "()[Ljava/lang/String;"));
+}
+
+const CJNIMediaCodecInfoCodecCapabilities CJNIMediaCodecInfo::getCapabilitiesForType(const std::string &type) const
+{
+ return call_method<jhobject>(m_object,
+ "getCapabilitiesForType", "(Ljava/lang/String;)Landroid/media/MediaCodecInfo$CodecCapabilities;",
+ jcast<jhstring>(type));
+}
diff --git a/xbmc/android/jni/MediaCodecInfo.h b/xbmc/android/jni/MediaCodecInfo.h
new file mode 100644
index 0000000000..48a3272f15
--- /dev/null
+++ b/xbmc/android/jni/MediaCodecInfo.h
@@ -0,0 +1,203 @@
+#pragma once
+/*
+ * Copyright (C) 2013 Team XBMC
+ * http://www.xbmc.org
+ *
+ * This Program is free 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 2, 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
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with XBMC; see the file COPYING. If not, see
+ * <http://www.gnu.org/licenses/>.
+ *
+ */
+
+#include "JNIBase.h"
+
+class CJNIMediaCodecInfoCodecProfileLevel : public CJNIBase
+{
+public:
+ CJNIMediaCodecInfoCodecProfileLevel(const jni::jhobject &object) : CJNIBase(object) {};
+ //~CJNIMediaCodecInfoCodecProfileLevel(){};
+
+ int profile() const;
+ int level() const;
+
+ static void PopulateStaticFields();
+
+ static int AVCProfileBaseline;
+ static int AVCProfileMain;
+ static int AVCProfileExtended;
+ static int AVCProfileHigh;
+ static int AVCProfileHigh10;
+ static int AVCProfileHigh422;
+ static int AVCProfileHigh444;
+ static int AVCLevel1;
+ static int AVCLevel1b;
+ static int AVCLevel11;
+ static int AVCLevel12;
+ static int AVCLevel13;
+ static int AVCLevel2;
+ static int AVCLevel21;
+ static int AVCLevel22;
+ static int AVCLevel3;
+ static int AVCLevel31;
+ static int AVCLevel32;
+ static int AVCLevel4;
+ static int AVCLevel41;
+ static int AVCLevel42;
+ static int AVCLevel5;
+ static int AVCLevel51;
+ static int H263ProfileBaseline;
+ static int H263ProfileH320Coding;
+ static int H263ProfileBackwardCompatible;
+ static int H263ProfileISWV2;
+ static int H263ProfileISWV3;
+ static int H263ProfileHighCompression;
+ static int H263ProfileInternet;
+ static int H263ProfileInterlace;
+ static int H263ProfileHighLatency;
+ static int H263Level10;
+ static int H263Level20;
+ static int H263Level30;
+ static int H263Level40;
+ static int H263Level45;
+ static int H263Level50;
+ static int H263Level60;
+ static int H263Level70;
+ static int MPEG4ProfileSimple;
+ static int MPEG4ProfileSimpleScalable;
+ static int MPEG4ProfileCore;
+ static int MPEG4ProfileMain;
+ static int MPEG4ProfileNbit;
+ static int MPEG4ProfileScalableTexture;
+ static int MPEG4ProfileSimpleFace;
+ static int MPEG4ProfileSimpleFBA;
+ static int MPEG4ProfileBasicAnimated;
+ static int MPEG4ProfileHybrid;
+ static int MPEG4ProfileAdvancedRealTime;
+ static int MPEG4ProfileCoreScalable;
+ static int MPEG4ProfileAdvancedCoding;
+ static int MPEG4ProfileAdvancedCore;
+ static int MPEG4ProfileAdvancedScalable;
+ static int MPEG4ProfileAdvancedSimple;
+ static int MPEG4Level0;
+ static int MPEG4Level0b;
+ static int MPEG4Level1;
+ static int MPEG4Level2;
+ static int MPEG4Level3;
+ static int MPEG4Level4;
+ static int MPEG4Level4a;
+ static int MPEG4Level5;
+ static int AACObjectMain;
+ static int AACObjectLC;
+ static int AACObjectSSR;
+ static int AACObjectLTP;
+ static int AACObjectHE;
+ static int AACObjectScalable;
+ static int AACObjectERLC;
+ static int AACObjectLD;
+ static int AACObjectHE_PS;
+ static int AACObjectELD;
+
+private:
+ CJNIMediaCodecInfoCodecProfileLevel();
+ static const char *m_classname;
+};
+/*
+Compiled from "MediaCodecInfo.java"
+public final class android.media.MediaCodecInfo$CodecProfileLevel extends java.lang.Object{
+public int profile;
+ Signature: I
+public int level;
+ Signature: I
+public android.media.MediaCodecInfo$CodecProfileLevel();
+ Signature: ()V
+}
+*/
+
+class CJNIMediaCodecInfoCodecCapabilities : public CJNIBase
+{
+public:
+ CJNIMediaCodecInfoCodecCapabilities(const jni::jhobject &object) : CJNIBase(object) {};
+ //~CJNIMediaCodecInfoCodecCapabilities() {};
+
+ std::vector<int> colorFormats() const;
+ std::vector<CJNIMediaCodecInfoCodecProfileLevel> profileLevels() const;
+
+ static void PopulateStaticFields();
+
+ static int COLOR_FormatMonochrome;
+ static int COLOR_Format8bitRGB332;
+ static int COLOR_Format12bitRGB444;
+ static int COLOR_Format16bitARGB4444;
+ static int COLOR_Format16bitARGB1555;
+ static int COLOR_Format16bitRGB565;
+ static int COLOR_Format16bitBGR565;
+ static int COLOR_Format18bitRGB666;
+ static int COLOR_Format18bitARGB1665;
+ static int COLOR_Format19bitARGB1666;
+ static int COLOR_Format24bitRGB888;
+ static int COLOR_Format24bitBGR888;
+ static int COLOR_Format24bitARGB1887;
+ static int COLOR_Format25bitARGB1888;
+ static int COLOR_Format32bitBGRA8888;
+ static int COLOR_Format32bitARGB8888;
+ static int COLOR_FormatYUV411Planar;
+ static int COLOR_FormatYUV411PackedPlanar;
+ static int COLOR_FormatYUV420Planar;
+ static int COLOR_FormatYUV420PackedPlanar;
+ static int COLOR_FormatYUV420SemiPlanar;
+ static int COLOR_FormatYUV422Planar;
+ static int COLOR_FormatYUV422PackedPlanar;
+ static int COLOR_FormatYUV422SemiPlanar;
+ static int COLOR_FormatYCbYCr;
+ static int COLOR_FormatYCrYCb;
+ static int COLOR_FormatCbYCrY;
+ static int COLOR_FormatCrYCbY;
+ static int COLOR_FormatYUV444Interleaved;
+ static int COLOR_FormatRawBayer8bit;
+ static int COLOR_FormatRawBayer10bit;
+ static int COLOR_FormatRawBayer8bitcompressed;
+ static int COLOR_FormatL2;
+ static int COLOR_FormatL4;
+ static int COLOR_FormatL8;
+ static int COLOR_FormatL16;
+ static int COLOR_FormatL24;
+ static int COLOR_FormatL32;
+ static int COLOR_FormatYUV420PackedSemiPlanar;
+ static int COLOR_FormatYUV422PackedSemiPlanar;
+ static int COLOR_Format18BitBGR666;
+ static int COLOR_Format24BitARGB6666;
+ static int COLOR_Format24BitABGR6666;
+ static int COLOR_TI_FormatYUV420PackedSemiPlanar;
+ static int COLOR_QCOM_FormatYUV420SemiPlanar;
+
+private:
+ CJNIMediaCodecInfoCodecCapabilities();
+
+ static const char *m_classname;
+};
+
+class CJNIMediaCodecInfo : public CJNIBase
+{
+public:
+ CJNIMediaCodecInfo(const jni::jhobject &object) : CJNIBase(object) {};
+ //~CJNIMediaCodecInfo() {};
+
+ std::string getName() const;
+ bool isEncoder() const;
+ std::vector<std::string> getSupportedTypes() const;
+ const CJNIMediaCodecInfoCodecCapabilities getCapabilitiesForType(const std::string &type) const;
+
+private:
+ CJNIMediaCodecInfo();
+};
+
diff --git a/xbmc/android/jni/MediaCodecList.cpp b/xbmc/android/jni/MediaCodecList.cpp
new file mode 100644
index 0000000000..9cd8b72f82
--- /dev/null
+++ b/xbmc/android/jni/MediaCodecList.cpp
@@ -0,0 +1,41 @@
+/*
+ * Copyright (C) 2013 Team XBMC
+ * http://www.xbmc.org
+ *
+ * This Program is free 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 2, 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
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with XBMC; see the file COPYING. If not, see
+ * <http://www.gnu.org/licenses/>.
+ *
+ */
+
+#include "MediaCodecList.h"
+#include "MediaCodecInfo.h"
+
+#include "jutils/jutils-details.hpp"
+
+using namespace jni;
+
+const char* CJNIMediaCodecList::m_classname = "android/media/MediaCodecList";
+
+int CJNIMediaCodecList::getCodecCount()
+{
+ return call_static_method<int>(m_classname,
+ "getCodecCount", "()I");
+}
+
+const CJNIMediaCodecInfo CJNIMediaCodecList::getCodecInfoAt(int index)
+{
+ return call_static_method<jhobject>(m_classname,
+ "getCodecInfoAt", "(I)Landroid/media/MediaCodecInfo;",
+ index);
+}
diff --git a/xbmc/android/jni/MediaCodecList.h b/xbmc/android/jni/MediaCodecList.h
new file mode 100644
index 0000000000..804428cdc0
--- /dev/null
+++ b/xbmc/android/jni/MediaCodecList.h
@@ -0,0 +1,38 @@
+#pragma once
+/*
+ * Copyright (C) 2013 Team XBMC
+ * http://www.xbmc.org
+ *
+ * This Program is free 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 2, 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
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with XBMC; see the file COPYING. If not, see
+ * <http://www.gnu.org/licenses/>.
+ *
+ */
+
+#include "JNIBase.h"
+#include "MediaCodecInfo.h"
+
+class CJNIMediaCodecList : public CJNIBase
+{
+public:
+ CJNIMediaCodecList(const jni::jhobject &object) : CJNIBase(object) {};
+ //~CJNIMediaCodecList() {};
+
+ static int getCodecCount();
+ static const CJNIMediaCodecInfo getCodecInfoAt(int index);
+
+private:
+ CJNIMediaCodecList();
+
+ static const char *m_classname;
+};
diff --git a/xbmc/android/jni/MediaCrypto.h b/xbmc/android/jni/MediaCrypto.h
new file mode 100644
index 0000000000..b080952501
--- /dev/null
+++ b/xbmc/android/jni/MediaCrypto.h
@@ -0,0 +1,29 @@
+#pragma once
+/*
+ * Copyright (C) 2013 Team XBMC
+ * http://www.xbmc.org
+ *
+ * This Program is free 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 2, 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
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with XBMC; see the file COPYING. If not, see
+ * <http://www.gnu.org/licenses/>.
+ *
+ */
+
+#include "JNIBase.h"
+
+class CJNIMediaCrypto : public CJNIBase
+{
+public:
+ CJNIMediaCrypto(const jni::jhobject &object) : CJNIBase(object) {};
+ ~CJNIMediaCrypto() {};
+};
diff --git a/xbmc/android/jni/MediaFormat.cpp b/xbmc/android/jni/MediaFormat.cpp
new file mode 100644
index 0000000000..17316fc8c4
--- /dev/null
+++ b/xbmc/android/jni/MediaFormat.cpp
@@ -0,0 +1,166 @@
+/*
+ * Copyright (C) 2013 Team XBMC
+ * http://www.xbmc.org
+ *
+ * This Program is free 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 2, 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
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with XBMC; see the file COPYING. If not, see
+ * <http://www.gnu.org/licenses/>.
+ *
+ */
+
+#include "JNIBase.h"
+#include "MediaFormat.h"
+
+#include "jutils/jutils-details.hpp"
+
+using namespace jni;
+
+std::string CJNIMediaFormat::KEY_MIME;
+std::string CJNIMediaFormat::KEY_SAMPLE_RATE;
+std::string CJNIMediaFormat::KEY_CHANNEL_COUNT;
+std::string CJNIMediaFormat::KEY_WIDTH;
+std::string CJNIMediaFormat::KEY_HEIGHT;
+std::string CJNIMediaFormat::KEY_MAX_INPUT_SIZE;
+std::string CJNIMediaFormat::KEY_BIT_RATE;
+std::string CJNIMediaFormat::KEY_COLOR_FORMAT;
+std::string CJNIMediaFormat::KEY_FRAME_RATE;
+std::string CJNIMediaFormat::KEY_I_FRAME_INTERVAL;
+std::string CJNIMediaFormat::KEY_DURATION;
+std::string CJNIMediaFormat::KEY_IS_ADTS;
+std::string CJNIMediaFormat::KEY_CHANNEL_MASK;
+std::string CJNIMediaFormat::KEY_AAC_PROFILE;
+std::string CJNIMediaFormat::KEY_FLAC_COMPRESSION_LEVEL;
+const char *CJNIMediaFormat::m_classname = "android/media/MediaFormat";
+
+void CJNIMediaFormat::PopulateStaticFields()
+{
+ if(GetSDKVersion() >= 16)
+ {
+ jhclass clazz = find_class("android/media/MediaFormat");
+ KEY_MIME = jcast<std::string>(get_static_field<jhstring>(clazz, "KEY_MIME"));
+ KEY_SAMPLE_RATE = jcast<std::string>(get_static_field<jhstring>(clazz, "KEY_SAMPLE_RATE"));
+ KEY_CHANNEL_COUNT = jcast<std::string>(get_static_field<jhstring>(clazz, "KEY_CHANNEL_COUNT"));
+ KEY_WIDTH = jcast<std::string>(get_static_field<jhstring>(clazz, "KEY_WIDTH"));
+ KEY_HEIGHT = jcast<std::string>(get_static_field<jhstring>(clazz, "KEY_HEIGHT"));
+ KEY_MAX_INPUT_SIZE = jcast<std::string>(get_static_field<jhstring>(clazz, "KEY_MAX_INPUT_SIZE"));
+ KEY_BIT_RATE = jcast<std::string>(get_static_field<jhstring>(clazz, "KEY_BIT_RATE"));
+ KEY_COLOR_FORMAT = jcast<std::string>(get_static_field<jhstring>(clazz, "KEY_COLOR_FORMAT"));
+ KEY_FRAME_RATE = jcast<std::string>(get_static_field<jhstring>(clazz, "KEY_FRAME_RATE"));
+ KEY_I_FRAME_INTERVAL= jcast<std::string>(get_static_field<jhstring>(clazz, "KEY_I_FRAME_INTERVAL"));
+ KEY_DURATION = jcast<std::string>(get_static_field<jhstring>(clazz, "KEY_DURATION"));
+ KEY_IS_ADTS = jcast<std::string>(get_static_field<jhstring>(clazz, "KEY_IS_ADTS"));
+ KEY_CHANNEL_MASK = jcast<std::string>(get_static_field<jhstring>(clazz, "KEY_CHANNEL_MASK"));
+ KEY_AAC_PROFILE = jcast<std::string>(get_static_field<jhstring>(clazz, "KEY_AAC_PROFILE"));
+ KEY_FLAC_COMPRESSION_LEVEL = jcast<std::string>(get_static_field<jhstring>(clazz, "KEY_FLAC_COMPRESSION_LEVEL"));
+ }
+}
+
+const CJNIMediaFormat CJNIMediaFormat::createAudioFormat(const std::string &mime, int sampleRate, int channelCount)
+{
+ return call_static_method<jhobject>(m_classname,
+ "createAudioFormat", "(Ljava/lang/String;II)Landroid/media/MediaFormat;",
+ jcast<jhstring>(mime), sampleRate, channelCount);
+}
+
+const CJNIMediaFormat CJNIMediaFormat::createVideoFormat(const std::string &mime, int width, int height)
+{
+ return call_static_method<jhobject>(m_classname,
+ "createVideoFormat", "(Ljava/lang/String;II)Landroid/media/MediaFormat;",
+ jcast<jhstring>(mime), width, height);
+}
+
+bool CJNIMediaFormat::containsKey(const std::string &name)
+{
+ return call_method<jboolean>(m_object,
+ "containsKey", "(Ljava/lang/String;)Z",
+ jcast<jhstring>(name));
+}
+
+int CJNIMediaFormat::getInteger(const std::string &name)
+{
+ return call_method<jint>(m_object,
+ "getInteger",
+ "(Ljava/lang/String;)I",
+ jcast<jhstring>(name));
+}
+
+int64_t CJNIMediaFormat::getLong(const std::string &name)
+{
+ return call_method<jlong>(m_object,
+ "getLong", "(Ljava/lang/String;)J",
+ jcast<jhstring>(name));
+}
+
+float CJNIMediaFormat::getFloat(const std::string &name)
+{
+ return call_method<jfloat>(m_object,
+ "getFloat", "(Ljava/lang/String;)F",
+ jcast<jhstring>(name));
+}
+
+std::string CJNIMediaFormat::getString(const std::string &name)
+{
+ jhstring jhstring_rtn = call_method<jhstring>(m_object,
+ "getString", "(Ljava/lang/String;)Ljava/lang/String;",
+ jcast<jhstring>(name));
+ return jcast<std::string>(jhstring_rtn);
+}
+
+const CJNIByteBuffer CJNIMediaFormat::getByteBuffer(const std::string &name)
+{
+ return call_method<jhobject>(m_object,
+ "getByteBuffer", "(Ljava/lang/String;)Ljava/nio/ByteBuffer;",
+ jcast<jhstring>(name));
+}
+
+void CJNIMediaFormat::setInteger(const std::string &name, int value)
+{
+ call_method<void>(m_object,
+ "setInteger", "(Ljava/lang/String;I)V",
+ jcast<jhstring>(name), value);
+}
+
+void CJNIMediaFormat::setLong(const std::string &name, int64_t value)
+{
+ call_method<void>(m_object,
+ "setLong", "(Ljava/lang/String;J)V",
+ jcast<jhstring>(name), value);
+}
+
+void CJNIMediaFormat::setFloat(const std::string &name, float value)
+{
+ call_method<void>(m_object,
+ "setFloat", "(Ljava/lang/String;F)V",
+ jcast<jhstring>(name), value);
+}
+
+void CJNIMediaFormat::setString(const std::string &name,const std::string &value)
+{
+ call_method<void>(m_object,
+ "setString", "(Ljava/lang/String;Ljava/lang/String;)V",
+ jcast<jhstring>(name), jcast<jhstring>(value));
+}
+
+void CJNIMediaFormat::setByteBuffer(const std::string &name, CJNIByteBuffer &bytes)
+{
+ call_method<void>(m_object,
+ "setByteBuffer", "(Ljava/lang/String;Ljava/nio/ByteBuffer;)V",
+ jcast<jhstring>(name), bytes.get_raw());
+}
+
+std::string CJNIMediaFormat::toString() const
+{
+ jhstring jhstring_rtn = call_method<jhstring>(m_object,
+ "toString", "()Ljava/lang/String;");
+ return jcast<std::string>(jhstring_rtn);
+}
diff --git a/xbmc/android/jni/MediaFormat.h b/xbmc/android/jni/MediaFormat.h
new file mode 100644
index 0000000000..bb40f24036
--- /dev/null
+++ b/xbmc/android/jni/MediaFormat.h
@@ -0,0 +1,68 @@
+#pragma once
+/*
+ * Copyright (C) 2013 Team XBMC
+ * http://www.xbmc.org
+ *
+ * This Program is free 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 2, 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
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with XBMC; see the file COPYING. If not, see
+ * <http://www.gnu.org/licenses/>.
+ *
+ */
+
+#include "JNIBase.h"
+#include "ByteBuffer.h"
+
+class CJNIMediaFormat : public CJNIBase
+{
+public:
+ CJNIMediaFormat(const jni::jhobject &object) : CJNIBase(object) {};
+ //~CJNIMediaFormat() {};
+
+ bool containsKey(const std::string &name);
+ int getInteger( const std::string &name);
+ int64_t getLong( const std::string &name);
+ float getFloat( const std::string &name);
+ std::string getString( const std::string &name);
+ const CJNIByteBuffer getByteBuffer(const std::string &name);
+ void setInteger( const std::string &name, int value);
+ void setLong( const std::string &name, int64_t value);
+ void setFloat( const std::string &name, float value);
+ void setString( const std::string &name, const std::string &value);
+ void setByteBuffer(const std::string &name, CJNIByteBuffer &bytes);
+ std::string toString() const;
+
+ static void PopulateStaticFields();
+ static const CJNIMediaFormat createAudioFormat(const std::string &mime, int sampleRate, int channelCount);
+ static const CJNIMediaFormat createVideoFormat(const std::string &mime, int width, int height);
+
+ static std::string KEY_MIME;
+ static std::string KEY_SAMPLE_RATE;
+ static std::string KEY_CHANNEL_COUNT;
+ static std::string KEY_WIDTH;
+ static std::string KEY_HEIGHT;
+ static std::string KEY_MAX_INPUT_SIZE;
+ static std::string KEY_BIT_RATE;
+ static std::string KEY_COLOR_FORMAT;
+ static std::string KEY_FRAME_RATE;
+ static std::string KEY_I_FRAME_INTERVAL;
+ static std::string KEY_DURATION;
+ static std::string KEY_IS_ADTS;
+ static std::string KEY_CHANNEL_MASK;
+ static std::string KEY_AAC_PROFILE;
+ static std::string KEY_FLAC_COMPRESSION_LEVEL;
+
+private:
+ CJNIMediaFormat();
+
+ static const char *m_classname;
+};
diff --git a/xbmc/android/jni/View.cpp b/xbmc/android/jni/View.cpp
new file mode 100644
index 0000000000..252e6759ad
--- /dev/null
+++ b/xbmc/android/jni/View.cpp
@@ -0,0 +1,131 @@
+/*
+ * Copyright (C) 2013 Team XBMC
+ * http://www.xbmc.org
+ *
+ * This Program is free 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 2, 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
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with XBMC; see the file COPYING. If not, see
+ * <http://www.gnu.org/licenses/>.
+ *
+ */
+
+#include "Window.h"
+#include "View.h"
+
+#include "jutils/jutils-details.hpp"
+
+using namespace jni;
+
+/************************************************************************/
+/************************************************************************/
+int CJNIViewInputDeviceMotionRange::getAxis() const
+{
+ return call_method<int>(m_object,
+ "getAxis", "()I");
+}
+
+float CJNIViewInputDeviceMotionRange::getFlat() const
+{
+ return call_method<jfloat>(m_object,
+ "getFlat", "()F");
+}
+
+float CJNIViewInputDeviceMotionRange::getFuzz() const
+{
+ return call_method<jfloat>(m_object,
+ "getFuzz", "()F");
+}
+
+float CJNIViewInputDeviceMotionRange::getMax() const
+{
+ return call_method<jfloat>(m_object,
+ "getMax", "()F");
+}
+
+float CJNIViewInputDeviceMotionRange::getMin() const
+{
+ return call_method<jfloat>(m_object,
+ "getMin", "()F");
+}
+
+float CJNIViewInputDeviceMotionRange::getRange() const
+{
+ return call_method<jfloat>(m_object,
+ "getRange", "()F");
+}
+
+int CJNIViewInputDeviceMotionRange::getSource() const
+{
+ return call_method<int>(m_object,
+ "getSource", "()I");
+}
+
+/************************************************************************/
+/************************************************************************/
+const char *CJNIViewInputDevice::m_classname = "android/view/InputDevice";
+
+const CJNIViewInputDevice CJNIViewInputDevice::getDevice(int id)
+{
+ return call_static_method<jhobject>(m_classname,
+ "getDevice", "(I)Landroid/view/InputDevice;",
+ id);
+}
+
+std::string CJNIViewInputDevice::getName() const
+{
+ return jcast<std::string>(call_method<jhstring>(m_object,
+ "getName", "()Ljava/lang/String;"));
+}
+
+const CJNIViewInputDeviceMotionRange CJNIViewInputDevice::getMotionRange(int axis) const
+{
+ return call_method<jhobject>(m_object,
+ "getMotionRange", "(I)Landroid/view/InputDevice$MotionRange;",
+ axis);
+}
+
+/************************************************************************/
+/************************************************************************/
+int CJNIView::SYSTEM_UI_FLAG_FULLSCREEN(0);
+int CJNIView::SYSTEM_UI_FLAG_HIDE_NAVIGATION(0);
+int CJNIView::SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN(0);
+int CJNIView::SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION(0);
+int CJNIView::SYSTEM_UI_FLAG_LAYOUT_STABLE(0);
+int CJNIView::SYSTEM_UI_FLAG_LOW_PROFILE(0);
+int CJNIView::SYSTEM_UI_FLAG_VISIBLE(0);
+
+void CJNIView::PopulateStaticFields()
+{
+ jhclass clazz = find_class("android/view/View");
+ if(GetSDKVersion() >= 16)
+ {
+ SYSTEM_UI_FLAG_FULLSCREEN = (get_static_field<int>(clazz, "SYSTEM_UI_FLAG_FULLSCREEN"));
+ SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN = (get_static_field<int>(clazz, "SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN"));
+ SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION = (get_static_field<int>(clazz, "SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION"));
+ SYSTEM_UI_FLAG_LAYOUT_STABLE = (get_static_field<int>(clazz, "SYSTEM_UI_FLAG_LAYOUT_STABLE"));
+ }
+ SYSTEM_UI_FLAG_HIDE_NAVIGATION = (get_static_field<int>(clazz, "SYSTEM_UI_FLAG_HIDE_NAVIGATION"));
+ SYSTEM_UI_FLAG_LOW_PROFILE = (get_static_field<int>(clazz, "SYSTEM_UI_FLAG_LOW_PROFILE"));
+ SYSTEM_UI_FLAG_VISIBLE = (get_static_field<int>(clazz, "SYSTEM_UI_FLAG_VISIBLE"));
+}
+
+void CJNIView::setSystemUiVisibility(int visibility)
+{
+ call_method<void>(m_object,
+ "setSystemUiVisibility", "(I)V", visibility);
+}
+
+int CJNIView::getSystemUiVisibility()
+{
+ return call_method<int>(m_object,
+ "getSystemUiVisibility", "()I");
+}
diff --git a/xbmc/android/jni/View.h b/xbmc/android/jni/View.h
new file mode 100644
index 0000000000..bcb1e26e95
--- /dev/null
+++ b/xbmc/android/jni/View.h
@@ -0,0 +1,76 @@
+#pragma once
+/*
+ * Copyright (C) 2013 Team XBMC
+ * http://www.xbmc.org
+ *
+ * This Program is free 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 2, 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
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with XBMC; see the file COPYING. If not, see
+ * <http://www.gnu.org/licenses/>.
+ *
+ */
+
+#include "JNIBase.h"
+
+class CJNIViewInputDeviceMotionRange : public CJNIBase
+{
+public:
+ CJNIViewInputDeviceMotionRange(const jni::jhobject &object) : CJNIBase(object) {};
+ ~CJNIViewInputDeviceMotionRange() {};
+
+ int getAxis() const;
+ float getFlat() const;
+ float getFuzz() const;
+ float getMax() const;
+ float getMin() const;
+ float getRange() const;
+ int getSource() const;
+
+private:
+ CJNIViewInputDeviceMotionRange();
+};
+
+class CJNIViewInputDevice : public CJNIBase
+{
+public:
+ CJNIViewInputDevice(const jni::jhobject &object) : CJNIBase(object) {};
+ ~CJNIViewInputDevice() {};
+
+ static const CJNIViewInputDevice getDevice(int id);
+
+ std::string getName() const;
+ const CJNIViewInputDeviceMotionRange getMotionRange(int axis) const;
+
+private:
+ CJNIViewInputDevice();
+
+ static const char *m_classname;
+};
+
+class CJNIView : public CJNIBase
+{
+public:
+ CJNIView(const jni::jhobject &object) : CJNIBase(object) {};
+ ~CJNIView() {};
+
+ void setSystemUiVisibility(int visibility);
+ int getSystemUiVisibility();
+
+ static void PopulateStaticFields();
+ static int SYSTEM_UI_FLAG_FULLSCREEN;
+ static int SYSTEM_UI_FLAG_HIDE_NAVIGATION;
+ static int SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN;
+ static int SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION;
+ static int SYSTEM_UI_FLAG_LAYOUT_STABLE;
+ static int SYSTEM_UI_FLAG_LOW_PROFILE;
+ static int SYSTEM_UI_FLAG_VISIBLE;
+};
diff --git a/xbmc/android/jni/Window.cpp b/xbmc/android/jni/Window.cpp
new file mode 100644
index 0000000000..83b08576cf
--- /dev/null
+++ b/xbmc/android/jni/Window.cpp
@@ -0,0 +1,32 @@
+/*
+ * Copyright (C) 2013 Team XBMC
+ * http://www.xbmc.org
+ *
+ * This Program is free 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 2, 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
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with XBMC; see the file COPYING. If not, see
+ * <http://www.gnu.org/licenses/>.
+ *
+ */
+
+#include "Window.h"
+#include "View.h"
+
+#include "jutils/jutils-details.hpp"
+
+using namespace jni;
+
+CJNIView CJNIWindow::getDecorView()
+{
+ return call_method<jhobject>(m_object,
+ "getDecorView", "()Landroid/view/View;");
+}
diff --git a/xbmc/android/jni/Window.h b/xbmc/android/jni/Window.h
new file mode 100644
index 0000000000..0b01a55555
--- /dev/null
+++ b/xbmc/android/jni/Window.h
@@ -0,0 +1,32 @@
+#pragma once
+/*
+ * Copyright (C) 2013 Team XBMC
+ * http://www.xbmc.org
+ *
+ * This Program is free 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 2, 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
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with XBMC; see the file COPYING. If not, see
+ * <http://www.gnu.org/licenses/>.
+ *
+ */
+
+#include "JNIBase.h"
+
+class CJNIView;
+class CJNIWindow : public CJNIBase
+{
+public:
+ CJNIWindow(const jni::jhobject &object) : CJNIBase(object) {};
+ ~CJNIWindow() {};
+
+ CJNIView getDecorView();
+};