takePicture 失败并出现与堆相关的错误

Posted

技术标签:

【中文标题】takePicture 失败并出现与堆相关的错误【英文标题】:takePicture fails with heap related error 【发布时间】:2013-01-31 12:34:00 【问题描述】:

第一件事:以下错误发生在 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() 中执行 a):

//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");
        

    
);

编辑: 在稍微改变了我的布局之后,终于调用了图片回调,我得到了有效的数据(耶),但是错误仍然存​​在。这是我当前的布局:

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

    <SurfaceView
        android:id="@+id/surfaceView1"
        android:layout_
        android:layout_
        android:layout_weight="1.55" />

    <LinearLayout
        android:layout_
        android:layout_
        android:orientation="vertical" >

        <Button
            android:id="@+id/snap_button"
            android:layout_
            android:layout_
            android:text="Capture" />

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

    </LinearLayout>

</LinearLayout>

【问题讨论】:

问题解决了吗? 执行此代码时是否安装了 SD 卡? forum.xda-developers.com/showthread.php?t=819037#6 我正在将拍摄的照片保存到 sdcard 上,因此人们会认为它已正确安装。我刚刚尝试卸载并重新安装,但错误消息仍然存在。 我认为关键错误是第三个错误,它说在找不到 pmem_camera 后,它切换到 pmem_adsp,这大概是成功的。我不知道为什么 pmem_camera 没有在你的系统上初始化。 【参考方案1】:

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

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

a) 未调用 startPreview;

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

可能都是正确的。

【讨论】:

这就是我目前正在做的事情,并且错误消息仍然存在。我认为过早调用 startPreview 会导致不同的错误 能否附上完整的代码。我可以使用 Android 2.3.3 在我的 HTC Desire 上进行测试,因此如果消息仍然存在,我们可以消除硬件或供应商问题 :)

以上是关于takePicture 失败并出现与堆相关的错误的主要内容,如果未能解决你的问题,请参考以下文章

Android 相机 takePicture() 失败

致命异常:java.lang.RuntimeException:takePicture 失败

我制作的 vue 前端编译失败,出现一个错误,提示“未找到此相关模块模块”

数据流作业在 BigQuery 写入失败并出现后端错误

Packer 自定义映像构建失败并出现 ssh 身份验证错误

WiFiDirect discoverServices 不断失败并出现错误 3 (NO_SERVICE_REQUESTS)