2017-02-13 11 views
0

私はアンドロイドシステム上でアクティビティを開発しましたが、実行時に問題が発生します:アクティビティを開始すると、ログ "D/Camera:app passed NULL surface"で表示され、カメラの画像。 SurfaceHolderオブジェクトのisValid関数のチェックをコードに挿入し、関数はfalseを返します。Androidサーフェスが有効でない

これはアクティビティのコードです。

package marl.com.mbpspay; 

import android.hardware.Camera; 
import android.support.v7.app.AppCompatActivity; 
import android.os.Bundle; 
import android.util.Log; 
import android.view.SurfaceHolder; 
import android.view.SurfaceView; 

public class CameraActivity extends AppCompatActivity implements SurfaceHolder.Callback { 

    Camera camera; 
    SurfaceView surfaceView; 
    SurfaceHolder surfaceHolder; 

    @Override 
    protected void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.activity_camera); 

     surfaceView = (SurfaceView)findViewById(R.id.surfaceView); 
     surfaceHolder = surfaceView.getHolder(); 
     surfaceHolder.addCallback(this); 
     surfaceHolder.setType(SurfaceHolder.SURFACE_TYPE_PUSH_BUFFERS); 

     try{ 
      camera = Camera.open(Camera.CameraInfo.CAMERA_FACING_BACK); 
     }catch(RuntimeException e){ 
      Log.e("CameraActivity", "init_camera: " + e); 
      return; 
     } 

     if(surfaceHolder.getSurface().isValid()) { 
      Log.i("PreviewCallback", "Camera open [" + surfaceHolder + "]"); 
     } 
     Camera.Parameters param; 
     param = camera.getParameters(); 
     //modify parameter 
     param.setPreviewFrameRate(20); 
     param.setPreviewSize(176, 144); 
     camera.setParameters(param); 

     Camera.PreviewCallback previewCallback = new Camera.PreviewCallback() { 
      @Override 
      public void onPreviewFrame(byte[] data, Camera camera) { 
       Log.i("PreviewCallback","image get"); 
      } 
     }; 

     try { 
      Log.i("PreviewCallback","STEP 0 ["+surfaceHolder.getSurface()+"]"); 
      camera.setPreviewDisplay(surfaceHolder); 
      Log.i("PreviewCallback","STEP 1 ["+surfaceHolder+"]"); 
      camera.setPreviewCallback(previewCallback); 
      Log.i("PreviewCallback","STEP 2 ["+surfaceHolder+"]"); 
      camera.startPreview(); 
      //camera.takePicture(shutter, raw, jpeg) 
     } catch (Exception e) { 
      Log.e("CameraActivity", "init_camera: " + e); 
      return; 
     } 
    } 

    public void surfaceChanged(SurfaceHolder arg0, int arg1, int arg2, int arg3) { 
     // TODO Auto-generated method stub 
    } 

    public void surfaceCreated(SurfaceHolder holder) { 
     // TODO Auto-generated method stub 
    } 

    public void surfaceDestroyed(SurfaceHolder holder) { 
     // TODO Auto-generated method stub 
    } 

} 

ここでレイアウトのxml。

<?xml version="1.0" encoding="utf-8"?> 
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    xmlns:tools="http://schemas.android.com/tools" 
    android:id="@+id/activity_camera" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:paddingBottom="@dimen/activity_vertical_margin" 
    android:paddingLeft="@dimen/activity_horizontal_margin" 
    android:paddingRight="@dimen/activity_horizontal_margin" 
    android:paddingTop="@dimen/activity_vertical_margin" 
    tools:context="marl.com.mbpspay.CameraActivity"> 

    <SurfaceView 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     android:layout_centerVertical="true" 
     android:layout_centerHorizontal="true" 
     android:id="@+id/surfaceView" /> 
</RelativeLayout> 

誰かがこの問題の解決策を見つけることができますか?

答えて

0

「isValid」かどうかにかかわらずSurfaceを使用しているようですが、先にstartPreview()を呼び出してください。 onCreate()メソッドのため、サーフェスはまだ作成されていない可能性があります。 Cameraのプレビューを開始する前に、surfaceCreated()SurfaceHolder.Callbackのコールバックを待つ必要があります。

関連する問題