2011-12-09 21 views
-2

ビデオを録画して外部SDカードに保存しようとしています。しかし、たびに3つのエラーが発生するAndroid Nullpointer例外

誰でもチュートリアルを知っていたり、自分のコードを修正するのに役立つかもしれません。

私はこの3つのエラー

12-09 14:12:23.592: E/AndroidRuntime(4377): java.lang.NullPointerException 
    12-09 14:12:23.592: E/AndroidRuntime(4377):  at com.mahesh.VideoStreamActivity.surfaceChanged(VideoStreamActivity.java:71) 
    12-09 14:12:23.592: E/AndroidRuntime(4377):  at android.view.SurfaceView.updateWindow(SurfaceView.java:568) 
    12-09 14:12:23.592: E/AndroidRuntime(4377):  at android.view.SurfaceView.access$000(SurfaceView.java:82) 
    12-09 14:12:23.592: E/AndroidRuntime(4377):  at android.view.SurfaceView$3.onPreDraw(SurfaceView.java:171) 
    12-09 14:12:23.592: E/AndroidRuntime(4377):  at android.view.ViewTreeObserver.dispatchOnPreDraw(ViewTreeObserver.java:590) 
    12-09 14:12:23.592: E/AndroidRuntime(4377):  at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1590) 
    12-09 14:12:23.592: E/AndroidRuntime(4377):  at android.view.ViewRootImpl.handleMessage(ViewRootImpl.java:2382) 
    12-09 14:12:23.592: E/AndroidRuntime(4377):  at android.os.Handler.dispatchMessage(Handler.java:99) 
    12-09 14:12:23.592: E/AndroidRuntime(4377):  at android.os.Looper.loop(Looper.java:137) 
    12-09 14:12:23.592: E/AndroidRuntime(4377):  at android.app.ActivityThread.main(ActivityThread.java:4340) 
    12-09 14:12:23.592: E/AndroidRuntime(4377):  at java.lang.reflect.Method.invokeNative(Native Method) 
    12-09 14:12:23.592: E/AndroidRuntime(4377):  at java.lang.reflect.Method.invoke(Method.java:511) 
    12-09 14:12:23.592: E/AndroidRuntime(4377):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784) 
    12-09 14:12:23.592: E/AndroidRuntime(4377):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551) 
    12-09 14:12:23.592: E/AndroidRuntime(4377):  at dalvik.system.NativeStart.main(Native Method) 
    12-09 14:17:02.723: E/CAMERA_TUTORIAL(4596): /data/data/com.mahesh/cache/sdcard/videooutput: open failed: ENOENT (No such file or directory) 

