takePicture因堆相关错误而失败

时间:2013-02-15 13:57:29

标签: java android android-camera

首先要做的事情是:在2个不同的HTC Desires上发生以下错误,一个是2.3.3,另一个是4.0.4。

尝试调用时,我收到以下错误消息.takePicture:

E/MemoryHeapBase(104): error opening /dev/pmem_camera: No such file or directory
E/QualcommCameraHardware(104): failed to construct master heap for pmem pool /dev/pmem_camera
E/QualcommCameraHardware(104): initSnapshot X failed with pmem_camera, trying with pmem_adsp

在此错误之后永远不会调用相应的PictureCallback。

我能找到的唯一解释是a)没有调用startPreview; b)尝试拍摄太快(在调用图片回调之前); c)未设置正确的使用/权限

我在这里,在我的FullscreenActivity的 onResume()中:

//open the camera resource
cam = Camera.open();

Camera.Parameters params = cam.getParameters();
//change Parameters
params.setJpegQuality(100);//best quality
params.setFlashMode(Parameters.FLASH_MODE_TORCH);
//params.setZoom(2);
List<Size> supportedPreviewSizes = cam.getParameters().getSupportedPreviewSizes();
params.setPreviewSize(supportedPreviewSizes.get(0).width, supportedPreviewSizes.get(0).height);
cam.setParameters(params);

SurfaceView sv = (SurfaceView)this.findViewById(R.id.surfaceView1);
SurfaceHolder mHolder = sv.getHolder(); 
mHolder.setType(SurfaceHolder.SURFACE_TYPE_PUSH_BUFFERS); 
mHolder.setSizeFromLayout();
mHolder.addCallback(this);

try {
    cam.setPreviewDisplay(mHolder);
} catch (IOException e) {
    Log.d(TAG, "Error setting camera preview: " + e.getMessage());
}

//Log.d(TAG, "Starting Preview");
cam.startPreview();

b)不应该适用于我,因为我只想拍一张照片

c):使用部分清单

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

其他一些代码:

我调用takePicture(请注意,此处的记录意味着允许AsyncTask在完成后再次调用takePicture。不相关但是错误仍然存​​在而没有调用AsyncTask):

findViewById(R.id.snap_button).setOnClickListener(new View.OnClickListener() {

    @Override
    public void onClick(View v) {

        recording = !recording;

        Button btn = (Button)findViewById(R.id.snap_button);
        if(recording) {
            //update buttontext
            btn.setText("Stop");
            //start recording by taking a picture
            cam.takePicture(null,null, mPicture);

        } else {
            //update button text
            btn.setText("Start");
        }

    }
});

修改 稍微改变我的布局后,最终会调用pictureCallback并获得有效数据(yay),但错误仍然存​​在。这是我目前的布局:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="horizontal" >

    <SurfaceView
        android:id="@+id/surfaceView1"
        android:layout_width="0dp"
        android:layout_height="369dp"
        android:layout_weight="1.55" />

    <LinearLayout
        android:layout_width="wrap_content"
        android:layout_height="match_parent"
        android:orientation="vertical" >

        <Button
            android:id="@+id/snap_button"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Capture" />

        <ProgressBar
            android:id="@+id/progressBar1"
            style="?android:attr/progressBarStyleLarge"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />

    </LinearLayout>

</LinearLayout>

1 个答案:

答案 0 :(得分:1)

我会说你在步骤中有一些错误。

你应该看一下这个例子: cw-android - camera preview(第127+行)。我猜你在surfaceChanged第一次SurfaceHolder.Callback之前没有等到,通常你应该调用startPreview()方法,因此你的解释

  

a)没有调用startPreview;

     

b)尝试拍摄太快(在调用图片回调之前);

可能都是正确的。