2012-03-24 15 views
6

He creado mi propia aplicación de cámara. Y cuando hago clic en el botón, toma la fotografía y la guarda en la galaxia. Lo que quiero hacer es tomar la foto sin una vista previa y sin hacer clic en ningún botón.Creando mi propia aplicación de cámara + Capturo automáticamente la imagen

Mi principal clase de actividad.

package themiya.camera.android; 

import java.io.File; 
import java.io.FileNotFoundException; 
import java.io.FileOutputStream; 
import java.io.IOException; 
import java.text.SimpleDateFormat; 
import java.util.Calendar; 
import java.util.Date; 

import android.app.Activity; 
import android.content.Context; 
import android.content.pm.PackageManager; 
import android.hardware.Camera; 
import android.hardware.Camera.PictureCallback; 
import android.net.Uri; 
import android.os.Bundle; 
import android.os.Environment; 
import android.provider.MediaStore; 
import android.view.View; 
import android.widget.Button; 
import android.widget.FrameLayout; 
import android.widget.Toast; 

public class CameraActivity extends Activity { 

private Camera mCamera; 
private CameraPreview mPreview; 
public static final int MEDIA_TYPE_IMAGE = 1; 


@Override 
public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.main); 
    Button captureButton = (Button) findViewById(R.id.button_capture); 
    System.out.println("Starting!"); 

    // Create an instance of Camera 
    mCamera = getCameraInstance(); 
    // Create our Preview view and set it as the content of our activity. 
    mPreview = new CameraPreview(this, mCamera); 
    FrameLayout preview = (FrameLayout) findViewById(R.id.camera_preview); 
    preview.addView(mPreview); 

    final PictureCallback mPicture = new PictureCallback() { 

     public void onPictureTaken(byte[] data, Camera camera) { 

      File pictureFile = getOutputMediaFile(MEDIA_TYPE_IMAGE); 

      if (pictureFile == null){ 
       return; 
      } 

      try { 
       FileOutputStream fos = new FileOutputStream(pictureFile); 
       fos.write(data); 
       fos.close(); 
       MediaStore.Images.Media.insertImage(getContentResolver(), pictureFile.getAbsolutePath(), pictureFile.getName(), pictureFile.getName()); 
      } catch (FileNotFoundException e) { 

      } catch (IOException e) { 

      } 
      } 
     }; 





    // Add a listener to the Capture button 
     captureButton.setOnClickListener(

      new View.OnClickListener() { 

       public void onClick(View v) { 
        // get an image from the camera 

        System.out.println("Photo Taking!"); 
        mCamera.takePicture(null, null, mPicture); 



       } 
      } 
     ); 




} 




/** A safe way to get an instance of the Camera object. */ 
public static Camera getCameraInstance(){ 
    Camera c = null; 
    try { 
     c = Camera.open(); // attempt to get a Camera instance 
    } 
    catch (Exception e){ 
     // Camera is not available (in use or does not exist) 
    } 
    return c; // returns null if camera is unavailable 
} 

@Override 
protected void onPause() { 
    super.onPause(); 
    releaseCamera();    // release the camera immediately on pause event 
} 



private void releaseCamera(){ 
    if (mCamera != null){ 
     mCamera.release();  // release the camera for other applications 
     mCamera = null; 
    } 
} 



/** Create a File for saving an image or video */ 
private File getOutputMediaFile(int type){ 
    // To be safe, you should check that the SDCard is mounted 
    // using Environment.getExternalStorageState() before doing this. 

    File mediaStorageDir = new File(Environment.getExternalStoragePublicDirectory(
       Environment.DIRECTORY_PICTURES), "MyCameraApp"); 


    // This location works best if you want the created images to be shared 
    // between applications and persist after your app has been uninstalled. 

    // Create the storage directory if it does not exist 
    if (! mediaStorageDir.exists()){ 
     if (! mediaStorageDir.mkdirs()){ 
      return null; 
     } 
    } 

    // Create a media file name 
    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; 
} 
} 

Y la clase de vista previa.

package themiya.camera.android; 

import android.content.Context; 
import android.hardware.Camera; 
import android.view.SurfaceHolder; 
import android.view.SurfaceView; 

public class CameraPreview extends SurfaceView implements SurfaceHolder.Callback{ 

    private SurfaceHolder mHolder; 
    private Camera mCamera; 

