2017-02-13 3 views
0

Я разработал действие для системы Android, и у меня возникла проблема во время выполнения: при запуске деятельности я получаю в журнале «D/Camera: app through NULL surface» и на вид поверхности не отображается изображения камеры. Я вставил в код проверку функции isValid объекта SurfaceHolder, и функция возвращает 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

Похоже, вы используете Surface независимо от того, является ли он «isValid» или нет, путем предварительной усыпки startPreview(). Поскольку вы находитесь в своем методе onCreate(), поверхность, вероятно, еще не создана. Вы должны подождать surfaceCreated() обратного вызова SurfaceHolder.Callback, прежде чем пытаться начать просмотр Camera.