CameraTest.java

本文介绍了一个简单的Android应用程序,用于实现相机预览功能。该程序通过SurfaceView显示摄像头画面,并使用Camera API进行摄像头操作。同时,文章提供了完整的源代码及配置文件。
package com.lx;

import android.app.Activity;
import android.graphics.PixelFormat;
import android.hardware.Camera;
import android.os.Bundle;
import android.util.Log;
import android.view.SurfaceHolder;
import android.view.SurfaceView;
import android.view.Window;
import android.view.WindowManager;

public class CameraTest extends Activity implements SurfaceHolder.Callback {

private static final String TAG = "CameraTest";
private SurfaceView mSurfaceView;
private SurfaceHolder mSurfaceHolder;
private Camera mCamera;
private boolean mPreviewRunning;

/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {

Log.i(TAG, "==============Into onCreate============");
super.onCreate(savedInstanceState);
getWindow().setFormat(PixelFormat.TRANSLUCENT);
requestWindowFeature(Window.FEATURE_NO_TITLE);
getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,
WindowManager.LayoutParams.FLAG_FULLSCREEN);
setContentView(R.layout.main);
mSurfaceView = (SurfaceView) findViewById(R.id.surface_camera);
mSurfaceHolder = mSurfaceView.getHolder();
mSurfaceHolder.addCallback(this);
mSurfaceHolder.setType(SurfaceHolder.SURFACE_TYPE_PUSH_BUFFERS);
}

public void surfaceChanged(SurfaceHolder holder, int format, int w, int h) {

if (mPreviewRunning) {
mCamera.stopPreview();
}
Camera.Parameters p = mCamera.getParameters();
p.setPreviewSize(w, h);
Log.i(TAG, "==============Into surfaceChanged============ format "+ p.getPreviewFormat() + " w: "+ w + " h: "+ h);

mCamera.setParameters(p);
try {
mCamera.setPreviewDisplay(holder);
} catch (Exception e) {
e.printStackTrace();
}
mCamera.startPreview();
mPreviewRunning = true;

}

public void surfaceCreated(SurfaceHolder holder) {
Log.i(TAG, "==============Into surfaceCreated============");
mCamera = Camera.open();

}

public void surfaceDestroyed(SurfaceHolder holder) {
Log.i(TAG, "==============Into surfaceDestroyed============");
mCamera.stopPreview();
mPreviewRunning = false;
mCamera.release();

}

Camera.PictureCallback mPictureCallback = new Camera.PictureCallback() {
public void onPictureTaken(byte[] imageData, Camera c) {
Log.i(TAG, "==============Into onPictureTaken============");
}
};

}



------------------------------------------------------

配置文件

main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="fill_parent"
android:layout_height="fill_parent">
<SurfaceView android:id="@+id/surface_camera"
android:layout_width="fill_parent" android:layout_height="10dip"
android:layout_weight="1">
</SurfaceView>
</LinearLayout>



-------------------------------------------

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.lx" android:versionCode="1" android:versionName="1.0">
<application android:icon="@drawable/icon" android:label="@string/app_name">
<activity android:name=".CameraTest" android:label="@string/app_name">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>

<uses-permission android:name="android.permission.CAMERA" />
<uses-feature android:name="android.hardware.camera" />
<uses-feature android:name="android.hardware.camera.autofocus" />
<uses-sdk android:minSdkVersion="8" />
</manifest>