    public CameraPreview(Context context,Camera camera) { 
     super(context); 
     mCamera = camera; 

     /*SurfaceView view = new SurfaceView(this); 
     c.setPreviewDisplay(view.getHolder()); 
     c.startPreview(); 
     c.takePicture(shutterCallback, rawPictureCallback, jpegPictureCallback); 
     * */ 

     // Install a SurfaceHolder.Callback so we get notified when the 
     // underlying surface is created and destroyed. 
     mHolder = getHolder(); 

     mHolder.addCallback(this); 
     // deprecated setting, but required on Android versions prior to 3.0 
     mHolder.setType(SurfaceHolder.SURFACE_TYPE_PUSH_BUFFERS); 


    } 

    public void surfaceChanged(SurfaceHolder holder, int format, int width, 
      int height) { 
     // TODO Auto-generated method stub 

     if (mHolder.getSurface() == null){ 
      // preview surface does not exist 
      return; 
      } 

      // stop preview before making changes 
      try { 
       mCamera.stopPreview(); 
      } catch (Exception e){ 
      // ignore: tried to stop a non-existent preview 
      } 

      // set preview size and make any resize, rotate or 
      // reformatting changes here 

      // start preview with new settings 
      try { 
       mCamera.setPreviewDisplay(mHolder); 
       mCamera.startPreview(); 

      } catch (Exception e){ 

      } 

    } 

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

    } 

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

    } 

} 

En la clase de actividad, el método de hacer clic es el siguiente.

captureButton.setOnClickListener(

      new View.OnClickListener() { 

       public void onClick(View v) { 
         // get an image from the camera 

        System.out.println("Photo Taking!"); 
        mCamera.takePicture(null, null, mPicture); 



       } 
      } 
     ); 

Y cuando quito esa parte oyente y de venta sólo la aplicación se bloquea parte

mCamera.takePicture(null, null, mPicture); 

. Creo que eso puede deberse a la demora que la aplicación demora en abrir la cámara. Así que, intente obtener la fotografía antes de abrir la cámara. También espere (10000); no funcionó para mí

Y también quiero tomar la foto sin la vista previa. De acuerdo con mi conocimiento, tengo que cambiar la clase de vista previa para hacer eso. Pero no sé la forma correcta de hacerlo.

¿Alguien puede ayudarme con este asp.

+0

Ok he encontrado una respuesta para tomar la imagen de forma automática .... Timer final de t = new Timer(); \t t.schedule (nueva TimerTask() { \t \t \t \t \t \t \t \t @ Override \t \t \t \t public void run() { mCamera.takePicture (null, null, mPicture); \t \t \t \t \t t.cancel(); \t \t \t \t} \t \t \t}, 5000); Ahora quiero detener la vista previa ... – MoraRockey

Respuesta

0

Ok Encontré una respuesta para tomar la foto automáticamente. Agregar como comentario para el uso de otros.

final Timer t = new Timer(); 
t.schedule(new TimerTask() { 
@Override 
public void run() { 
mCamera.takePicture(null, null, mPicture); t.cancel(); 
} 
},5000); 
5

el truco es dar a la clase de cámara un SurfaceView que no es parte de la jerarquía de vista. El siguiente código es de una de mis aplicaciones donde i utilizado esta técnica para mostrar mi propia

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

    @Override 
    protected void onPause() { 
     super.onPause(); 
     if (mCamera != null) { 
      mCamera.stopPreview(); 
      mCamera.release(); 
      mCamera = null; 
     } 
    } 

    @Override 
    protected void onResume() { 
     super.onResume(); 
     mCamera = Camera.open(); 
     startPreview(); 
    } 

    private void startPreview() { 
      if (mCamera != null) { 
       mCamera.stopPreview(); 
       try { 
        mCamera.setPreviewDisplay(new SurfaceView(this).getHolder()); 
       } catch (IOException e) { 
        e.printStackTrace(); 
       } 
       mCamera.setPreviewCallbackWithBuffer(this); 

       Camera.Parameters parameters = mCamera.getParameters();  
       parameters.setPreviewSize(IMAGE_W, IMAGE_H); 
       mCamera.setParameters(parameters); 
       PixelFormat p = new PixelFormat(); 
       PixelFormat.getPixelFormatInfo(parameters.getPreviewFormat(), p); 
       int bufSize = (IMAGE_W * IMAGE_H * p.bitsPerPixel)/8; 
       mCamera.addCallbackBuffer(new byte[bufSize]); 
       mCamera.startPreview(); 
      } 
     } 
    public void onPreviewFrame(final byte[] data, Camera camera) { 
     if (mCamera == null) { 
      return; 
     } 
     mCamera.addCallbackBuffer(data); 
    } 
} 
-1

su sencillo crear otro método con una variable de temporizador con retardo 10000 que acaba la actividad de la vista previa, entonces se hará. La lógica es que este método se ejecutará 5 segundos después de que se complete la actividad del temporizador 1.

Cuestiones relacionadas