私のアプリは、カメラを使って写真を撮ろうとすると、nullポインター例外が発生します。私のアプリはこうしてカメラを呼び出します:
//go to camera app.
Intent intent = new Intent("android.media.action.IMAGE_CAPTURE");
intent.putExtra(MediaStore.EXTRA_OUTPUT,Uri.fromFile(getTempFile()));
//open camera. Take picture.
startActivityForResult(intent, PIC_ONE);
onresultコードは次のとおりです。
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data){
if (requestCode == PIC_ONE)
{
//prevent null pointer
if(data.getData()!=null){
uri1 = data.getData();
File f = new File(getPath(uri1));//<-NULL POINTER EXCEPTION
//...do stuff
}
これにより、上記のようにnullpointer例外が発生します。getPathにより、このnullポインタが発生します。getPath()を以下に示します。このメソッドは、メディアストアから画像を取得する必要があります。
public String getPath(Uri uri) {
String[] projection = { MediaStore.Images.Media.DATA };
Cursor cursor = managedQuery(uri, projection, null, null, null);
startManagingCursor(cursor);
if(cursor!=null){
int column_index = cursor.getColumnIndexOrThrow(MediaStore.Images.Media.DATA);
cursor.moveToFirst();
return cursor.getString(column_index);
}
else return null;
}
以下はlogcatです:
06-07 22:53:59.650: ERROR/AndroidRuntime(3935): java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=100, result=-1, data=Intent { act=inline-data dat=file:///mnt/sdcard/image.tmp typ=image/jpeg (has extras) }} to activity {com.myapp.myactivity/myactivity.java}: java.lang.NullPointerException
06-07 22:53:59.650: ERROR/AndroidRuntime(3935): at android.app.ActivityThread.deliverResults(ActivityThread.java:2553)
06-07 22:53:59.650: ERROR/AndroidRuntime(3935): at android.app.ActivityThread.handleSendResult(ActivityThread.java:2595)
06-07 22:53:59.650: ERROR/AndroidRuntime(3935): at android.app.ActivityThread.access$2000(ActivityThread.java:121)
06-07 22:53:59.650: ERROR/AndroidRuntime(3935): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:973)
06-07 22:53:59.650: ERROR/AndroidRuntime(3935): at android.os.Handler.dispatchMessage(Handler.java:99)
06-07 22:53:59.650: ERROR/AndroidRuntime(3935): at android.os.Looper.loop(Looper.java:138)
06-07 22:53:59.650: ERROR/AndroidRuntime(3935): at android.app.ActivityThread.main(ActivityThread.java:3701)
06-07 22:53:59.650: ERROR/AndroidRuntime(3935): at java.lang.reflect.Method.invokeNative(Native Method)
06-07 22:53:59.650: ERROR/AndroidRuntime(3935): at java.lang.reflect.Method.invoke(Method.java:507)
06-07 22:53:59.650: ERROR/AndroidRuntime(3935): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:878)
06-07 22:53:59.650: ERROR/AndroidRuntime(3935): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:636)
06-07 22:53:59.650: ERROR/AndroidRuntime(3935): at dalvik.system.NativeStart.main(Native Method)
06-07 22:53:59.650: ERROR/AndroidRuntime(3935): Caused by: java.lang.NullPointerException
06-07 22:53:59.650: ERROR/AndroidRuntime(3935): at java.io.File.fixSlashes(File.java:205)
06-07 22:53:59.650: ERROR/AndroidRuntime(3935): at java.io.File.init(File.java:189)
06-07 22:53:59.650: ERROR/AndroidRuntime(3935): at java.io.File.<init>(File.java:139)
06-07 22:53:59.650: ERROR/AndroidRuntime(3935): at com.myapp.myactivity.java.onActivityResult(myactivity.java:928)
奇妙なことに、このアプリはXperia X10で正常に動作しますが、Xperiaacroを含む新しい電話ではこのnullポインターがあります。私はそれを調査しましたが、カメラアプリが大きすぎて最初のアクティビティが終了するため、問題が発生する可能性があるようです。
だから私はこれらの2つの方法を無効にしました:
@Override
protected void onSaveInstanceState(Bundle outState) {
super.onSaveInstanceState(outState);
if (uri1 != null) {
outState.putString("cameraImageUri1", uri1.toString());
}
}
@Override
protected void onRestoreInstanceState(Bundle savedInstanceState) {
super.onRestoreInstanceState(savedInstanceState);
if (savedInstanceState.containsKey("cameraImageUri1")) {
uri1 = Uri.parse(savedInstanceState.getString("cameraImageUri1"));
}
Log.v("THIS ACTIVITY","has called onrestore...");
}
onRestoreInstanceStateは、写真の撮影および終了プロセス中にも呼び出されることはありません。だから私は何が起こっているのか分かりません。このnullポインタが呼び出されるのはなぜですか