Commit d36f8b9e authored by Alexander Smorkalov's avatar Alexander Smorkalov

Code review comments applied

Sample renamed to CameraControl;
Picture taking added to show camera preview restart.
parent 86f7a357
...@@ -16,7 +16,7 @@ add_subdirectory(tutorial-1-addopencv) ...@@ -16,7 +16,7 @@ add_subdirectory(tutorial-1-addopencv)
add_subdirectory(tutorial-2-opencvcamera) add_subdirectory(tutorial-2-opencvcamera)
add_subdirectory(tutorial-3-native) add_subdirectory(tutorial-3-native)
add_subdirectory(tutorial-4-mixed) add_subdirectory(tutorial-4-mixed)
add_subdirectory(tutorial-5-customcamera) add_subdirectory(tutorial-5-cameracontrol)
#hello-android sample #hello-android sample
if(HAVE_opencv_highgui) if(HAVE_opencv_highgui)
......
<?xml version="1.0" encoding="UTF-8"?> <?xml version="1.0" encoding="UTF-8"?>
<projectDescription> <projectDescription>
<name>OpenCV Tutorial 5 - Custom camera</name> <name>OpenCV Tutorial 5 - Camera Control</name>
<comment></comment> <comment></comment>
<projects> <projects>
</projects> </projects>
......
...@@ -9,7 +9,7 @@ ...@@ -9,7 +9,7 @@
android:icon="@drawable/icon" android:icon="@drawable/icon"
android:theme="@android:style/Theme.NoTitleBar.Fullscreen" > android:theme="@android:style/Theme.NoTitleBar.Fullscreen" >
<activity android:name="Sample5CustomCamera" <activity android:name="Sample5CameraControl"
android:label="@string/app_name" android:label="@string/app_name"
android:screenOrientation="landscape" android:screenOrientation="landscape"
android:configChanges="keyboardHidden|orientation"> android:configChanges="keyboardHidden|orientation">
...@@ -34,5 +34,6 @@ ...@@ -34,5 +34,6 @@
<uses-feature android:name="android.hardware.camera.autofocus" android:required="false"/> <uses-feature android:name="android.hardware.camera.autofocus" android:required="false"/>
<uses-feature android:name="android.hardware.camera.front" android:required="false"/> <uses-feature android:name="android.hardware.camera.front" android:required="false"/>
<uses-feature android:name="android.hardware.camera.front.autofocus" android:required="false"/> <uses-feature android:name="android.hardware.camera.front.autofocus" android:required="false"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
</manifest> </manifest>
set(sample example-tutorial-5-customcamera) set(sample example-tutorial-5-cameracontrol)
add_android_project(${sample} "${CMAKE_CURRENT_SOURCE_DIR}" LIBRARY_DEPS ${OpenCV_BINARY_DIR} SDK_TARGET 11 ${ANDROID_SDK_TARGET}) add_android_project(${sample} "${CMAKE_CURRENT_SOURCE_DIR}" LIBRARY_DEPS ${OpenCV_BINARY_DIR} SDK_TARGET 11 ${ANDROID_SDK_TARGET})
if(TARGET ${sample}) if(TARGET ${sample})
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="match_parent" > android:layout_height="match_parent" >
<org.opencv.samples.tutorial5.CustomJavaCameraView <org.opencv.samples.tutorial5.SampleJavaCameraView
android:layout_width="fill_parent" android:layout_width="fill_parent"
android:layout_height="fill_parent" android:layout_height="fill_parent"
android:visibility="gone" android:visibility="gone"
......
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<resources> <resources>
<string name="app_name">OCV T5 Custom Camera</string> <string name="app_name">OCV T5 Camera Control</string>
</resources> </resources>
...@@ -11,16 +11,20 @@ import org.opencv.android.CameraBridgeViewBase.CvCameraViewListener; ...@@ -11,16 +11,20 @@ import org.opencv.android.CameraBridgeViewBase.CvCameraViewListener;
import android.app.Activity; import android.app.Activity;
import android.os.Bundle; import android.os.Bundle;
import android.os.Environment;
import android.util.Log; import android.util.Log;
import android.view.Menu; import android.view.Menu;
import android.view.MenuItem; import android.view.MenuItem;
import android.view.MotionEvent;
import android.view.SurfaceView; import android.view.SurfaceView;
import android.view.View;
import android.view.View.OnTouchListener;
import android.view.WindowManager; import android.view.WindowManager;
public class Sample5CustomCamera extends Activity implements CvCameraViewListener { public class Sample5CameraControl extends Activity implements CvCameraViewListener, OnTouchListener {
private static final String TAG = "OCVSample::Activity"; private static final String TAG = "OCVSample::Activity";
private CustomJavaCameraView mOpenCvCameraView; private SampleJavaCameraView mOpenCvCameraView;
private MenuItem[] mEffectMenuItems; private MenuItem[] mEffectMenuItems;
private BaseLoaderCallback mLoaderCallback = new BaseLoaderCallback(this) { private BaseLoaderCallback mLoaderCallback = new BaseLoaderCallback(this) {
...@@ -31,6 +35,7 @@ public class Sample5CustomCamera extends Activity implements CvCameraViewListene ...@@ -31,6 +35,7 @@ public class Sample5CustomCamera extends Activity implements CvCameraViewListene
{ {
Log.i(TAG, "OpenCV loaded successfully"); Log.i(TAG, "OpenCV loaded successfully");
mOpenCvCameraView.enableView(); mOpenCvCameraView.enableView();
mOpenCvCameraView.setOnTouchListener(Sample5CameraControl.this);
} break; } break;
default: default:
{ {
...@@ -40,7 +45,7 @@ public class Sample5CustomCamera extends Activity implements CvCameraViewListene ...@@ -40,7 +45,7 @@ public class Sample5CustomCamera extends Activity implements CvCameraViewListene
} }
}; };
public Sample5CustomCamera() { public Sample5CameraControl() {
Log.i(TAG, "Instantiated new " + this.getClass()); Log.i(TAG, "Instantiated new " + this.getClass());
} }
...@@ -53,7 +58,7 @@ public class Sample5CustomCamera extends Activity implements CvCameraViewListene ...@@ -53,7 +58,7 @@ public class Sample5CustomCamera extends Activity implements CvCameraViewListene
setContentView(R.layout.tutorial5_surface_view); setContentView(R.layout.tutorial5_surface_view);
mOpenCvCameraView = (CustomJavaCameraView) findViewById(R.id.tutorial5_activity_java_surface_view); mOpenCvCameraView = (SampleJavaCameraView) findViewById(R.id.tutorial5_activity_java_surface_view);
mOpenCvCameraView.setVisibility(SurfaceView.VISIBLE); mOpenCvCameraView.setVisibility(SurfaceView.VISIBLE);
...@@ -112,4 +117,11 @@ public class Sample5CustomCamera extends Activity implements CvCameraViewListene ...@@ -112,4 +117,11 @@ public class Sample5CustomCamera extends Activity implements CvCameraViewListene
mOpenCvCameraView.setEffect((String) item.getTitle()); mOpenCvCameraView.setEffect((String) item.getTitle());
return true; return true;
} }
@Override
public boolean onTouch(View v, MotionEvent event) {
Log.i(TAG,"onTouch event");
mOpenCvCameraView.takePicture(Environment.getExternalStorageDirectory().getPath() + "/sample_picture.jpg");
return false;
}
} }
package org.opencv.samples.tutorial5; package org.opencv.samples.tutorial5;
import java.io.FileOutputStream;
import java.util.List; import java.util.List;
import org.opencv.android.JavaCameraView; import org.opencv.android.JavaCameraView;
import android.content.Context; import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.hardware.Camera; import android.hardware.Camera;
import android.hardware.Camera.PictureCallback;
import android.util.AttributeSet; import android.util.AttributeSet;
import android.util.Log;
public class CustomJavaCameraView extends JavaCameraView { public class SampleJavaCameraView extends JavaCameraView {
public CustomJavaCameraView(Context context, AttributeSet attrs) { private static final String TAG = "Sample::SampleJavaCameraView";
public SampleJavaCameraView(Context context, AttributeSet attrs) {
super(context, attrs); super(context, attrs);
} }
...@@ -27,4 +34,27 @@ public class CustomJavaCameraView extends JavaCameraView { ...@@ -27,4 +34,27 @@ public class CustomJavaCameraView extends JavaCameraView {
params.setColorEffect(effect); params.setColorEffect(effect);
mCamera.setParameters(params); mCamera.setParameters(params);
} }
public void takePicture(final String fileName) {
Log.i(TAG, "Tacking picture");
PictureCallback callback = new PictureCallback() {
private String mPictureFileName = fileName;
@Override
public void onPictureTaken(byte[] data, Camera camera) {
Log.i(TAG, "Saving a bitmap to file");
Bitmap picture = BitmapFactory.decodeByteArray(data, 0, data.length);
try {
FileOutputStream out = new FileOutputStream(mPictureFileName);
picture.compress(Bitmap.CompressFormat.JPEG, 90, out);
mCamera.startPreview();
} catch (Exception e) {
e.printStackTrace();
}
}
};
mCamera.takePicture(null, null, callback);
}
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment