summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNanang Izzuddin <nanang@teluu.com>2015-03-23 06:28:40 +0000
committerNanang Izzuddin <nanang@teluu.com>2015-03-23 06:28:40 +0000
commit2a4634c8e713cf6a781136f7bc3059db3104de97 (patch)
treec60e53754e04badf4049d39507dd0f7ef53d3269
parent9022f2f9cf0d1f99abb33e2393f78897c3cdbefa (diff)
Re #1822: Moved Android camera helper (PjCamera.java and PjCameraInfo.java) from sample app to pjmedia-video dev dir.
git-svn-id: http://svn.pjsip.org/repos/pjproject/trunk@5018 74dad513-b988-da41-8d7b-12977e46ad98
-rw-r--r--pjmedia/src/pjmedia-videodev/android/PjCamera.java (renamed from pjsip-apps/src/pjsua/android/src/org/pjsip/PjCamera.java)402
-rw-r--r--pjmedia/src/pjmedia-videodev/android/PjCameraInfo.java (renamed from pjsip-apps/src/pjsua/android/src/org/pjsip/PjCameraInfo.java)202
-rw-r--r--pjsip-apps/src/pjsua/android/jni/Android.mk7
-rw-r--r--pjsip-apps/src/swig/java/Makefile4
4 files changed, 330 insertions, 285 deletions
diff --git a/pjsip-apps/src/pjsua/android/src/org/pjsip/PjCamera.java b/pjmedia/src/pjmedia-videodev/android/PjCamera.java
index 1beffa49..a192a9b3 100644
--- a/pjsip-apps/src/pjsua/android/src/org/pjsip/PjCamera.java
+++ b/pjmedia/src/pjmedia-videodev/android/PjCamera.java
@@ -1,192 +1,210 @@
-package org.pjsip;
-
-import android.graphics.SurfaceTexture;
-import android.hardware.Camera;
-import android.util.Log;
-import android.view.SurfaceView;
-import android.view.SurfaceHolder;
-
-import java.io.IOException;
-
-public class PjCamera implements Camera.PreviewCallback, SurfaceHolder.Callback
-{
- private final String TAG = "PjCamera";
-
- public class Param {
- public int width;
- public int height;
- public int format;
- public int fps1000;
- }
-
- private Camera camera = null;
- private boolean isRunning = false;
- private int camIdx;
- private long userData;
-
- private Param param = null;
-
- private SurfaceView surfaceView = null;
- private SurfaceHolder surfaceHolder = null;
- private SurfaceTexture surfaceTexture = null;
-
- public PjCamera(int idx, int w, int h, int fmt, int fps,
- long userData_, SurfaceView surface)
- {
- camIdx = idx;
- userData = userData_;
-
- param = new Param();
- param.width = w;
- param.height = h;
- param.format = fmt;
- param.fps1000 = fps;
-
- SetSurfaceView(surface);
- }
-
- public void SetSurfaceView(SurfaceView surface)
- {
- boolean isCaptureRunning = isRunning;
-
- if (isCaptureRunning)
- Stop();
-
- if (surface != null) {
- surfaceView = surface;
- surfaceHolder = surfaceView.getHolder();
- } else {
- // Create dummy texture
- surfaceHolder = null;
- surfaceView = null;
- if (surfaceTexture == null) {
- surfaceTexture = new SurfaceTexture(10);
- }
- }
-
- if (isCaptureRunning)
- Start();
- }
-
- public int SwitchDevice(int idx)
- {
- boolean isCaptureRunning = isRunning;
- int oldIdx = camIdx;
-
- if (isCaptureRunning)
- Stop();
-
- camIdx = idx;
-
- if (isCaptureRunning) {
- int ret = Start();
- if (ret != 0) {
- /* Try to revert back */
- camIdx = oldIdx;
- Start();
- return ret;
- }
- }
-
- return 0;
- }
-
- public int Start()
- {
- try {
- camera = Camera.open(camIdx);
- } catch (Exception e) {
- Log.d("IOException", e.getMessage());
- return -10;
- }
-
- try {
- if (surfaceHolder != null) {
- camera.setPreviewDisplay(surfaceHolder);
- surfaceHolder.addCallback(this);
- } else {
- camera.setPreviewTexture(surfaceTexture);
- }
- } catch (IOException e) {
- Log.d("IOException", e.getMessage());
- return -20;
- }
-
- Camera.Parameters cp = camera.getParameters();
- cp.setPreviewSize(param.width, param.height);
- cp.setPreviewFormat(param.format);
- // Some devices such as Nexus require an exact FPS range from the
- // supported FPS ranges, specifying a subset range will raise
- // exception.
- //cp.setPreviewFpsRange(param.fps1000, param.fps1000);
- try {
- camera.setParameters(cp);
- } catch (RuntimeException e) {
- Log.d("RuntimeException", e.getMessage());
- return -30;
- }
-
- camera.setPreviewCallback(this);
- camera.startPreview();
- isRunning = true;
-
- return 0;
- }
-
- public void Stop()
- {
- isRunning = false;
- if (camera == null)
- return;
-
- if (surfaceHolder != null)
- surfaceHolder.removeCallback(this);
-
- camera.setPreviewCallback(null);
- camera.stopPreview();
- camera.release();
- camera = null;
- }
-
- native void PushFrame(byte[] data, int length, long userData_);
-
- public void onPreviewFrame(byte[] data, Camera camera)
- {
- if (isRunning) {
- PushFrame(data, data.length, userData);
- }
- }
-
- public void surfaceChanged(SurfaceHolder holder,
- int format, int width, int height)
- {
- Log.d(TAG, "VideoCaptureAndroid::surfaceChanged");
- }
-
- public void surfaceCreated(SurfaceHolder holder)
- {
- Log.d(TAG, "VideoCaptureAndroid::surfaceCreated");
- try {
- if(camera != null) {
- camera.setPreviewDisplay(holder);
- }
- } catch (IOException e) {
- Log.e(TAG, "Failed to set preview surface!", e);
- }
- }
-
- public void surfaceDestroyed(SurfaceHolder holder)
- {
- Log.d(TAG, "VideoCaptureAndroid::surfaceDestroyed");
- try {
- if(camera != null) {
- camera.setPreviewDisplay(null);
- }
- } catch (IOException e) {
- Log.e(TAG, "Failed to clear preview surface!", e);
- } catch (RuntimeException e) {
- Log.w(TAG, "Clear preview surface useless", e);
- }
- }
-
-}
+/* $Id$ */
+/*
+ * Copyright (C) 2015 Teluu Inc. (http://www.teluu.com)
+ *
+ * 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 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ */
+package org.pjsip;
+
+import android.graphics.SurfaceTexture;
+import android.hardware.Camera;
+import android.util.Log;
+import android.view.SurfaceView;
+import android.view.SurfaceHolder;
+
+import java.io.IOException;
+
+public class PjCamera implements Camera.PreviewCallback, SurfaceHolder.Callback
+{
+ private final String TAG = "PjCamera";
+
+ public class Param {
+ public int width;
+ public int height;
+ public int format;
+ public int fps1000;
+ }
+
+ private Camera camera = null;
+ private boolean isRunning = false;
+ private int camIdx;
+ private long userData;
+
+ private Param param = null;
+
+ private SurfaceView surfaceView = null;
+ private SurfaceHolder surfaceHolder = null;
+ private SurfaceTexture surfaceTexture = null;
+
+ public PjCamera(int idx, int w, int h, int fmt, int fps,
+ long userData_, SurfaceView surface)
+ {
+ camIdx = idx;
+ userData = userData_;
+
+ param = new Param();
+ param.width = w;
+ param.height = h;
+ param.format = fmt;
+ param.fps1000 = fps;
+
+ SetSurfaceView(surface);
+ }
+
+ public void SetSurfaceView(SurfaceView surface)
+ {
+ boolean isCaptureRunning = isRunning;
+
+ if (isCaptureRunning)
+ Stop();
+
+ if (surface != null) {
+ surfaceView = surface;
+ surfaceHolder = surfaceView.getHolder();
+ } else {
+ // Create dummy texture
+ surfaceHolder = null;
+ surfaceView = null;
+ if (surfaceTexture == null) {
+ surfaceTexture = new SurfaceTexture(10);
+ }
+ }
+
+ if (isCaptureRunning)
+ Start();
+ }
+
+ public int SwitchDevice(int idx)
+ {
+ boolean isCaptureRunning = isRunning;
+ int oldIdx = camIdx;
+
+ if (isCaptureRunning)
+ Stop();
+
+ camIdx = idx;
+
+ if (isCaptureRunning) {
+ int ret = Start();
+ if (ret != 0) {
+ /* Try to revert back */
+ camIdx = oldIdx;
+ Start();
+ return ret;
+ }
+ }
+
+ return 0;
+ }
+
+ public int Start()
+ {
+ try {
+ camera = Camera.open(camIdx);
+ } catch (Exception e) {
+ Log.d("IOException", e.getMessage());
+ return -10;
+ }
+
+ try {
+ if (surfaceHolder != null) {
+ camera.setPreviewDisplay(surfaceHolder);
+ surfaceHolder.addCallback(this);
+ } else {
+ camera.setPreviewTexture(surfaceTexture);
+ }
+ } catch (IOException e) {
+ Log.d("IOException", e.getMessage());
+ return -20;
+ }
+
+ Camera.Parameters cp = camera.getParameters();
+ cp.setPreviewSize(param.width, param.height);
+ cp.setPreviewFormat(param.format);
+ // Some devices such as Nexus require an exact FPS range from the
+ // supported FPS ranges, specifying a subset range will raise
+ // exception.
+ //cp.setPreviewFpsRange(param.fps1000, param.fps1000);
+ try {
+ camera.setParameters(cp);
+ } catch (RuntimeException e) {
+ Log.d("RuntimeException", e.getMessage());
+ return -30;
+ }
+
+ camera.setPreviewCallback(this);
+ camera.startPreview();
+ isRunning = true;
+
+ return 0;
+ }
+
+ public void Stop()
+ {
+ isRunning = false;
+ if (camera == null)
+ return;
+
+ if (surfaceHolder != null)
+ surfaceHolder.removeCallback(this);
+
+ camera.setPreviewCallback(null);
+ camera.stopPreview();
+ camera.release();
+ camera = null;
+ }
+
+ native void PushFrame(byte[] data, int length, long userData_);
+
+ public void onPreviewFrame(byte[] data, Camera camera)
+ {
+ if (isRunning) {
+ PushFrame(data, data.length, userData);
+ }
+ }
+
+ public void surfaceChanged(SurfaceHolder holder,
+ int format, int width, int height)
+ {
+ Log.d(TAG, "VideoCaptureAndroid::surfaceChanged");
+ }
+
+ public void surfaceCreated(SurfaceHolder holder)
+ {
+ Log.d(TAG, "VideoCaptureAndroid::surfaceCreated");
+ try {
+ if(camera != null) {
+ camera.setPreviewDisplay(holder);
+ }
+ } catch (IOException e) {
+ Log.e(TAG, "Failed to set preview surface!", e);
+ }
+ }
+
+ public void surfaceDestroyed(SurfaceHolder holder)
+ {
+ Log.d(TAG, "VideoCaptureAndroid::surfaceDestroyed");
+ try {
+ if(camera != null) {
+ camera.setPreviewDisplay(null);
+ }
+ } catch (IOException e) {
+ Log.e(TAG, "Failed to clear preview surface!", e);
+ } catch (RuntimeException e) {
+ Log.w(TAG, "Clear preview surface useless", e);
+ }
+ }
+
+}
diff --git a/pjsip-apps/src/pjsua/android/src/org/pjsip/PjCameraInfo.java b/pjmedia/src/pjmedia-videodev/android/PjCameraInfo.java
index 2f4e9cf5..d1c71939 100644
--- a/pjsip-apps/src/pjsua/android/src/org/pjsip/PjCameraInfo.java
+++ b/pjmedia/src/pjmedia-videodev/android/PjCameraInfo.java
@@ -1,92 +1,110 @@
-package org.pjsip;
-
-import java.util.List;
-
-import android.hardware.Camera;
-import android.util.Log;
-
-public class PjCameraInfo {
- public int facing;
- public int orient;
- public int[] supportedSize; // [w1, h1, w2, h2, ...]
- public int[] supportedFps1000; // [min1, max1, min2, max2, ...]
- public int[] supportedFormat; // [fmt1, fmt2, ...]
-
- // convert Format list {fmt1, fmt2, ...} to [fmt1, fmt2, ...]
- private static int[] IntegerListToIntArray(List<Integer> list)
- {
- int[] li = new int[list.size()];
- int i = 0;
- for (Integer e : list) {
- li[i++] = e.intValue();
- }
- return li;
- }
-
- // convert Fps list {[min1, max1], [min2, max2], ...} to
- // [min1, max1, min2, max2, ...]
- private static int[] IntArrayListToIntArray(List<int[]> list)
- {
- int[] li = new int[list.size() * 2];
- int i = 0;
- for (int[] e : list) {
- li[i++] = e[0];
- li[i++] = e[1];
- }
- return li;
- }
-
- // convert Size list {{w1, h1}, {w2, h2}, ...} to [w1, h1, w2, h2, ...]
- private static int[] CameraSizeListToIntArray(List<Camera.Size> list)
- {
- int[] li = new int[list.size() * 2];
- int i = 0;
- for (Camera.Size e : list) {
- li[i++] = e.width;
- li[i++] = e.height;
- }
- return li;
- }
-
- public static int GetCameraCount()
- {
- return Camera.getNumberOfCameras();
- }
-
- // Get camera info: facing, orientation, supported size/fps/format.
- // Camera must not be opened.
- public static PjCameraInfo GetCameraInfo(int idx)
- {
- if (idx < 0 || idx >= GetCameraCount())
- return null;
-
- Camera cam;
- try {
- cam = Camera.open(idx);
- } catch (Exception e) {
- Log.d("IOException", e.getMessage());
- return null;
- }
-
- PjCameraInfo pjci = new PjCameraInfo();
-
- Camera.CameraInfo ci = new Camera.CameraInfo();
- Camera.getCameraInfo(idx, ci);
-
- pjci.facing = ci.facing;
- pjci.orient = ci.orientation;
-
- Camera.Parameters param = cam.getParameters();
- cam.release();
- cam = null;
-
- pjci.supportedFormat = IntegerListToIntArray(
- param.getSupportedPreviewFormats());
- pjci.supportedFps1000 = IntArrayListToIntArray(
- param.getSupportedPreviewFpsRange());
- pjci.supportedSize = CameraSizeListToIntArray(
- param.getSupportedPreviewSizes());
-
- return pjci;
- }
-}
+/* $Id$ */
+/*
+ * Copyright (C) 2015 Teluu Inc. (http://www.teluu.com)
+ *
+ * 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 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ */
+package org.pjsip;
+
+import java.util.List;
+
+import android.hardware.Camera;
+import android.util.Log;
+
+public class PjCameraInfo {
+ public int facing;
+ public int orient;
+ public int[] supportedSize; // [w1, h1, w2, h2, ...]
+ public int[] supportedFps1000; // [min1, max1, min2, max2, ...]
+ public int[] supportedFormat; // [fmt1, fmt2, ...]
+
+ // convert Format list {fmt1, fmt2, ...} to [fmt1, fmt2, ...]
+ private static int[] IntegerListToIntArray(List<Integer> list)
+ {
+ int[] li = new int[list.size()];
+ int i = 0;
+ for (Integer e : list) {
+ li[i++] = e.intValue();
+ }
+ return li;
+ }
+
+ // convert Fps list {[min1, max1], [min2, max2], ...} to
+ // [min1, max1, min2, max2, ...]
+ private static int[] IntArrayListToIntArray(List<int[]> list)
+ {
+ int[] li = new int[list.size() * 2];
+ int i = 0;
+ for (int[] e : list) {
+ li[i++] = e[0];
+ li[i++] = e[1];
+ }
+ return li;
+ }
+
+ // convert Size list {{w1, h1}, {w2, h2}, ...} to [w1, h1, w2, h2, ...]
+ private static int[] CameraSizeListToIntArray(List<Camera.Size> list)
+ {
+ int[] li = new int[list.size() * 2];
+ int i = 0;
+ for (Camera.Size e : list) {
+ li[i++] = e.width;
+ li[i++] = e.height;
+ }
+ return li;
+ }
+
+ public static int GetCameraCount()
+ {
+ return Camera.getNumberOfCameras();
+ }
+
+ // Get camera info: facing, orientation, supported size/fps/format.
+ // Camera must not be opened.
+ public static PjCameraInfo GetCameraInfo(int idx)
+ {
+ if (idx < 0 || idx >= GetCameraCount())
+ return null;
+
+ Camera cam;
+ try {
+ cam = Camera.open(idx);
+ } catch (Exception e) {
+ Log.d("IOException", e.getMessage());
+ return null;
+ }
+
+ PjCameraInfo pjci = new PjCameraInfo();
+
+ Camera.CameraInfo ci = new Camera.CameraInfo();
+ Camera.getCameraInfo(idx, ci);
+
+ pjci.facing = ci.facing;
+ pjci.orient = ci.orientation;
+
+ Camera.Parameters param = cam.getParameters();
+ cam.release();
+ cam = null;
+
+ pjci.supportedFormat = IntegerListToIntArray(
+ param.getSupportedPreviewFormats());
+ pjci.supportedFps1000 = IntArrayListToIntArray(
+ param.getSupportedPreviewFpsRange());
+ pjci.supportedSize = CameraSizeListToIntArray(
+ param.getSupportedPreviewSizes());
+
+ return pjci;
+ }
+}
diff --git a/pjsip-apps/src/pjsua/android/jni/Android.mk b/pjsip-apps/src/pjsua/android/jni/Android.mk
index b1f99af6..826da8d3 100644
--- a/pjsip-apps/src/pjsua/android/jni/Android.mk
+++ b/pjsip-apps/src/pjsua/android/jni/Android.mk
@@ -28,8 +28,13 @@ LOCAL_LDFLAGS := $(APP_LDFLAGS)
LOCAL_LDLIBS := $(MY_MODULES) $(APP_LDLIBS)
LOCAL_SRC_FILES := $(MY_JNI_WRAP) pjsua_app_callback.cpp
+# Copy Java Camera helper components from pjmedia/src/pjmedia-videodev/android
+src/org/pjsip/PjCamera.java:
+ @echo "Copying Android camera helper components..."
+ cp -u $(PJDIR)/pjmedia/src/pjmedia-videodev/android/PjCamera*.java src/org/pjsip
+
# Invoke SWIG
-$(MY_JNI_DIR)/$(MY_JNI_WRAP):
+$(MY_JNI_DIR)/$(MY_JNI_WRAP): src/org/pjsip/PjCamera.java
@echo "Invoking SWIG..."
$(MY_SWIG) -c++ -o $(MY_JNI_DIR)/$(MY_JNI_WRAP) -package org.pjsip.pjsua -outdir src/org/pjsip/pjsua -java $(MY_JNI_DIR)/pjsua.i
diff --git a/pjsip-apps/src/swig/java/Makefile b/pjsip-apps/src/swig/java/Makefile
index f24bdddd..19da66dc 100644
--- a/pjsip-apps/src/swig/java/Makefile
+++ b/pjsip-apps/src/swig/java/Makefile
@@ -176,6 +176,10 @@ clean distclean realclean:
$(MY_PACKAGE_PATH)/*.java $(MY_PACKAGE_PATH)/*.class
java: $(MY_PACKAGE_PATH)/Error.class $(MY_PACKAGE_PATH)/test.class $(MY_PACKAGE_PATH)/sample.class
+ifeq ($(OS),android)
+ @echo "Copying Android camera helper components..."
+ cp -u $(PJDIR)/pjmedia/src/pjmedia-videodev/android/PjCamera*.java $(MY_PACKAGE_PATH)/..
+endif
$(MY_PACKAGE_PATH)/Error.class: $(MY_PACKAGE_PATH)/Error.java
$(MY_JAVAC) -d $(OUT_DIR) $(MY_PACKAGE_PATH)/*.java $(MY_APP_JAVA)