2012-10-04 3 views
0

나는이 코드를 시도 :Android 앱에 사진을 저장할 때 RuntimeException이 발생합니까?

public class pantalla8 extends Activity { 

    private static final int CAPTURE_IMAGE_ACTIVITY_REQUEST_CODE = 100; 
    private Uri fileUri; 
    public static final int MEDIA_TYPE_IMAGE = 1; 

    public void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.camera); 

     final Button camera = (Button) findViewById(R.id.boton12); 
     camera.setOnClickListener(new OnClickListener(){ 
      public void onClick(View arg0){ 
       Intent cameraIntent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE); 
       fileUri = getOutputMediaFileUri(MEDIA_TYPE_IMAGE); 
       cameraIntent.putExtra(MediaStore.EXTRA_OUTPUT, fileUri); 
       startActivityForResult(cameraIntent, CAPTURE_IMAGE_ACTIVITY_REQUEST_CODE); 
      } 
     }); 
    } 

    private static Uri getOutputMediaFileUri(int type){ 
      return Uri.fromFile(getOutputMediaFile(type)); 
    } 


    private static File getOutputMediaFile(int type){ 
     String state = Environment.getExternalStorageState(); 

     if (Environment.MEDIA_MOUNTED.equals(state)) { 
      File mediaStorageDir = new File(Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_PICTURES), "MyCameraApp"); 
      if (! mediaStorageDir.exists()){ 
       if (! mediaStorageDir.mkdirs()){ 
        Log.d("MyCameraApp", "failed to create directory"); 
        return null; 
       } 
      } 

      String timeStamp = new SimpleDateFormat("yyyyMMdd_HHmmss").format(new Date()); 
      File mediaFile; 
      if (type == MEDIA_TYPE_IMAGE){ 
       mediaFile = new File(mediaStorageDir.getPath() + File.separator + 
       "IMG_"+ timeStamp + ".jpg"); 
      } else { 
       return null; 
      } 

      return mediaFile; 
     } else { 
      return null; 
     } 
    } 

    @Override 
    protected void onActivityResult(int requestCode, int resultCode, Intent data) { 
     if (requestCode == CAPTURE_IMAGE_ACTIVITY_REQUEST_CODE) { 
      if (resultCode == RESULT_OK) { 
       Toast.makeText(this, "Image saved to:\n" + 
         data.getData(), Toast.LENGTH_LONG).show(); 
      } else if (resultCode == RESULT_CANCELED) { 
       Toast.makeText(this, "Cancelado", Toast.LENGTH_SHORT).show(); 
      } else { 
       Toast.makeText(this, "Falla", Toast.LENGTH_SHORT).show(); 
      } 
     } 
    } 
} 

파일 MyCameraApp이 제대로 생성되고 사진이 제대로이 디렉토리에 저장됩니다,하지만 난 런타임 예외 받고 있어요 :

10-04 14:22:16.398: E/AndroidRuntime(6952): FATAL EXCEPTION: main 
10-04 14:22:16.398: E/AndroidRuntime(6952): java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=100, result=-1, data=null} to activity {tian.proto/tian.proto.pantalla8}: java.lang.NullPointerException 
10-04 14:22:16.398: E/AndroidRuntime(6952):  at android.app.ActivityThread.deliverResults(ActivityThread.java:2536) 
10-04 14:22:16.398: E/AndroidRuntime(6952):  at android.app.ActivityThread.handleSendResult(ActivityThread.java:2578) 
10-04 14:22:16.398: E/AndroidRuntime(6952):  at android.app.ActivityThread.access$2000(ActivityThread.java:117) 
10-04 14:22:16.398: E/AndroidRuntime(6952):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:965) 
10-04 14:22:16.398: E/AndroidRuntime(6952):  at android.os.Handler.dispatchMessage(Handler.java:99) 
10-04 14:22:16.398: E/AndroidRuntime(6952):  at android.os.Looper.loop(Looper.java:130) 
10-04 14:22:16.398: E/AndroidRuntime(6952):  at android.app.ActivityThread.main(ActivityThread.java:3687) 
10-04 14:22:16.398: E/AndroidRuntime(6952):  at java.lang.reflect.Method.invokeNative(Native Method) 
10-04 14:22:16.398: E/AndroidRuntime(6952):  at java.lang.reflect.Method.invoke(Method.java:507) 
10-04 14:22:16.398: E/AndroidRuntime(6952):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:842) 
10-04 14:22:16.398: E/AndroidRuntime(6952):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:600) 
10-04 14:22:16.398: E/AndroidRuntime(6952):  at dalvik.system.NativeStart.main(Native Method) 
10-04 14:22:16.398: E/AndroidRuntime(6952): Caused by: java.lang.NullPointerException 
10-04 14:22:16.398: E/AndroidRuntime(6952):  at tian.proto.pantalla8.onActivityResult(pantalla8.java:95) 
10-04 14:22:16.398: E/AndroidRuntime(6952):  at android.app.Activity.dispatchActivityResult(Activity.java:3908) 
10-04 14:22:16.398: E/AndroidRuntime(6952):  at android.app.ActivityThread.deliverResults(ActivityThread.java:2532) 
10-04 14:22:16.398: E/AndroidRuntime(6952):  ... 11 more 

그렇게하지를 왜 그런지 아는 사람 ... 내가 뭘 잘못하고 있는지 말해 줄 수 있니? AsyncTask 스레드 내에서 카메라 인 텐트를 호출해야합니까?

미리 감사드립니다.

답변

0

중단 점과 디버깅을 사용하여 확인하십시오. 그러나 onActivityResult에서 만드는 유일한 개체 호출은 data.getData()이므로 데이터가 null 인 것으로 추측합니다.

+0

네, 그렇긴하지만 왜 null입니까? 그게 내가 이해 못하는거야 ... 그런데, 답장을 보내 주셔서 감사합니다 ... –

+0

나는 내 머리 꼭대기에서 잘 모르겠다. 내가 카메라의 의도와 함께 연주 한 이후로 잠시 지났습니다. 런타임 예외 대신 카메라 앱에서 결과 데이터 null을 검색합니다. 당신은 아마 google에 무언가를 찾아 낼 것이다. – toadzky

관련 문제