Создание собственного приложения для камеры + Автоматический захват изображения

Я создал собственное приложение для камеры. И когда я нажимаю кнопку, она берет изображение и сохраняет его в галари. Я хочу сделать снимок без предварительного просмотра и без нажатия любой кнопки.

Мой основной класс деятельности.

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; } } 

И класс предварительного просмотра.

 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 } } 

В классе активности метод on click выглядит следующим образом.

 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); } } ); 

И когда я удаляю эту часть слушателя и ставил только

 mCamera.takePicture(null, null, mPicture); 

Сбои приложений. Я думаю, что это может быть связано с задержкой, которую приложение принимает, чтобы открыть камеру. Поэтому код пытается получить фотографию перед открытием камеры. Также ждите (10000); Не работал для меня.

А также я хочу сделать снимок без предварительного просмотра. По моим сведениям, я должен изменить класс предварительного просмотра, чтобы сделать это. Но я не знаю, как правильно это сделать.

Может ли кто-нибудь помочь мне с этим asp.

Трюк заключается в том, чтобы предоставить классу Camera SurfaceView, который не является частью иерархии представлений. Следующий код из одного из моих приложений, где я использовал эту технику, чтобы отображать мои собственные

 @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); } } 

Хорошо, я нашел ответ, чтобы сделать снимок автоматически. Добавление в качестве комментария для использования других.

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

Его просто создать другой метод с переменной таймера со 10000 задержкой, которая завершит активность предварительного просмотра, тогда вы будете сделаны. Логика заключается в том, что этот метод будет работать через 5 секунд после выполнения действия 1-го таймера.