2010.11.16———android Camera 拍照的两个问题
1、setParameters failed 异常信息如下
原因在于
这两个属性 如果这两个属性设置的和真实手机的不一样时,就会报上面的错误 很是郁闷
最好的方法 就是 不设置这两项
2、java.lang.NullPointerException
其实 这个原因 是因为
这个方法是异步执行的 也就是说
new MyPictureCallback()还没有执行完成,
下面的代码就开始执行了 这时候 picFile就是空的 所以就会报空指针异常
解决方法 把
1、setParameters failed 异常信息如下
- 11-1611:21:33.902:WARN/System.err(27218):java.lang.RuntimeException:setParametersfailed
- 11-1611:21:33.902:WARN/System.err(27218):atandroid.hardware.Camera.native_setParameters(NativeMethod)
- ...
- ...
原因在于
- parameters.setPreviewSize()//设置预览照片的大小
- parameters.setPictureSize()//设置照片的大小
这两个属性 如果这两个属性设置的和真实手机的不一样时,就会报上面的错误 很是郁闷
最好的方法 就是 不设置这两项
2、java.lang.NullPointerException
- 11-1613:33:39.801:ERROR/AndroidRuntime(5676):FATALEXCEPTION:main
- 11-1613:33:39.801:ERROR/AndroidRuntime(5676):java.lang.NullPointerException
- 11-1613:33:39.801:ERROR/AndroidRuntime(5676):atcom.huitu.project.PicActivity.onKeyDown(PicActivity.java:87)
- 11-1613:33:39.801:ERROR/AndroidRuntime(5676):atandroid.view.KeyEvent.dispatch(KeyEvent.java:1257)
- 11-1613:33:39.801:ERROR/AndroidRuntime(5676):atandroid.app.Activity.dispatchKeyEvent(Activity.java:2075)
其实 这个原因 是因为
- @Override
- publicbooleanonKeyDown(intkeyCode,KeyEventevent){
- if(event.getRepeatCount()==0&&camera!=null){
- switch(keyCode){
- caseKeyEvent.KEYCODE_SEARCH://按下的是搜索键
- camera.autoFocus(null);//自动对焦
- returntrue;
- caseKeyEvent.KEYCODE_CAMERA:
- caseKeyEvent.KEYCODE_DPAD_CENTER:
- camera.takePicture(null,null,newMyPictureCallback());
- Intentdata=newIntent();
- data.putExtra("picFile",picFile.getAbsolutePath());
- setResult(100,data);
- finish();
- returntrue;
- }
- }
- returnsuper.onKeyDown(keyCode,event);
- }
- privatefinalclassMyPictureCallbackimplementsPictureCallback{
- privateStringname="pic";
- publicvoidonPictureTaken(byte[]data,Cameracamera){
- try{
- Bitmapbitmap=BitmapFactory.decodeByteArray(data,0,data.length);
- picFile=newFile(Environment.getExternalStorageDirectory(),name+System.currentTimeMillis()+".jpg");
- FileOutputStreamoutStream=newFileOutputStream(picFile);
- bitmap.compress(CompressFormat.JPEG,100,outStream);
- outStream.close();
- //camera.startPreview();
- }catch(Exceptione){
- e.printStackTrace();
- }
- }
- }
- camera.takePicture(null,null,newMyPictureCallback());
new MyPictureCallback()还没有执行完成,
- Intentdata=newIntent();
- data.putExtra("picFile",picFile.getAbsolutePath());
- setResult(100,data);
- finish();
下面的代码就开始执行了 这时候 picFile就是空的 所以就会报空指针异常
解决方法 把
- Intentdata=newIntent();
- data.putExtra("picFile",picFile.getAbsolutePath());
- setResult(100,data);
- finish();
- 放到MyPictureCallback()里面最后执行即可
因为项目中有用到相机拍照功能,所以研究了下camera。
在实践的过程中发现两个问题:
1、用模拟器启动不了camera,提示:java.lang.runtimeException:setparameters failed.....
因为parameters.setPictureSize(320, 480)(设置分辨率)的参数有误,
如果不清楚分辨率可以却掉这句话,再运行就OK 了。
如果真的想看分辨率可以看logcat日志上面有写:getParameters(....)里面就是一些相关的参数。
2、连续两次以上的拍照,会出现异常:java.lang.RuntimeException:fail to connect to camera service。
因为没有对camera进行释放,或者说系统有自动释放功能但是还没有被处理。可以通过手动释放:
/**
* 停止预览
*/
@Override
public void surfaceDestroyed(SurfaceHolder holder) {
// TODO Auto-generated method stub
mCamera.stopPreview();
mCamera.release();//加上这句,就OK!
mCamera=null;
}
在实践的过程中发现两个问题:
1、用模拟器启动不了camera,提示:java.lang.runtimeException:setparameters failed.....
因为parameters.setPictureSize(320, 480)(设置分辨率)的参数有误,
如果不清楚分辨率可以却掉这句话,再运行就OK 了。
如果真的想看分辨率可以看logcat日志上面有写:getParameters(....)里面就是一些相关的参数。
2、连续两次以上的拍照,会出现异常:java.lang.RuntimeException:fail to connect to camera service。
因为没有对camera进行释放,或者说系统有自动释放功能但是还没有被处理。可以通过手动释放:
/**
* 停止预览
*/
@Override
public void surfaceDestroyed(SurfaceHolder holder) {
// TODO Auto-generated method stub
mCamera.stopPreview();
mCamera.release();//加上这句,就OK!
mCamera=null;
}