12-09 14:17:02.723: W/System.err(4596): java.io.FileNotFoundException: /data/data/com.mahesh/cache/sdcard/videooutput: open failed: ENOENT (No such file or directory) 
12-09 14:17:02.734: W/System.err(4596):  at libcore.io.IoBridge.open(IoBridge.java:406) 
12-09 14:17:02.734: W/System.err(4596):  at java.io.FileOutputStream.<init>(FileOutputStream.java:88) 
12-09 14:17:02.734: W/System.err(4596):  at java.io.FileOutputStream.<init>(FileOutputStream.java:128) 
12-09 14:17:02.734: W/System.err(4596):  at java.io.FileOutputStream.<init>(FileOutputStream.java:117) 
12-09 14:17:02.734: W/System.err(4596):  at android.media.MediaRecorder.prepare(MediaRecorder.java:623) 
12-09 14:17:02.734: W/System.err(4596):  at com.mahesh.VideoStreamActivity.startRecording(VideoStreamActivity.java:119) 
12-09 14:17:02.734: W/System.err(4596):  at com.mahesh.VideoStreamActivity.surfaceCreated(VideoStreamActivity.java:50) 
12-09 14:17:02.743: W/System.err(4596):  at android.view.SurfaceView.updateWindow(SurfaceView.java:562) 
12-09 14:17:02.743: W/System.err(4596):  at android.view.SurfaceView.access$000(SurfaceView.java:82) 
12-09 14:17:02.743: W/System.err(4596):  at android.view.SurfaceView$3.onPreDraw(SurfaceView.java:171) 
12-09 14:17:02.743: W/System.err(4596):  at android.view.ViewTreeObserver.dispatchOnPreDraw(ViewTreeObserver.java:590) 
12-09 14:17:02.743: W/System.err(4596):  at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1590) 
12-09 14:17:02.743: W/System.err(4596):  at android.view.ViewRootImpl.handleMessage(ViewRootImpl.java:2382) 
12-09 14:17:02.743: W/System.err(4596):  at android.os.Handler.dispatchMessage(Handler.java:99) 
12-09 14:17:02.743: W/System.err(4596):  at android.os.Looper.loop(Looper.java:137) 
12-09 14:17:02.743: W/System.err(4596):  at android.app.ActivityThread.main(ActivityThread.java:4340) 
12-09 14:17:02.753: W/System.err(4596):  at java.lang.reflect.Method.invokeNative(Native Method) 
12-09 14:17:02.753: W/System.err(4596):  at java.lang.reflect.Method.invoke(Method.java:511) 
12-09 14:17:02.753: W/System.err(4596):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784) 
12-09 14:17:02.753: W/System.err(4596):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551) 
12-09 14:17:02.753: W/System.err(4596):  at dalvik.system.NativeStart.main(Native Method) 
12-09 14:17:02.753: W/System.err(4596): Caused by: libcore.io.ErrnoException: open failed: ENOENT (No such file or directory) 
12-09 14:17:02.753: W/System.err(4596):  at libcore.io.Posix.open(Native Method) 
12-09 14:17:02.753: W/System.err(4596):  at libcore.io.BlockGuardOs.open(BlockGuardOs.java:98) 
12-09 14:17:02.763: W/System.err(4596):  at libcore.io.IoBridge.open(IoBridge.java:390) 
12-09 14:17:02.763: W/System.err(4596):  ... 20 more 
12-09 14:17:02.773: D/AndroidRuntime(4596): Shutting down VM 
12-09 14:17:02.773: W/dalvikvm(4596): threadid=1: thread exiting with uncaught exception (group=0x409951f8) 
12-09 14:17:02.793: E/AndroidRuntime(4596): FATAL EXCEPTION: main 
12-09 14:17:02.793: E/AndroidRuntime(4596): java.lang.RuntimeException: setParameters failed 
12-09 14:17:02.793: E/AndroidRuntime(4596):  at android.hardware.Camera.native_setParameters(Native Method) 
12-09 14:17:02.793: E/AndroidRuntime(4596):  at android.hardware.Camera.setParameters(Camera.java:1253) 
12-09 14:17:02.793: E/AndroidRuntime(4596):  at com.mahesh.VideoStreamActivity.surfaceChanged(VideoStreamActivity.java:68) 
12-09 14:17:02.793: E/AndroidRuntime(4596):  at android.view.SurfaceView.updateWindow(SurfaceView.java:568) 
12-09 14:17:02.793: E/AndroidRuntime(4596):  at android.view.SurfaceView.access$000(SurfaceView.java:82) 
12-09 14:17:02.793: E/AndroidRuntime(4596):  at android.view.SurfaceView$3.onPreDraw(SurfaceView.java:171) 
12-09 14:17:02.793: E/AndroidRuntime(4596):  at android.view.ViewTreeObserver.dispatchOnPreDraw(ViewTreeObserver.java:590) 
12-09 14:17:02.793: E/AndroidRuntime(4596):  at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1590) 
12-09 14:17:02.793: E/AndroidRuntime(4596):  at android.view.ViewRootImpl.handleMessage(ViewRootImpl.java:2382) 
12-09 14:17:02.793: E/AndroidRuntime(4596):  at android.os.Handler.dispatchMessage(Handler.java:99) 
12-09 14:17:02.793: E/AndroidRuntime(4596):  at android.os.Looper.loop(Looper.java:137) 
12-09 14:17:02.793: E/AndroidRuntime(4596):  at android.app.ActivityThread.main(ActivityThread.java:4340) 
12-09 14:17:02.793: E/AndroidRuntime(4596):  at java.lang.reflect.Method.invokeNative(Native Method) 
12-09 14:17:02.793: E/AndroidRuntime(4596):  at java.lang.reflect.Method.invoke(Method.java:511) 
12-09 14:17:02.793: E/AndroidRuntime(4596):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784) 
12-09 14:17:02.793: E/AndroidRuntime(4596):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551) 
12-09 14:17:02.793: E/AndroidRuntime(4596):  at dalvik.system.NativeStart.main(Native Method) 

    code>>>>>>>>>>>>>>>>>>>>>>>>> 
    import java.io.File; 
    import java.io.IOException; 

    import android.app.Activity; 
    import android.graphics.PixelFormat; 
    import android.hardware.Camera; 
    import android.media.MediaRecorder; 
    import android.os.Bundle; 
    import android.util.Log; 
    import android.view.SurfaceHolder; 
    import android.view.SurfaceView; 
    import android.widget.Toast; 

    public class VideoStreamActivity extends Activity implements SurfaceHolder.Callback{ 

     private static final String TAG = "CAMERA_TUTORIAL"; 

     private SurfaceView surfaceView; 
     private SurfaceHolder surfaceHolder; 
     private Camera camera; 
     private boolean previewRunning; 
     private MediaRecorder mediaRecorder; 
     private final int maxDurationInMs = 20000; 
     private final long maxFileSizeInBytes = 500000; 
     private final int videoFramesPerSecond = 20; 
     private File tempFile; 



     String cacheFileName="/sdcard/videooutput"; 

      @Override 
      public void onCreate(Bundle savedInstanceState) { 
        super.onCreate(savedInstanceState); 
        setContentView(R.layout.camera_surface); 
        surfaceView = (SurfaceView) findViewById(R.id.surface_camera); 
        surfaceHolder = surfaceView.getHolder(); 
        surfaceHolder.addCallback(this); 
        surfaceHolder.setType(SurfaceHolder.SURFACE_TYPE_PUSH_BUFFERS); 
      } 

      @Override 
     public void surfaceCreated(SurfaceHolder holder) { 
      camera = Camera.open(); 
      if (camera != null){ 
       Camera.Parameters params = camera.getParameters(); 
       camera.setParameters(params); 

      } 
      else { 
       Toast.makeText(getApplicationContext(), "Camera not available!", Toast.LENGTH_LONG).show(); 
       finish(); 
      } 
     } 

     @Override 
     public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) { 
      if (previewRunning){ 
       camera.stopPreview(); 
      } 
      Camera.Parameters p = camera.getParameters(); 
      p.getPreferredPreviewSizeForVideo(); 
      p.setPreviewSize(width, height); 

      p.setPreviewFormat(PixelFormat.JPEG); 

      camera.setParameters(p); 

      try { 
       camera.setPreviewDisplay(holder); 
       camera.startPreview(); 
       previewRunning = true; 
      } 
      catch (IOException e) { 
       Log.e(TAG,e.getMessage()); 
       e.printStackTrace(); 
      } 
     } 

     @Override 
     public void surfaceDestroyed(SurfaceHolder holder) { 
      camera.stopPreview(); 
      previewRunning = false; 
      camera.release(); 
     } 



     public boolean startRecording(){ 
      try { 
       camera.unlock(); 

       mediaRecorder = new MediaRecorder(); 

       mediaRecorder.setCamera(camera); 
       mediaRecorder.setAudioSource(MediaRecorder.AudioSource.MIC); 
       mediaRecorder.setVideoSource(MediaRecorder.VideoSource.CAMERA); 

       mediaRecorder.setOutputFormat(MediaRecorder.OutputFormat.DEFAULT); 

       mediaRecorder.setMaxDuration(maxDurationInMs); 


       tempFile = new File(getCacheDir(),cacheFileName); 

       mediaRecorder.setOutputFile(tempFile.getPath()); 

       mediaRecorder.setVideoFrameRate(videoFramesPerSecond); 
       mediaRecorder.setVideoSize(surfaceView.getWidth(), surfaceView.getHeight()); 

       mediaRecorder.setAudioEncoder(MediaRecorder.AudioEncoder.DEFAULT); 
       mediaRecorder.setVideoEncoder(MediaRecorder.VideoEncoder.DEFAULT); 

       mediaRecorder.setPreviewDisplay(surfaceHolder.getSurface()); 

       mediaRecorder.setMaxFileSize(maxFileSizeInBytes); 

          mediaRecorder.prepare(); 
       mediaRecorder.start(); 

       return true; 
      } catch (IllegalStateException e) { 
       Log.e(TAG,e.getMessage()); 
       e.printStackTrace(); 
       return false; 
      } catch (IOException e) { 
       Log.e(TAG,e.getMessage()); 
       e.printStackTrace(); 
       return false; 
      } 
     } 

     public void stopRecording(){ 
      mediaRecorder.stop(); 
      camera.lock(); 
     } 
    } 

答えて

3

はあなたが開いているファイルのパスを見てみましょう取得していていずれかが私を助けることができる:

/data/data/com.mahesh/cache/sdcard/videooutput 

あなたが使用してファイルを開いているように見えます不正なパス。コードなしでは他に何も言わない。

0

これは、開発ツールではるかに簡単です。最初は、あなたがinstatiatedされていないオブジェクトへのポインタを呼び出しているか、ポインタがアドレスを設定していないことを示します。

2番目の方法は、存在しないファイルを開こうとしているという点で、パスまたはファイル名が間違っている可能性があります。

他の2つが修正されると、3番目のページが表示されます。

エラーメッセージで指定された行にブレークポイントを配置し、渡される値を確認してください。

関連する問題