【发布时间】:2015-02-22 10:59:25
【问题描述】:
我正在 Activity 中拍照,但出现此错误:
活动加载正常,当我按下拍照然后崩溃。
12-24 17:22:19.347: E/AndroidRuntime(32764): FATAL EXCEPTION: main
12-24 17:22:19.347: E/AndroidRuntime(32764): java.lang.NullPointerException
12-24 17:22:19.347: E/AndroidRuntime(32764): at java.io.File.fixSlashes(File.java:185)
12-24 17:22:19.347: E/AndroidRuntime(32764): at java.io.File.<init>(File.java:134)
12-24 17:22:19.347: E/AndroidRuntime(32764): at com.example.CameraActivity$1.onPictureTaken(CameraActivity.java:287)
12-24 17:22:19.347: E/AndroidRuntime(32764): at android.hardware.Camera$EventHandler.handleMessage(Camera.java:855)
12-24 17:22:19.347: E/AndroidRuntime(32764): at android.os.Handler.dispatchMessage(Handler.java:107)
12-24 17:22:19.347: E/AndroidRuntime(32764): at android.os.Looper.loop(Looper.java:194)
12-24 17:22:19.347: E/AndroidRuntime(32764): at android.app.ActivityThread.main(ActivityThread.java:5449)
12-24 17:22:19.347: E/AndroidRuntime(32764): at java.lang.reflect.Method.invokeNative(Native Method)
12-24 17:22:19.347: E/AndroidRuntime(32764): at java.lang.reflect.Method.invoke(Method.java:525)
12-24 17:22:19.347: E/AndroidRuntime(32764): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:833)
12-24 17:22:19.347: E/AndroidRuntime(32764): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:600)
12-24 17:22:19.347: E/AndroidRuntime(32764): at dalvik.system.NativeStart.main(Native Method)
nnnnnnnn nnnnnnnnnnnn nnnnnnnnnnnn nnnnnnnnnnnnnnnn 这是我的代码公园:
private PictureCallback mPicture = new PictureCallback() {
@Override
public void onPictureTaken(byte[] data, Camera camera) {
Log.e("camera test", "1111");
File pictureFile = new File( outFile ); //********* LINE 287
if (pictureFile == null){
Log.d(TAG, "Error creating media file, check storage permissions: ");
return;
}
/*
imageCrop(data, pictureFile, 0, (int)(1200 / 720 * top_px), 1200, 1200);
Intent returnIntent = new Intent();
returnIntent.putExtra("capturedFile",pictureFile.getAbsolutePath());
setResult(RESULT_OK,returnIntent);
finish();
*/
try {
FileOutputStream fos = new FileOutputStream(pictureFile);
fos.write(data);
fos.close();
BitmapFactory.Options options = new BitmapFactory.Options();
options.inJustDecodeBounds = true;
Bitmap btemp = BitmapFactory.decodeFile(outFile,options);
Log.e("picture captured", options.outHeight + "|" + options.outWidth);
Intent returnIntent = new Intent();
returnIntent.putExtra("capturedFile",pictureFile.getAbsolutePath());
setResult(RESULT_OK,returnIntent);
finish();
} catch (FileNotFoundException e) {
Log.d(TAG, "File not found: " + e.getMessage());
} catch (IOException e) {
Log.d(TAG, "Error accessing file: " + e.getMessage());
}
}
};
-----------更新代码 ---------- ---------------------------------------------
我有一个调用自定义拍照活动的片段。
意图额外传递给活动调用不起作用。如果我打印 logcat,我可以在 Fragment 中看到意图。但是 Activity 没有收到它。
片段:
Intent intent = new Intent();
intent.setClass(getActivity(), CameraActivity.class);
Uri fileUri = getOutputMediaFileUri(MEDIA_TYPE_IMAGE);
intent.putExtra("outFile", fileUri);
Log.e(TAG, "" +
"------------------------------------------------------ " +
"fileUri intent => " + fileUri);
startActivityForResult(intent, CAPTURE_IMAGE_ACTIVITY_REQUEST_CODE);
活动:
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_camera);
Intent intent = getIntent();
outFile = intent.getStringExtra("outFile");
String test = getIntent().getExtras().getString("outFile");
Log.i("CameraActivity", "" +
"- " +
"test intent => " + test);
Log.e("CameraActivity", "" +
"- " +
"intent.getStringExtra(outFile) => " + intent.getStringExtra("outFile"));
Log.e("CameraActivity", "" +
"- " +
"outFile intent => " + outFile);
LogCat:
来自片段:
12-26 11:12:21.399: E/PostProductFragment(3563): - fileUri intent => file:///mnt/sdcard/Pictures/MyCameraApp/IMG_20141226_111221.jpg
来自活动日志:
12-26 11:12:21.449: I/CameraActivity(3563): - test intent => null
12-26 11:12:21.449: E/CameraActivity(3563): - intent.getStringExtra(outFile) => null
12-26 11:12:21.449: E/CameraActivity(3563): - outFile intent => null
【问题讨论】:
-
所以
outFile为空,你检查了吗? -
查看
outFile的值你初始化了吗? -
看起来您的变量 outFile 为空。你在哪里初始化它?尝试使用调试器获取更多信息。
-
onCreate - Intent intent = getIntent(); outFile = intent.getStringExtra("outFile");这里不对劲。谢谢
-
如果
outFile为null,它将在IOException 中被捕获。
标签: java android android-activity error-handling android-camera