E TestRunner: failed: testJpegThumbnailSize(android.hardware.cts.CameraTest) 行 1772: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: ----- begin exception ----- 行 1773: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: junit.framework.AssertionFailedError 行 1774: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: at junit.framework.Assert.fail(Assert.java:48) 行 1775: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: at junit.framework.Assert.assertTrue(Assert.java:20) 行 1776: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: at junit.framework.Assert.assertTrue(Assert.java:27) 行 1777: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: at android.hardware.cts.CameraTest.testJpegThumbnailSizeByCamera(CameraTest.java:916) 行 1778: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: at android.hardware.cts.CameraTest.testJpegThumbnailSize(CameraTest.java:906) 行 1779: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: at java.lang.reflect.Method.invoke(Native Method) 行 1780: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:59) 行 1781: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) 行 1782: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:61) 行 1783: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17) 行 1784: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: at androidx.test.internal.runner.junit4.statement.UiThreadStatement$1.run(UiThreadStatement.java:56) 行 1785: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:487) 行 1786: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: at java.util.concurrent.FutureTask.run(FutureTask.java:264) 行 1787: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:487) 行 1788: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: at java.util.concurrent.FutureTask.run(FutureTask.java:264) 行 1789: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: at android.app.Instrumentation$SyncRunnable.run(Instrumentation.java:2612) 行 1790: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: at android.os.Handler.handleCallback(Handler.java:959) 行 1791: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: at android.os.Handler.dispatchMessage(Handler.java:100) 行 1792: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: at android.os.Looper.loopOnce(Looper.java:232) 行 1793: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: at android.os.Looper.loop(Looper.java:317) 行 1794: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: at android.app.ActivityThread.main(ActivityThread.java:8705) 行 1795: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: at java.lang.reflect.Method.invoke(Native Method) 行 1796: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:580) 行 1797: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:886) 行 1798: 08-11 09:36:03.658 10131 16935 16947 E TestRunner: ----- end exception -----
08-12
06-25 03:08:55.954 1047 556 3232 E Camera3-Device: Camera 100: initialize: Could not open camera session: Function not implemented (-38) 06-25 03:08:55.954 1047 556 3232 E Camera2ClientBase: initializeImpl: Camera 100: unable to initialize device: Function not implemented (-38) 06-25 03:08:55.954 1047 556 3232 E CameraService: connectHelper: Could not initialize client from HAL. 06-25 03:08:55.954 1047 556 3232 I Camera2Client: Camera 0: Closed 06-25 03:08:55.954 1047 556 3232 D Camera2ClientBase: Camera 100: start to disconnect 06-25 03:08:55.955 1047 556 3232 D Camera2ClientBase: Camera 100: serializationLock acquired 06-25 03:08:55.955 1047 556 3232 D Camera2ClientBase: Camera 100: Shutting down 06-25 03:08:55.955 1047 556 3232 D Camera2ClientBase: Camera 100: start to cacheDump 06-25 03:08:55.955 1047 556 3232 I Camera3-Device: disconnectImpl: E 06-25 03:08:55.955 1047 556 3232 E CameraService: unregisterMonitorUid: Trying to unregister uid: 10066 which is not monitored! 06-25 03:08:55.955 1047 556 3232 I CameraService: disconnect: Disconnected client for camera 100 for PID 3801 06-25 03:08:55.956 1047 556 3232 D cameraserver: FGS Logger Transaction failed 06-25 03:08:55.956 1047 556 3232 D cameraserver: -129 06-25 03:08:55.956 1047 556 3232 I Camera2ClientBase: ~Camera2ClientBase: Client object's dtor for Camera Id 100 completed. Client was: android.camera.cts (PID 3801, UID 10066) 06-25 03:08:55.956 1047 556 3232 I Camera3-Device: disconnectImpl: E 06-25 03:08:55.986 10066 3801 3817 E TestRunner: failed: testCameraExternalConnected(android.hardware.cts.CameraTest) 06-25 03:08:55.986 10066 3801 3817 E TestRunner: ----- begin exception ----- 06-25 03:08:55.986 1000 882 978 W libprocessgroup: SetCgroup::ExecuteForProcess: failed to open /dev/stune/top-app/cgroup.procs: No such file or directory 06-25 03:08:55.987 1000 494 494 I BpBinder: onLastStrongRef automatically unlinking death recipients: 06-25 03:08:55.987 10066 3801 3817 E TestRunner: java.lang.AssertionError: Devices with external camera support must have all listed cameras be connected and openable for testing 06-25 03:08:55.987 10066 3801 3817 E TestRunner: at android.hardware.cts.CameraTest.testCameraExternalConnected(CameraTest.java:3514) 06-25 03:08:55.987 10066 3801 3817 E TestRunner: at java.lang.reflect.Method.invoke(Native Method) 06-25 03:08:55.987 10066 3801 3817 E TestRunner: at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:59) 06-25 03:08:55.987 10066 3801 3817 E TestRunner: at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) 06-25 03:08:55.987 10066 3801 3817 E TestRunner: at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:61) 06-25 03:08:55.987 10066 3801 3817 E TestRunner: at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17) 06-25 03:08:55.987 10066 3801 3817 E TestRunner: at org.junit.internal.runners.statements.FailOnTimeout$CallableStatement.call(FailOnTimeout.java:148) 06-25 03:08:55.987 10066 3801 3817 E TestRunner: at org.junit.internal.runners.statements.FailOnTimeout$CallableStatement.call(FailOnTimeout.java:142) 06-25 03:08:55.987 10066 3801 3817 E TestRunner: at java.util.concurrent.FutureTask.run(FutureTask.java:264) 06-25 03:08:55.987 10066 3801 3817 E TestRunner: at java.lang.Thread.run(Thread.java:1012) 06-25 03:08:55.987 10066 3801 3817 E TestRunner: Caused by: java.lang.RuntimeException: Fail to connect to camera service 06-25 03:08:55.987 10066 3801 3817 E TestRunner: at android.hardware.Camera.<init>(Camera.java:513) 06-25 03:08:55.987 10066 3801 3817 E TestRunner: at android.hardware.Camera.open(Camera.java:399) 06-25 03:08:55.987 10066 3801 3817 E TestRunner: at android.hardware.cts.CameraTest.testCameraExternalConnected(CameraTest.java:3511) 06-25 03:08:55.987 10066 3801 3817 E TestRunner: ... 9 more 06-25 03:08:55.988 10066 3801 3817 E TestRunner: ----- end exception -----
09-03
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值