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 失败并出现与堆相关的错误的主要内容,如果未能解决你的问题,请参考以下文章
致命异常:java.lang.RuntimeException:takePicture 失败
我制作的 vue 前端编译失败,出现一个错误,提示“未找到此相关模块模块”
Packer 自定义映像构建失败并出现 ssh 身份验证错误
WiFiDirect discoverServices 不断失败并出现错误 3 (NO_SERVICE_REQUESTS)